| 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 |