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

Side by Side Diff: chrome/browser/chromeos/file_system_provider/provided_file_system_unittest.cc

Issue 294073007: [fsp] Let extensions decide about the file system id. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased. Created 6 years, 7 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 // TODO(mtomasz): Move these test cases to operations/unmount_unittest.cc. 5 // TODO(mtomasz): Move these test cases to operations/unmount_unittest.cc.
6 6
7 #include <string> 7 #include <string>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/files/file.h" 10 #include "base/files/file.h"
(...skipping 11 matching lines...) Expand all
22 #include "extensions/browser/event_router.h" 22 #include "extensions/browser/event_router.h"
23 #include "testing/gtest/include/gtest/gtest.h" 23 #include "testing/gtest/include/gtest/gtest.h"
24 24
25 namespace chromeos { 25 namespace chromeos {
26 namespace file_system_provider { 26 namespace file_system_provider {
27 27
28 namespace { 28 namespace {
29 29
30 const char kExtensionId[] = "mbflcebpggnecokmikipoihdbecnjfoj"; 30 const char kExtensionId[] = "mbflcebpggnecokmikipoihdbecnjfoj";
31 const int kExpectedRequestId = 1; 31 const int kExpectedRequestId = 1;
32 const int kFileSystemId = 2; 32 const char kFileSystemId[] = "camera-pictures";
33 const char kFileSystemName[] = "Camera Pictures"; 33 const char kFileSystemName[] = "Camera Pictures";
34 34
35 class FakeEventRouter : public extensions::EventRouter { 35 class FakeEventRouter : public extensions::EventRouter {
36 public: 36 public:
37 explicit FakeEventRouter(Profile* profile) : EventRouter(profile, NULL) {} 37 explicit FakeEventRouter(Profile* profile) : EventRouter(profile, NULL) {}
38 virtual ~FakeEventRouter() {} 38 virtual ~FakeEventRouter() {}
39 39
40 virtual void DispatchEventToExtension(const std::string& extension_id, 40 virtual void DispatchEventToExtension(const std::string& extension_id,
41 scoped_ptr<extensions::Event> event) 41 scoped_ptr<extensions::Event> event)
42 OVERRIDE { 42 OVERRIDE {
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
85 virtual ~FileSystemProviderProvidedFileSystemTest() {} 85 virtual ~FileSystemProviderProvidedFileSystemTest() {}
86 86
87 virtual void SetUp() OVERRIDE { 87 virtual void SetUp() OVERRIDE {
88 profile_.reset(new TestingProfile); 88 profile_.reset(new TestingProfile);
89 event_router_.reset(new FakeEventRouter(profile_.get())); 89 event_router_.reset(new FakeEventRouter(profile_.get()));
90 event_router_->AddEventListener( 90 event_router_->AddEventListener(
91 extensions::api::file_system_provider::OnUnmountRequested::kEventName, 91 extensions::api::file_system_provider::OnUnmountRequested::kEventName,
92 NULL, 92 NULL,
93 kExtensionId); 93 kExtensionId);
94 94
95 base::FilePath mount_path = 95 const base::FilePath mount_path =
96 util::GetMountPath(profile_.get(), kExtensionId, kFileSystemId); 96 util::GetMountPath(profile_.get(), kExtensionId, kFileSystemId);
97 file_system_info_.reset(new ProvidedFileSystemInfo( 97 file_system_info_.reset(new ProvidedFileSystemInfo(
98 kExtensionId, kFileSystemId, kFileSystemName, mount_path)); 98 kExtensionId, kFileSystemId, kFileSystemName, mount_path));
99 provided_file_system_.reset( 99 provided_file_system_.reset(
100 new ProvidedFileSystem(event_router_.get(), *file_system_info_.get())); 100 new ProvidedFileSystem(event_router_.get(), *file_system_info_.get()));
101 } 101 }
102 102
103 content::TestBrowserThreadBundle thread_bundle_; 103 content::TestBrowserThreadBundle thread_bundle_;
104 scoped_ptr<TestingProfile> profile_; 104 scoped_ptr<TestingProfile> profile_;
105 scoped_ptr<FakeEventRouter> event_router_; 105 scoped_ptr<FakeEventRouter> event_router_;
106 scoped_ptr<ProvidedFileSystemInfo> file_system_info_; 106 scoped_ptr<ProvidedFileSystemInfo> file_system_info_;
107 scoped_ptr<ProvidedFileSystemInterface> provided_file_system_; 107 scoped_ptr<ProvidedFileSystemInterface> provided_file_system_;
108 }; 108 };
109 109
110 TEST_F(FileSystemProviderProvidedFileSystemTest, RequestUnmount_Success) { 110 TEST_F(FileSystemProviderProvidedFileSystemTest, RequestUnmount_Success) {
111 EventLogger logger; 111 EventLogger logger;
112 112
113 provided_file_system_->RequestUnmount( 113 provided_file_system_->RequestUnmount(
114 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr())); 114 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr()));
115 base::RunLoop().RunUntilIdle(); 115 base::RunLoop().RunUntilIdle();
116 116
117 // Verify that the event has been sent to the providing extension. 117 // Verify that the event has been sent to the providing extension.
118 EXPECT_EQ(kExtensionId, event_router_->extension_id()); 118 EXPECT_EQ(kExtensionId, event_router_->extension_id());
119 const extensions::Event* event = event_router_->event(); 119 const extensions::Event* event = event_router_->event();
120 ASSERT_TRUE(event); 120 ASSERT_TRUE(event);
121 ASSERT_TRUE(event->event_args); 121 ASSERT_TRUE(event->event_args);
122 base::ListValue* event_args = event->event_args.get(); 122 base::ListValue* event_args = event->event_args.get();
123 EXPECT_EQ(2u, event_args->GetSize()); 123 EXPECT_EQ(2u, event_args->GetSize());
124 int file_system_id = 0; 124 std::string file_system_id;
125 EXPECT_TRUE(event_args->GetInteger(0, &file_system_id)); 125 EXPECT_TRUE(event_args->GetString(0, &file_system_id));
126 EXPECT_EQ(kFileSystemId, file_system_id); 126 EXPECT_EQ(kFileSystemId, file_system_id);
127 127
128 // Remember the request id, and verify it is valid. 128 // Remember the request id, and verify it is valid.
129 int request_id = 0; 129 int request_id = 0;
130 EXPECT_TRUE(event_args->GetInteger(1, &request_id)); 130 EXPECT_TRUE(event_args->GetInteger(1, &request_id));
131 EXPECT_EQ(kExpectedRequestId, request_id); 131 EXPECT_EQ(kExpectedRequestId, request_id);
132 132
133 // Callback should not be called, yet. 133 // Callback should not be called, yet.
134 EXPECT_FALSE(logger.error()); 134 EXPECT_FALSE(logger.error());
135 135
(...skipping 17 matching lines...) Expand all
153 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr())); 153 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr()));
154 base::RunLoop().RunUntilIdle(); 154 base::RunLoop().RunUntilIdle();
155 155
156 // Verify that the event has been sent to the providing extension. 156 // Verify that the event has been sent to the providing extension.
157 EXPECT_EQ(kExtensionId, event_router_->extension_id()); 157 EXPECT_EQ(kExtensionId, event_router_->extension_id());
158 const extensions::Event* event = event_router_->event(); 158 const extensions::Event* event = event_router_->event();
159 ASSERT_TRUE(event); 159 ASSERT_TRUE(event);
160 ASSERT_TRUE(event->event_args); 160 ASSERT_TRUE(event->event_args);
161 base::ListValue* event_args = event->event_args.get(); 161 base::ListValue* event_args = event->event_args.get();
162 EXPECT_EQ(2u, event_args->GetSize()); 162 EXPECT_EQ(2u, event_args->GetSize());
163 int file_system_id = 0; 163 std::string file_system_id;
164 EXPECT_TRUE(event_args->GetInteger(0, &file_system_id)); 164 EXPECT_TRUE(event_args->GetString(0, &file_system_id));
165 EXPECT_EQ(kFileSystemId, file_system_id); 165 EXPECT_EQ(kFileSystemId, file_system_id);
166 166
167 // Remember the request id, and verify it is valid. 167 // Remember the request id, and verify it is valid.
168 int request_id = 0; 168 int request_id = 0;
169 EXPECT_TRUE(event_args->GetInteger(1, &request_id)); 169 EXPECT_TRUE(event_args->GetInteger(1, &request_id));
170 EXPECT_EQ(kExpectedRequestId, request_id); 170 EXPECT_EQ(kExpectedRequestId, request_id);
171 171
172 // Simulate sending an error response from the providing extension. 172 // Simulate sending an error response from the providing extension.
173 RequestManager* request_manager = provided_file_system_->GetRequestManager(); 173 RequestManager* request_manager = provided_file_system_->GetRequestManager();
174 ASSERT_TRUE(request_manager); 174 ASSERT_TRUE(request_manager);
175 bool reply_result = request_manager->RejectRequest( 175 bool reply_result = request_manager->RejectRequest(
176 request_id, base::File::FILE_ERROR_NOT_FOUND); 176 request_id, base::File::FILE_ERROR_NOT_FOUND);
177 EXPECT_TRUE(reply_result); 177 EXPECT_TRUE(reply_result);
178 178
179 // Callback should be called. Verify the error code. 179 // Callback should be called. Verify the error code.
180 ASSERT_TRUE(logger.error()); 180 ASSERT_TRUE(logger.error());
181 EXPECT_EQ(base::File::FILE_ERROR_NOT_FOUND, *logger.error()); 181 EXPECT_EQ(base::File::FILE_ERROR_NOT_FOUND, *logger.error());
182 } 182 }
183 183
184 } // namespace file_system_provider 184 } // namespace file_system_provider
185 } // namespace chromeos 185 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698