Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(172)

Side by Side Diff: webkit/browser/fileapi/copy_or_move_operation_delegate_unittest.cc

Issue 23463048: Implement stream based cross file system copy. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "webkit/browser/fileapi/copy_or_move_operation_delegate.h"
kinuko 2013/09/21 10:44:36 afaik having this header at the top of unittest fi
hidehiko 2013/09/23 08:18:10 Ok, Done. # But about half of unittest files in th
kinuko 2013/09/23 22:10:20 Yup, there was an era when we were told to do so,
6
5 #include <map> 7 #include <map>
6 #include <queue> 8 #include <queue>
7 9
8 #include "base/basictypes.h" 10 #include "base/basictypes.h"
9 #include "base/bind.h" 11 #include "base/bind.h"
12 #include "base/file_util.h"
10 #include "base/files/scoped_temp_dir.h" 13 #include "base/files/scoped_temp_dir.h"
11 #include "base/message_loop/message_loop.h" 14 #include "base/message_loop/message_loop.h"
12 #include "base/run_loop.h" 15 #include "base/run_loop.h"
13 #include "base/stl_util.h" 16 #include "base/stl_util.h"
14 #include "testing/gtest/include/gtest/gtest.h" 17 #include "testing/gtest/include/gtest/gtest.h"
18 #include "webkit/browser/blob/file_stream_reader.h"
15 #include "webkit/browser/fileapi/async_file_test_helper.h" 19 #include "webkit/browser/fileapi/async_file_test_helper.h"
16 #include "webkit/browser/fileapi/copy_or_move_file_validator.h" 20 #include "webkit/browser/fileapi/copy_or_move_file_validator.h"
21 #include "webkit/browser/fileapi/file_stream_writer.h"
17 #include "webkit/browser/fileapi/file_system_backend.h" 22 #include "webkit/browser/fileapi/file_system_backend.h"
18 #include "webkit/browser/fileapi/file_system_context.h" 23 #include "webkit/browser/fileapi/file_system_context.h"
19 #include "webkit/browser/fileapi/file_system_operation.h" 24 #include "webkit/browser/fileapi/file_system_operation.h"
20 #include "webkit/browser/fileapi/file_system_url.h" 25 #include "webkit/browser/fileapi/file_system_url.h"
21 #include "webkit/browser/fileapi/mock_file_system_context.h" 26 #include "webkit/browser/fileapi/mock_file_system_context.h"
22 #include "webkit/browser/fileapi/test_file_set.h" 27 #include "webkit/browser/fileapi/test_file_set.h"
23 #include "webkit/browser/fileapi/test_file_system_backend.h" 28 #include "webkit/browser/fileapi/test_file_system_backend.h"
24 #include "webkit/browser/quota/mock_quota_manager.h" 29 #include "webkit/browser/quota/mock_quota_manager.h"
25 #include "webkit/browser/quota/quota_manager.h" 30 #include "webkit/browser/quota/quota_manager.h"
26 #include "webkit/common/fileapi/file_system_util.h" 31 #include "webkit/common/fileapi/file_system_util.h"
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after
107 const FileSystemURL& dest_url, 112 const FileSystemURL& dest_url,
108 int64 size) { 113 int64 size) {
109 ProgressRecord record; 114 ProgressRecord record;
110 record.type = type; 115 record.type = type;
111 record.source_url = source_url; 116 record.source_url = source_url;
112 record.dest_url = dest_url; 117 record.dest_url = dest_url;
113 record.size = size; 118 record.size = size;
114 records->push_back(record); 119 records->push_back(record);
115 } 120 }
116 121
122 void RecordFileProgressCallback(std::vector<int64>* records,
123 int64 progress) {
124 records->push_back(progress);
125 }
126
127 void AssignAndQuit(base::RunLoop* run_loop,
128 base::PlatformFileError* result_out,
129 base::PlatformFileError result) {
130 *result_out = result;
131 run_loop->Quit();
132 }
133
134 class ScopedThreadStopper {
135 public:
136 ScopedThreadStopper(base::Thread* thread) : thread_(thread) {
137 DCHECK(thread);
138 }
139
140 ~ScopedThreadStopper() {
141 // Give another chance for deleted streams to perform Close.
142 base::RunLoop().RunUntilIdle();
143 thread_->Stop();
144 base::RunLoop().RunUntilIdle();
kinuko 2013/09/21 10:44:36 Should we post one more task to the thread/runner
hidehiko 2013/09/23 08:18:10 Done.
145 }
146
147 private:
148 base::Thread* thread_;
149 DISALLOW_COPY_AND_ASSIGN(ScopedThreadStopper);
150 };
151
117 } // namespace 152 } // namespace
118 153
119 class CopyOrMoveOperationTestHelper { 154 class CopyOrMoveOperationTestHelper {
120 public: 155 public:
121 CopyOrMoveOperationTestHelper( 156 CopyOrMoveOperationTestHelper(
122 const GURL& origin, 157 const GURL& origin,
123 FileSystemType src_type, 158 FileSystemType src_type,
124 FileSystemType dest_type) 159 FileSystemType dest_type)
125 : origin_(origin), 160 : origin_(origin),
126 src_type_(src_type), 161 src_type_(src_type),
(...skipping 528 matching lines...) Expand 10 before | Expand all | Expand 10 after
655 EXPECT_EQ(FileSystemOperation::PROGRESS, records[j].type); 690 EXPECT_EQ(FileSystemOperation::PROGRESS, records[j].type);
656 EXPECT_FALSE(records[j].dest_url.is_valid()); 691 EXPECT_FALSE(records[j].dest_url.is_valid());
657 EXPECT_GE(records[j].size, current_size); 692 EXPECT_GE(records[j].size, current_size);
658 current_size = records[j].size; 693 current_size = records[j].size;
659 } 694 }
660 } 695 }
661 } 696 }
662 } 697 }
663 } 698 }
664 699
700
701 TEST(LocalFileSystemCopyOrMoveOperationTest, StreamCopyHelper) {
702 base::ScopedTempDir temp_dir;
703 ASSERT_TRUE(temp_dir.CreateUniqueTempDir());
704 base::FilePath source_path = temp_dir.path().AppendASCII("source");
705 const char kTestData[] = "abcdefghijklmnopqrstuvwxyz0123456789";
706 file_util::WriteFile(source_path, kTestData,
707 arraysize(kTestData) - 1); // Exclude trailing '\0'.
708
709 base::FilePath dest_path = temp_dir.path().AppendASCII("dest");
710 // LocalFileWriter requires the file is exists. So create an empty file here.
kinuko 2013/09/21 10:44:36 nit: is exists -> exists
hidehiko 2013/09/23 08:18:10 Done.
711 file_util::WriteFile(dest_path, "", 0);
712
713 base::MessageLoop message_loop;
714 base::Thread file_thread("file_thread");
715 ASSERT_TRUE(file_thread.Start());
716 ScopedThreadStopper thread_stopper(&file_thread);
717
718 scoped_refptr<base::MessageLoopProxy> task_runner =
719 file_thread.message_loop_proxy();
720
721 scoped_ptr<webkit_blob::FileStreamReader> reader(
722 webkit_blob::FileStreamReader::CreateForLocalFile(
723 task_runner.get(), source_path, 0, base::Time()));
724
725 scoped_ptr<FileStreamWriter> writer(
726 FileStreamWriter::CreateForLocalFile(task_runner.get(), dest_path, 0));
727
728 std::vector<int64> progress;
729 CopyOrMoveOperationDelegate::StreamCopyHelper helper(
730 reader.Pass(), writer.Pass(),
731 10, // buffer size
732 base::Bind(&RecordFileProgressCallback, base::Unretained(&progress)),
733 base::TimeDelta()); // For testing, we need all the progress.
734
735 base::PlatformFileError error = base::PLATFORM_FILE_ERROR_FAILED;
736 base::RunLoop run_loop;
737 helper.Run(base::Bind(&AssignAndQuit, &run_loop, &error));
738 run_loop.Run();
739
740 EXPECT_EQ(base::PLATFORM_FILE_OK, error);
741 ASSERT_EQ(5U, progress.size());
742 EXPECT_EQ(0, progress[0]);
743 EXPECT_EQ(10, progress[1]);
744 EXPECT_EQ(20, progress[2]);
745 EXPECT_EQ(30, progress[3]);
746 EXPECT_EQ(36, progress[4]);
747
748 std::string content;
749 ASSERT_TRUE(base::ReadFileToString(dest_path, &content));
750 EXPECT_EQ(kTestData, content);
751 }
752
665 } // namespace fileapi 753 } // namespace fileapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698