OLD | NEW |
---|---|
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 Loading... | |
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 Loading... | |
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 Loading... | |
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 |
OLD | NEW |