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