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/stl_util.h" | 10 #include "base/stl_util.h" |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
43 | 43 |
44 namespace { | 44 namespace { |
45 | 45 |
46 const char kOrigin[] = "http://example.com"; | 46 const char kOrigin[] = "http://example.com"; |
47 const char kServiceName[] = "test"; | 47 const char kServiceName[] = "test"; |
48 | 48 |
49 template <typename R> struct AssignTrait { | 49 template <typename R> struct AssignTrait { |
50 typedef const R& ArgumentType; | 50 typedef const R& ArgumentType; |
51 }; | 51 }; |
52 | 52 |
53 template <> struct AssignTrait<fileapi::SyncFileStatus> { | 53 template <> struct AssignTrait<SyncFileStatus> { |
54 typedef fileapi::SyncFileStatus ArgumentType; | 54 typedef SyncFileStatus ArgumentType; |
55 }; | 55 }; |
56 | 56 |
57 template <typename R> | 57 template <typename R> |
58 void AssignValueAndQuit(base::RunLoop* run_loop, | 58 void AssignValueAndQuit(base::RunLoop* run_loop, |
59 SyncStatusCode* status_out, R* value_out, | 59 SyncStatusCode* status_out, R* value_out, |
60 SyncStatusCode status, | 60 SyncStatusCode status, |
61 typename AssignTrait<R>::ArgumentType value) { | 61 typename AssignTrait<R>::ArgumentType value) { |
62 DCHECK(status_out); | 62 DCHECK(status_out); |
63 DCHECK(value_out); | 63 DCHECK(value_out); |
64 DCHECK(run_loop); | 64 DCHECK(run_loop); |
(...skipping 16 matching lines...) Expand all Loading... |
81 public: | 81 public: |
82 MockSyncEventObserver() {} | 82 MockSyncEventObserver() {} |
83 virtual ~MockSyncEventObserver() {} | 83 virtual ~MockSyncEventObserver() {} |
84 | 84 |
85 MOCK_METHOD3(OnSyncStateUpdated, | 85 MOCK_METHOD3(OnSyncStateUpdated, |
86 void(const GURL& app_origin, | 86 void(const GURL& app_origin, |
87 SyncServiceState state, | 87 SyncServiceState state, |
88 const std::string& description)); | 88 const std::string& description)); |
89 MOCK_METHOD4(OnFileSynced, | 89 MOCK_METHOD4(OnFileSynced, |
90 void(const fileapi::FileSystemURL& url, | 90 void(const fileapi::FileSystemURL& url, |
91 fileapi::SyncFileStatus status, | 91 SyncFileStatus status, |
92 fileapi::SyncAction action, | 92 SyncAction action, |
93 fileapi::SyncDirection direction)); | 93 SyncDirection direction)); |
94 }; | 94 }; |
95 | 95 |
96 ACTION_P3(NotifyStateAndCallback, | 96 ACTION_P3(NotifyStateAndCallback, |
97 mock_remote_service, service_state, operation_status) { | 97 mock_remote_service, service_state, operation_status) { |
98 mock_remote_service->NotifyRemoteServiceStateUpdated( | 98 mock_remote_service->NotifyRemoteServiceStateUpdated( |
99 service_state, "Test event."); | 99 service_state, "Test event."); |
100 base::MessageLoopProxy::current()->PostTask( | 100 base::MessageLoopProxy::current()->PostTask( |
101 FROM_HERE, base::Bind(arg1, operation_status)); | 101 FROM_HERE, base::Bind(arg1, operation_status)); |
102 } | 102 } |
103 | 103 |
(...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
412 | 412 |
413 event.Wait(); | 413 event.Wait(); |
414 } | 414 } |
415 | 415 |
416 TEST_F(SyncFileSystemServiceTest, GetFileSyncStatus) { | 416 TEST_F(SyncFileSystemServiceTest, GetFileSyncStatus) { |
417 InitializeApp(); | 417 InitializeApp(); |
418 | 418 |
419 const FileSystemURL kFile(file_system_->URL("foo")); | 419 const FileSystemURL kFile(file_system_->URL("foo")); |
420 | 420 |
421 fileapi::SyncStatusCode status; | 421 fileapi::SyncStatusCode status; |
422 fileapi::SyncFileStatus sync_file_status; | 422 SyncFileStatus sync_file_status; |
423 | 423 |
424 // 1. The file is not in conflicting nor in pending change state. | 424 // 1. The file is not in conflicting nor in pending change state. |
425 { | 425 { |
426 base::RunLoop run_loop; | 426 base::RunLoop run_loop; |
427 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) | 427 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) |
428 .WillOnce(Return(false)); | 428 .WillOnce(Return(false)); |
429 | 429 |
430 status = fileapi::SYNC_STATUS_UNKNOWN; | 430 status = fileapi::SYNC_STATUS_UNKNOWN; |
431 sync_file_status = fileapi::SYNC_FILE_STATUS_UNKNOWN; | 431 sync_file_status = SYNC_FILE_STATUS_UNKNOWN; |
432 sync_service_->GetFileSyncStatus( | 432 sync_service_->GetFileSyncStatus( |
433 kFile, | 433 kFile, |
434 base::Bind(&AssignValueAndQuit<fileapi::SyncFileStatus>, | 434 base::Bind(&AssignValueAndQuit<SyncFileStatus>, |
435 &run_loop, &status, &sync_file_status)); | 435 &run_loop, &status, &sync_file_status)); |
436 run_loop.Run(); | 436 run_loop.Run(); |
437 | 437 |
438 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); | 438 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); |
439 EXPECT_EQ(fileapi::SYNC_FILE_STATUS_SYNCED, sync_file_status); | 439 EXPECT_EQ(SYNC_FILE_STATUS_SYNCED, sync_file_status); |
440 } | 440 } |
441 | 441 |
442 // 2. Conflicting case. | 442 // 2. Conflicting case. |
443 { | 443 { |
444 base::RunLoop run_loop; | 444 base::RunLoop run_loop; |
445 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) | 445 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) |
446 .WillOnce(Return(true)); | 446 .WillOnce(Return(true)); |
447 | 447 |
448 status = fileapi::SYNC_STATUS_UNKNOWN; | 448 status = fileapi::SYNC_STATUS_UNKNOWN; |
449 sync_file_status = fileapi::SYNC_FILE_STATUS_UNKNOWN; | 449 sync_file_status = SYNC_FILE_STATUS_UNKNOWN; |
450 sync_service_->GetFileSyncStatus( | 450 sync_service_->GetFileSyncStatus( |
451 kFile, | 451 kFile, |
452 base::Bind(&AssignValueAndQuit<fileapi::SyncFileStatus>, | 452 base::Bind(&AssignValueAndQuit<SyncFileStatus>, |
453 &run_loop, &status, &sync_file_status)); | 453 &run_loop, &status, &sync_file_status)); |
454 run_loop.Run(); | 454 run_loop.Run(); |
455 | 455 |
456 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); | 456 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); |
457 EXPECT_EQ(fileapi::SYNC_FILE_STATUS_CONFLICTING, sync_file_status); | 457 EXPECT_EQ(SYNC_FILE_STATUS_CONFLICTING, sync_file_status); |
458 } | 458 } |
459 | 459 |
460 // 3. The file has pending local changes. | 460 // 3. The file has pending local changes. |
461 { | 461 { |
462 EXPECT_EQ(base::PLATFORM_FILE_OK, file_system_->CreateFile(kFile)); | 462 EXPECT_EQ(base::PLATFORM_FILE_OK, file_system_->CreateFile(kFile)); |
463 | 463 |
464 base::RunLoop run_loop; | 464 base::RunLoop run_loop; |
465 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) | 465 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) |
466 .WillOnce(Return(false)); | 466 .WillOnce(Return(false)); |
467 | 467 |
468 status = fileapi::SYNC_STATUS_UNKNOWN; | 468 status = fileapi::SYNC_STATUS_UNKNOWN; |
469 sync_file_status = fileapi::SYNC_FILE_STATUS_UNKNOWN; | 469 sync_file_status = SYNC_FILE_STATUS_UNKNOWN; |
470 sync_service_->GetFileSyncStatus( | 470 sync_service_->GetFileSyncStatus( |
471 kFile, | 471 kFile, |
472 base::Bind(&AssignValueAndQuit<fileapi::SyncFileStatus>, | 472 base::Bind(&AssignValueAndQuit<SyncFileStatus>, |
473 &run_loop, &status, &sync_file_status)); | 473 &run_loop, &status, &sync_file_status)); |
474 run_loop.Run(); | 474 run_loop.Run(); |
475 | 475 |
476 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); | 476 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); |
477 EXPECT_EQ(fileapi::SYNC_FILE_STATUS_HAS_PENDING_CHANGES, sync_file_status); | 477 EXPECT_EQ(SYNC_FILE_STATUS_HAS_PENDING_CHANGES, sync_file_status); |
478 } | 478 } |
479 | 479 |
480 // 4. The file has a conflict and pending local changes. In this case | 480 // 4. The file has a conflict and pending local changes. In this case |
481 // we return SYNC_FILE_STATUS_CONFLICTING. | 481 // we return SYNC_FILE_STATUS_CONFLICTING. |
482 { | 482 { |
483 EXPECT_EQ(base::PLATFORM_FILE_OK, file_system_->TruncateFile(kFile, 1U)); | 483 EXPECT_EQ(base::PLATFORM_FILE_OK, file_system_->TruncateFile(kFile, 1U)); |
484 | 484 |
485 base::RunLoop run_loop; | 485 base::RunLoop run_loop; |
486 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) | 486 EXPECT_CALL(*mock_remote_service(), IsConflicting(kFile)) |
487 .WillOnce(Return(true)); | 487 .WillOnce(Return(true)); |
488 | 488 |
489 status = fileapi::SYNC_STATUS_UNKNOWN; | 489 status = fileapi::SYNC_STATUS_UNKNOWN; |
490 sync_file_status = fileapi::SYNC_FILE_STATUS_UNKNOWN; | 490 sync_file_status = SYNC_FILE_STATUS_UNKNOWN; |
491 sync_service_->GetFileSyncStatus( | 491 sync_service_->GetFileSyncStatus( |
492 kFile, | 492 kFile, |
493 base::Bind(&AssignValueAndQuit<fileapi::SyncFileStatus>, | 493 base::Bind(&AssignValueAndQuit<SyncFileStatus>, |
494 &run_loop, &status, &sync_file_status)); | 494 &run_loop, &status, &sync_file_status)); |
495 run_loop.Run(); | 495 run_loop.Run(); |
496 | 496 |
497 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); | 497 EXPECT_EQ(fileapi::SYNC_STATUS_OK, status); |
498 EXPECT_EQ(fileapi::SYNC_FILE_STATUS_CONFLICTING, sync_file_status); | 498 EXPECT_EQ(SYNC_FILE_STATUS_CONFLICTING, sync_file_status); |
499 } | 499 } |
500 } | 500 } |
501 | 501 |
502 } // namespace sync_file_system | 502 } // namespace sync_file_system |
OLD | NEW |