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 #include <string> | 5 #include <string> |
6 #include <vector> | 6 #include <vector> |
7 | 7 |
8 #include "base/files/file.h" | 8 #include "base/files/file.h" |
9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
10 #include "base/run_loop.h" | 10 #include "base/run_loop.h" |
11 #include "base/values.h" | 11 #include "base/values.h" |
12 #include "chrome/browser/chromeos/file_system_provider/mount_path_util.h" | 12 #include "chrome/browser/chromeos/file_system_provider/mount_path_util.h" |
13 #include "chrome/browser/chromeos/file_system_provider/provided_file_system.h" | 13 #include "chrome/browser/chromeos/file_system_provider/provided_file_system.h" |
14 #include "chrome/browser/chromeos/file_system_provider/provided_file_system_info
.h" | 14 #include "chrome/browser/chromeos/file_system_provider/provided_file_system_info
.h" |
15 #include "chrome/browser/chromeos/file_system_provider/provided_file_system_inte
rface.h" | 15 #include "chrome/browser/chromeos/file_system_provider/provided_file_system_inte
rface.h" |
16 #include "chrome/browser/chromeos/file_system_provider/request_manager.h" | 16 #include "chrome/browser/chromeos/file_system_provider/request_manager.h" |
| 17 #include "chrome/common/extensions/api/file_system_provider.h" |
17 #include "chrome/test/base/testing_profile.h" | 18 #include "chrome/test/base/testing_profile.h" |
18 #include "content/public/test/test_browser_thread_bundle.h" | 19 #include "content/public/test/test_browser_thread_bundle.h" |
19 #include "extensions/browser/event_router.h" | 20 #include "extensions/browser/event_router.h" |
20 #include "testing/gtest/include/gtest/gtest.h" | 21 #include "testing/gtest/include/gtest/gtest.h" |
21 | 22 |
22 namespace chromeos { | 23 namespace chromeos { |
23 namespace file_system_provider { | 24 namespace file_system_provider { |
24 | 25 |
25 namespace { | 26 namespace { |
26 | 27 |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
77 } // namespace | 78 } // namespace |
78 | 79 |
79 class FileSystemProviderProvidedFileSystemTest : public testing::Test { | 80 class FileSystemProviderProvidedFileSystemTest : public testing::Test { |
80 protected: | 81 protected: |
81 FileSystemProviderProvidedFileSystemTest() {} | 82 FileSystemProviderProvidedFileSystemTest() {} |
82 virtual ~FileSystemProviderProvidedFileSystemTest() {} | 83 virtual ~FileSystemProviderProvidedFileSystemTest() {} |
83 | 84 |
84 virtual void SetUp() OVERRIDE { | 85 virtual void SetUp() OVERRIDE { |
85 profile_.reset(new TestingProfile); | 86 profile_.reset(new TestingProfile); |
86 event_router_.reset(new FakeEventRouter(profile_.get())); | 87 event_router_.reset(new FakeEventRouter(profile_.get())); |
| 88 event_router_->AddEventListener( |
| 89 extensions::api::file_system_provider::OnUnmountRequested::kEventName, |
| 90 NULL, |
| 91 kExtensionId); |
| 92 |
87 base::FilePath mount_path = | 93 base::FilePath mount_path = |
88 util::GetMountPath(profile_.get(), kExtensionId, kFileSystemId); | 94 util::GetMountPath(profile_.get(), kExtensionId, kFileSystemId); |
89 file_system_info_.reset(new ProvidedFileSystemInfo( | 95 file_system_info_.reset(new ProvidedFileSystemInfo( |
90 kExtensionId, kFileSystemId, kFileSystemName, mount_path)); | 96 kExtensionId, kFileSystemId, kFileSystemName, mount_path)); |
91 provided_file_system_.reset( | 97 provided_file_system_.reset( |
92 new ProvidedFileSystem(event_router_.get(), *file_system_info_.get())); | 98 new ProvidedFileSystem(event_router_.get(), *file_system_info_.get())); |
93 } | 99 } |
94 | 100 |
95 content::TestBrowserThreadBundle thread_bundle_; | 101 content::TestBrowserThreadBundle thread_bundle_; |
96 scoped_ptr<TestingProfile> profile_; | 102 scoped_ptr<TestingProfile> profile_; |
97 scoped_ptr<FakeEventRouter> event_router_; | 103 scoped_ptr<FakeEventRouter> event_router_; |
98 scoped_ptr<ProvidedFileSystemInfo> file_system_info_; | 104 scoped_ptr<ProvidedFileSystemInfo> file_system_info_; |
99 scoped_ptr<ProvidedFileSystemInterface> provided_file_system_; | 105 scoped_ptr<ProvidedFileSystemInterface> provided_file_system_; |
100 }; | 106 }; |
101 | 107 |
102 TEST_F(FileSystemProviderProvidedFileSystemTest, RequestUnmount_Success) { | 108 TEST_F(FileSystemProviderProvidedFileSystemTest, RequestUnmount_Success) { |
103 EventLogger logger; | 109 EventLogger logger; |
104 | 110 |
105 bool result = provided_file_system_->RequestUnmount( | 111 provided_file_system_->RequestUnmount( |
106 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr())); | 112 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr())); |
107 ASSERT_TRUE(result); | |
108 base::RunLoop().RunUntilIdle(); | 113 base::RunLoop().RunUntilIdle(); |
109 | 114 |
110 // Verify that the event has been sent to the providing extension. | 115 // Verify that the event has been sent to the providing extension. |
111 EXPECT_EQ(kExtensionId, event_router_->extension_id()); | 116 EXPECT_EQ(kExtensionId, event_router_->extension_id()); |
112 const extensions::Event* event = event_router_->event(); | 117 const extensions::Event* event = event_router_->event(); |
113 ASSERT_TRUE(event); | 118 ASSERT_TRUE(event); |
114 ASSERT_TRUE(event->event_args); | 119 ASSERT_TRUE(event->event_args); |
115 base::ListValue* event_args = event->event_args.get(); | 120 base::ListValue* event_args = event->event_args.get(); |
116 EXPECT_EQ(2u, event_args->GetSize()); | 121 EXPECT_EQ(2u, event_args->GetSize()); |
117 int file_system_id = 0; | 122 int file_system_id = 0; |
118 EXPECT_TRUE(event_args->GetInteger(0, &file_system_id)); | 123 EXPECT_TRUE(event_args->GetInteger(0, &file_system_id)); |
119 EXPECT_EQ(kFileSystemId, file_system_id); | 124 EXPECT_EQ(kFileSystemId, file_system_id); |
120 | 125 |
121 // Remember the request id, and verify it is valid. | 126 // Remember the request id, and verify it is valid. |
122 int request_id = 0; | 127 int request_id = 0; |
123 EXPECT_TRUE(event_args->GetInteger(1, &request_id)); | 128 EXPECT_TRUE(event_args->GetInteger(1, &request_id)); |
124 EXPECT_EQ(kExpectedRequestId, request_id); | 129 EXPECT_EQ(kExpectedRequestId, request_id); |
125 | 130 |
126 // Callback should not be called, yet. | 131 // Callback should not be called, yet. |
127 EXPECT_FALSE(logger.error()); | 132 EXPECT_FALSE(logger.error()); |
128 | 133 |
129 // Simulate sending a success response from the providing extension. | 134 // Simulate sending a success response from the providing extension. |
130 RequestManager* request_manager = provided_file_system_->GetRequestManager(); | 135 RequestManager* request_manager = provided_file_system_->GetRequestManager(); |
131 ASSERT_TRUE(request_manager); | 136 ASSERT_TRUE(request_manager); |
132 scoped_ptr<base::DictionaryValue> response(new base::DictionaryValue()); | 137 scoped_ptr<RequestValue> response; |
133 bool reply_result = request_manager->FulfillRequest( | 138 bool reply_result = request_manager->FulfillRequest( |
134 request_id, response.Pass(), false /* has_next */); | 139 request_id, response.Pass(), false /* has_next */); |
135 EXPECT_TRUE(reply_result); | 140 EXPECT_TRUE(reply_result); |
136 | 141 |
137 // Callback should be called. Verify the error code. | 142 // Callback should be called. Verify the error code. |
138 ASSERT_TRUE(logger.error()); | 143 ASSERT_TRUE(logger.error()); |
139 EXPECT_EQ(base::File::FILE_OK, *logger.error()); | 144 EXPECT_EQ(base::File::FILE_OK, *logger.error()); |
140 } | 145 } |
141 | 146 |
142 TEST_F(FileSystemProviderProvidedFileSystemTest, RequestUnmount_Error) { | 147 TEST_F(FileSystemProviderProvidedFileSystemTest, RequestUnmount_Error) { |
143 EventLogger logger; | 148 EventLogger logger; |
144 | 149 |
145 bool result = provided_file_system_->RequestUnmount( | 150 provided_file_system_->RequestUnmount( |
146 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr())); | 151 base::Bind(&EventLogger::OnStatusCallback, logger.GetWeakPtr())); |
147 ASSERT_TRUE(result); | |
148 base::RunLoop().RunUntilIdle(); | 152 base::RunLoop().RunUntilIdle(); |
149 | 153 |
150 // Verify that the event has been sent to the providing extension. | 154 // Verify that the event has been sent to the providing extension. |
151 EXPECT_EQ(kExtensionId, event_router_->extension_id()); | 155 EXPECT_EQ(kExtensionId, event_router_->extension_id()); |
152 const extensions::Event* event = event_router_->event(); | 156 const extensions::Event* event = event_router_->event(); |
153 ASSERT_TRUE(event); | 157 ASSERT_TRUE(event); |
154 ASSERT_TRUE(event->event_args); | 158 ASSERT_TRUE(event->event_args); |
155 base::ListValue* event_args = event->event_args.get(); | 159 base::ListValue* event_args = event->event_args.get(); |
156 EXPECT_EQ(2u, event_args->GetSize()); | 160 EXPECT_EQ(2u, event_args->GetSize()); |
157 int file_system_id = 0; | 161 int file_system_id = 0; |
(...skipping 12 matching lines...) Expand all Loading... |
170 request_id, base::File::FILE_ERROR_NOT_FOUND); | 174 request_id, base::File::FILE_ERROR_NOT_FOUND); |
171 EXPECT_TRUE(reply_result); | 175 EXPECT_TRUE(reply_result); |
172 | 176 |
173 // Callback should be called. Verify the error code. | 177 // Callback should be called. Verify the error code. |
174 ASSERT_TRUE(logger.error()); | 178 ASSERT_TRUE(logger.error()); |
175 EXPECT_EQ(base::File::FILE_ERROR_NOT_FOUND, *logger.error()); | 179 EXPECT_EQ(base::File::FILE_ERROR_NOT_FOUND, *logger.error()); |
176 } | 180 } |
177 | 181 |
178 } // namespace file_system_provider | 182 } // namespace file_system_provider |
179 } // namespace chromeos | 183 } // namespace chromeos |
OLD | NEW |