OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 <vector> | 5 #include <vector> |
6 | 6 |
7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
8 #include "base/bind.h" | 8 #include "base/bind.h" |
9 #include "base/run_loop.h" | 9 #include "base/run_loop.h" |
10 #include "base/single_thread_task_runner.h" | 10 #include "base/single_thread_task_runner.h" |
(...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
112 ACTION_P(MockStatusCallback, status) { | 112 ACTION_P(MockStatusCallback, status) { |
113 base::ThreadTaskRunnerHandle::Get()->PostTask( | 113 base::ThreadTaskRunnerHandle::Get()->PostTask( |
114 FROM_HERE, base::Bind(arg4, status)); | 114 FROM_HERE, base::Bind(arg4, status)); |
115 } | 115 } |
116 | 116 |
117 ACTION_P2(MockSyncFileCallback, status, url) { | 117 ACTION_P2(MockSyncFileCallback, status, url) { |
118 base::ThreadTaskRunnerHandle::Get()->PostTask( | 118 base::ThreadTaskRunnerHandle::Get()->PostTask( |
119 FROM_HERE, base::Bind(arg0, status, url)); | 119 FROM_HERE, base::Bind(arg0, status, url)); |
120 } | 120 } |
121 | 121 |
| 122 ACTION(InvokeCompletionClosure) { |
| 123 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 124 FROM_HERE, base::Bind(arg0)); |
| 125 } |
| 126 |
122 class SyncFileSystemServiceTest : public testing::Test { | 127 class SyncFileSystemServiceTest : public testing::Test { |
123 protected: | 128 protected: |
124 SyncFileSystemServiceTest() | 129 SyncFileSystemServiceTest() |
125 : thread_bundle_(content::TestBrowserThreadBundle::REAL_FILE_THREAD | | 130 : thread_bundle_(content::TestBrowserThreadBundle::REAL_FILE_THREAD | |
126 content::TestBrowserThreadBundle::REAL_IO_THREAD) {} | 131 content::TestBrowserThreadBundle::REAL_IO_THREAD) {} |
127 | 132 |
128 virtual void SetUp() OVERRIDE { | 133 virtual void SetUp() OVERRIDE { |
129 in_memory_env_.reset(leveldb::NewMemEnv(leveldb::Env::Default())); | 134 in_memory_env_.reset(leveldb::NewMemEnv(leveldb::Env::Default())); |
130 file_system_.reset(new CannedSyncableFileSystem( | 135 file_system_.reset(new CannedSyncableFileSystem( |
131 GURL(kOrigin), | 136 GURL(kOrigin), |
(...skipping 210 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
342 } | 347 } |
343 | 348 |
344 // The local_change_processor's ApplyLocalChange should be called once | 349 // The local_change_processor's ApplyLocalChange should be called once |
345 // with ADD_OR_UPDATE change for TYPE_FILE. | 350 // with ADD_OR_UPDATE change for TYPE_FILE. |
346 const FileChange change(FileChange::FILE_CHANGE_ADD_OR_UPDATE, | 351 const FileChange change(FileChange::FILE_CHANGE_ADD_OR_UPDATE, |
347 SYNC_FILE_TYPE_FILE); | 352 SYNC_FILE_TYPE_FILE); |
348 EXPECT_CALL(*mock_local_change_processor(), | 353 EXPECT_CALL(*mock_local_change_processor(), |
349 ApplyLocalChange(change, _, _, kFile, _)) | 354 ApplyLocalChange(change, _, _, kFile, _)) |
350 .WillOnce(MockStatusCallback(SYNC_STATUS_OK)); | 355 .WillOnce(MockStatusCallback(SYNC_STATUS_OK)); |
351 | 356 |
| 357 EXPECT_CALL(*mock_remote_service(), PromoteDemotedChanges(_)) |
| 358 .WillRepeatedly(InvokeCompletionClosure()); |
| 359 |
352 EXPECT_EQ(base::File::FILE_OK, file_system_->CreateFile(kFile)); | 360 EXPECT_EQ(base::File::FILE_OK, file_system_->CreateFile(kFile)); |
353 | 361 |
354 run_loop.Run(); | 362 run_loop.Run(); |
355 | 363 |
356 file_system_->RemoveSyncStatusObserver(&status_observer); | 364 file_system_->RemoveSyncStatusObserver(&status_observer); |
357 } | 365 } |
358 | 366 |
359 TEST_F(SyncFileSystemServiceTest, SimpleRemoteSyncFlow) { | 367 TEST_F(SyncFileSystemServiceTest, SimpleRemoteSyncFlow) { |
360 InitializeApp(); | 368 InitializeApp(); |
361 | 369 |
(...skipping 29 matching lines...) Expand all Loading... |
391 EXPECT_CALL(*mock_remote_service(), ProcessRemoteChange(_)) | 399 EXPECT_CALL(*mock_remote_service(), ProcessRemoteChange(_)) |
392 .WillOnce(MockSyncFileCallback(SYNC_STATUS_FILE_BUSY, | 400 .WillOnce(MockSyncFileCallback(SYNC_STATUS_FILE_BUSY, |
393 kFile)); | 401 kFile)); |
394 | 402 |
395 // ProcessRemoteChange should be called again when the becomes | 403 // ProcessRemoteChange should be called again when the becomes |
396 // not busy. | 404 // not busy. |
397 EXPECT_CALL(*mock_remote_service(), ProcessRemoteChange(_)) | 405 EXPECT_CALL(*mock_remote_service(), ProcessRemoteChange(_)) |
398 .WillOnce(InvokeWithoutArgs(&run_loop, &base::RunLoop::Quit)); | 406 .WillOnce(InvokeWithoutArgs(&run_loop, &base::RunLoop::Quit)); |
399 } | 407 } |
400 | 408 |
| 409 EXPECT_CALL(*mock_remote_service(), PromoteDemotedChanges(_)) |
| 410 .WillRepeatedly(InvokeCompletionClosure()); |
| 411 |
401 // We might also see an activity for local sync as we're going to make | 412 // We might also see an activity for local sync as we're going to make |
402 // a local write operation on kFile. | 413 // a local write operation on kFile. |
403 EXPECT_CALL(*mock_local_change_processor(), | 414 EXPECT_CALL(*mock_local_change_processor(), |
404 ApplyLocalChange(_, _, _, kFile, _)) | 415 ApplyLocalChange(_, _, _, kFile, _)) |
405 .Times(AnyNumber()); | 416 .Times(AnyNumber()); |
406 | 417 |
407 // This should trigger a remote sync. | 418 // This should trigger a remote sync. |
408 mock_remote_service()->NotifyRemoteChangeQueueUpdated(1); | 419 mock_remote_service()->NotifyRemoteChangeQueueUpdated(1); |
409 | 420 |
410 // Start a local operation on the same file (to make it BUSY). | 421 // Start a local operation on the same file (to make it BUSY). |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
466 base::Bind(&AssignValueAndQuit<SyncFileStatus>, | 477 base::Bind(&AssignValueAndQuit<SyncFileStatus>, |
467 &run_loop, &status, &sync_file_status)); | 478 &run_loop, &status, &sync_file_status)); |
468 run_loop.Run(); | 479 run_loop.Run(); |
469 | 480 |
470 EXPECT_EQ(SYNC_STATUS_OK, status); | 481 EXPECT_EQ(SYNC_STATUS_OK, status); |
471 EXPECT_EQ(SYNC_FILE_STATUS_HAS_PENDING_CHANGES, sync_file_status); | 482 EXPECT_EQ(SYNC_FILE_STATUS_HAS_PENDING_CHANGES, sync_file_status); |
472 } | 483 } |
473 } | 484 } |
474 | 485 |
475 } // namespace sync_file_system | 486 } // namespace sync_file_system |
OLD | NEW |