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

Side by Side Diff: chrome/browser/chromeos/arc/fileapi/arc_documents_provider_root_unittest.cc

Issue 2637163002: Defer ARC file system operations while ARC is booting. (Closed)
Patch Set: Review ready. Created 3 years, 11 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 <string.h> 5 #include <string.h>
6 6
7 #include <memory> 7 #include <memory>
8 #include <string> 8 #include <string>
9 #include <utility> 9 #include <utility>
10 10
11 #include "base/files/file_path.h" 11 #include "base/files/file_path.h"
12 #include "base/memory/ptr_util.h" 12 #include "base/memory/ptr_util.h"
13 #include "base/run_loop.h" 13 #include "base/run_loop.h"
14 #include "chrome/browser/chromeos/arc/fileapi/arc_documents_provider_root.h" 14 #include "chrome/browser/chromeos/arc/fileapi/arc_documents_provider_root.h"
15 #include "chrome/browser/chromeos/arc/fileapi/arc_documents_provider_util.h" 15 #include "chrome/browser/chromeos/arc/fileapi/arc_documents_provider_util.h"
16 #include "components/arc/arc_bridge_service.h" 16 #include "components/arc/arc_bridge_service.h"
17 #include "components/arc/arc_service_manager.h" 17 #include "components/arc/arc_service_manager.h"
18 #include "components/arc/test/fake_file_system_instance.h" 18 #include "components/arc/file_system/test/fake_arc_file_system_operation_runner. h"
19 #include "content/public/test/test_browser_thread_bundle.h" 19 #include "content/public/test/test_browser_thread_bundle.h"
20 #include "storage/common/fileapi/directory_entry.h" 20 #include "storage/common/fileapi/directory_entry.h"
21 #include "testing/gtest/include/gtest/gtest.h" 21 #include "testing/gtest/include/gtest/gtest.h"
22 #include "url/gurl.h" 22 #include "url/gurl.h"
23 23
24 using storage::DirectoryEntry; 24 using storage::DirectoryEntry;
25 using EntryList = storage::AsyncFileUtil::EntryList; 25 using EntryList = storage::AsyncFileUtil::EntryList;
26 26
27 namespace arc { 27 namespace arc {
28 28
(...skipping 13 matching lines...) Expand all
42 // (root)/ dir root-id 42 // (root)/ dir root-id
43 // dir/ dir dir-id 43 // dir/ dir dir-id
44 // photo.jpg image/jpeg photo-id 44 // photo.jpg image/jpeg photo-id
45 // music.bin audio/mp3 music-id 45 // music.bin audio/mp3 music-id
46 // dups/ dir dups-id 46 // dups/ dir dups-id
47 // dup.mp4 video/mp4 dup1-id 47 // dup.mp4 video/mp4 dup1-id
48 // dup.mp4 video/mp4 dup2-id 48 // dup.mp4 video/mp4 dup2-id
49 // dup.mp4 video/mp4 dup3-id 49 // dup.mp4 video/mp4 dup3-id
50 // dup.mp4 video/mp4 dup4-id 50 // dup.mp4 video/mp4 dup4-id
51 constexpr char kAuthority[] = "org.chromium.test"; 51 constexpr char kAuthority[] = "org.chromium.test";
52 constexpr DocumentSpec kRootSpec = {"root-id", "(root)", 52 // NOTE: ArcDocumentsProviderRoot::GetFileInfo() returns hard-coded info
53 kAndroidDirectoryMimeType, -1, 11}; 53 // for root documents.
54 constexpr DocumentSpec kRootSpec = {"root-id", nullptr /* not used */,
55 kAndroidDirectoryMimeType, -1, 0};
hidehiko 2017/01/20 08:01:49 Clarification: any reasons this change (11 -> 0)?
Shuhei Takahashi 2017/01/20 09:13:04 Yes. As I added commented above, the response to r
hidehiko 2017/01/20 10:06:26 Oh, I see. Thank you for explanation.
54 constexpr DocumentSpec kDirSpec = {"dir-id", "dir", kAndroidDirectoryMimeType, 56 constexpr DocumentSpec kDirSpec = {"dir-id", "dir", kAndroidDirectoryMimeType,
55 -1, 22}; 57 -1, 22};
56 constexpr DocumentSpec kPhotoSpec = {"photo-id", "photo.jpg", "image/jpeg", 3, 58 constexpr DocumentSpec kPhotoSpec = {"photo-id", "photo.jpg", "image/jpeg", 3,
57 33}; 59 33};
58 constexpr DocumentSpec kMusicSpec = {"music-id", "music.bin", "audio/mp3", 4, 60 constexpr DocumentSpec kMusicSpec = {"music-id", "music.bin", "audio/mp3", 4,
59 44}; 61 44};
60 constexpr DocumentSpec kDupsSpec = {"dups-id", "dups", 62 constexpr DocumentSpec kDupsSpec = {"dups-id", "dups",
61 kAndroidDirectoryMimeType, -1, 55}; 63 kAndroidDirectoryMimeType, -1, 55};
62 constexpr DocumentSpec kDup1Spec = {"dup1-id", "dup.mp4", "video/mp4", 6, 66}; 64 constexpr DocumentSpec kDup1Spec = {"dup1-id", "dup.mp4", "video/mp4", 6, 66};
63 constexpr DocumentSpec kDup2Spec = {"dup2-id", "dup.mp4", "video/mp4", 7, 77}; 65 constexpr DocumentSpec kDup2Spec = {"dup2-id", "dup.mp4", "video/mp4", 7, 77};
64 constexpr DocumentSpec kDup3Spec = {"dup3-id", "dup.mp4", "video/mp4", 8, 88}; 66 constexpr DocumentSpec kDup3Spec = {"dup3-id", "dup.mp4", "video/mp4", 8, 88};
65 constexpr DocumentSpec kDup4Spec = {"dup4-id", "dup.mp4", "video/mp4", 9, 99}; 67 constexpr DocumentSpec kDup4Spec = {"dup4-id", "dup.mp4", "video/mp4", 9, 99};
66 constexpr DocumentSpec kAllSpecs[] = {kRootSpec, kDirSpec, kPhotoSpec, 68 constexpr DocumentSpec kAllSpecs[] = {kRootSpec, kDirSpec, kPhotoSpec,
67 kMusicSpec, kDupsSpec, kDup1Spec, 69 kMusicSpec, kDupsSpec, kDup1Spec,
68 kDup2Spec, kDup3Spec, kDup4Spec}; 70 kDup2Spec, kDup3Spec, kDup4Spec};
69 71
70 mojom::DocumentPtr MakeDocument(const DocumentSpec& spec) { 72 mojom::DocumentPtr MakeDocument(const DocumentSpec& spec) {
71 mojom::DocumentPtr document = mojom::Document::New(); 73 mojom::DocumentPtr document = mojom::Document::New();
72 document->document_id = spec.document_id; 74 document->document_id = spec.document_id;
73 document->display_name = spec.display_name; 75 document->display_name = spec.display_name;
74 document->mime_type = spec.mime_type; 76 document->mime_type = spec.mime_type;
75 document->size = spec.size; 77 document->size = spec.size;
76 document->last_modified = spec.last_modified; 78 document->last_modified = spec.last_modified;
77 return document; 79 return document;
78 } 80 }
79 81
80 class FileSystemInstanceTestImpl : public FakeFileSystemInstance { 82 class ArcFileSystemOperationRunnerForTest
83 : public FakeArcFileSystemOperationRunner {
81 public: 84 public:
85 explicit ArcFileSystemOperationRunnerForTest(ArcBridgeService* bridge_service)
86 : FakeArcFileSystemOperationRunner(bridge_service) {}
87 ~ArcFileSystemOperationRunnerForTest() override = default;
88
82 void GetChildDocuments(const std::string& authority, 89 void GetChildDocuments(const std::string& authority,
83 const std::string& document_id, 90 const std::string& document_id,
84 const GetChildDocumentsCallback& callback) override { 91 const GetChildDocumentsCallback& callback) override {
85 EXPECT_EQ(kAuthority, authority); 92 EXPECT_EQ(kAuthority, authority);
86 base::Optional<std::vector<mojom::DocumentPtr>> result; 93 base::Optional<std::vector<mojom::DocumentPtr>> result;
87 if (document_id == kRootSpec.document_id) { 94 if (document_id == kRootSpec.document_id) {
88 result.emplace(); 95 result.emplace();
89 result.value().emplace_back(MakeDocument(kDirSpec)); 96 result.value().emplace_back(MakeDocument(kDirSpec));
90 result.value().emplace_back(MakeDocument(kDupsSpec)); 97 result.value().emplace_back(MakeDocument(kDupsSpec));
91 } else if (document_id == kDirSpec.document_id) { 98 } else if (document_id == kDirSpec.document_id) {
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
134 static_cast<uint64_t>(info.creation_time.ToJavaTime())); 141 static_cast<uint64_t>(info.creation_time.ToJavaTime()));
135 } 142 }
136 143
137 class ArcDocumentsProviderRootTest : public testing::Test { 144 class ArcDocumentsProviderRootTest : public testing::Test {
138 public: 145 public:
139 ArcDocumentsProviderRootTest() 146 ArcDocumentsProviderRootTest()
140 : arc_service_manager_(base::MakeUnique<ArcServiceManager>(nullptr)), 147 : arc_service_manager_(base::MakeUnique<ArcServiceManager>(nullptr)),
141 root_( 148 root_(
142 base::MakeUnique<ArcDocumentsProviderRoot>(kAuthority, 149 base::MakeUnique<ArcDocumentsProviderRoot>(kAuthority,
143 kRootSpec.document_id)) { 150 kRootSpec.document_id)) {
144 arc_service_manager_->arc_bridge_service()->file_system()->SetInstance( 151 arc_service_manager_->AddService(
145 &file_system_); 152 base::MakeUnique<ArcFileSystemOperationRunnerForTest>(
153 arc_service_manager_->arc_bridge_service()));
146 } 154 }
147 155
148 ~ArcDocumentsProviderRootTest() override = default; 156 ~ArcDocumentsProviderRootTest() override = default;
149 157
150 protected: 158 protected:
151 content::TestBrowserThreadBundle thread_bundle_; 159 content::TestBrowserThreadBundle thread_bundle_;
152 FileSystemInstanceTestImpl file_system_;
153 std::unique_ptr<ArcServiceManager> arc_service_manager_; 160 std::unique_ptr<ArcServiceManager> arc_service_manager_;
154 std::unique_ptr<ArcDocumentsProviderRoot> root_; 161 std::unique_ptr<ArcDocumentsProviderRoot> root_;
155 162
156 private: 163 private:
157 DISALLOW_COPY_AND_ASSIGN(ArcDocumentsProviderRootTest); 164 DISALLOW_COPY_AND_ASSIGN(ArcDocumentsProviderRootTest);
158 }; 165 };
159 166
160 } // namespace 167 } // namespace
161 168
162 TEST_F(ArcDocumentsProviderRootTest, GetFileInfo) { 169 TEST_F(ArcDocumentsProviderRootTest, GetFileInfo) {
(...skipping 197 matching lines...) Expand 10 before | Expand all | Expand 10 after
360 [](base::RunLoop* run_loop, const GURL& url) { 367 [](base::RunLoop* run_loop, const GURL& url) {
361 EXPECT_EQ(GURL("content://org.chromium.test/document/dup3-id"), 368 EXPECT_EQ(GURL("content://org.chromium.test/document/dup3-id"),
362 url); 369 url);
363 run_loop->Quit(); 370 run_loop->Quit();
364 }, 371 },
365 &run_loop)); 372 &run_loop));
366 run_loop.Run(); 373 run_loop.Run();
367 } 374 }
368 375
369 } // namespace arc 376 } // namespace arc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698