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 "chrome/browser/chromeos/drive/file_system.h" | 5 #include "chrome/browser/chromeos/drive/file_system.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
(...skipping 637 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
648 ASSERT_TRUE( | 648 ASSERT_TRUE( |
649 LoadChangeFeed("chromeos/gdata/delta_file_deleted_in_directory.json")); | 649 LoadChangeFeed("chromeos/gdata/delta_file_deleted_in_directory.json")); |
650 EXPECT_TRUE( | 650 EXPECT_TRUE( |
651 EntryExists(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1")))); | 651 EntryExists(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1")))); |
652 EXPECT_FALSE(EntryExists(base::FilePath( | 652 EXPECT_FALSE(EntryExists(base::FilePath( |
653 FILE_PATH_LITERAL("drive/root/Directory 1/Added file.gdoc")))); | 653 FILE_PATH_LITERAL("drive/root/Directory 1/Added file.gdoc")))); |
654 } | 654 } |
655 | 655 |
656 TEST_F(FileSystemTest, ChangeFeed_AddFileToNewDirectory) { | 656 TEST_F(FileSystemTest, ChangeFeed_AddFileToNewDirectory) { |
657 ASSERT_TRUE(LoadRootFeedDocument()); | 657 ASSERT_TRUE(LoadRootFeedDocument()); |
658 // Add file to a new directory. | 658 ASSERT_FALSE(EntryExists(base::FilePath( |
659 FILE_PATH_LITERAL("drive/root/New Directory/New File.txt")))); | |
660 | |
659 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 661 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
660 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); | 662 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); |
661 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 663 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
662 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/New Directory"))))) | 664 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/New Directory"))))) |
663 .Times(1); | 665 .Times(1); |
664 | 666 |
665 ASSERT_TRUE( | 667 // This adds "drive/root/New Directory" and then |
666 LoadChangeFeed("chromeos/gdata/delta_file_added_in_new_directory.json")); | 668 // "drive/root/New Directory/New File.txt" on the server. |
satorux1
2013/05/28 05:01:33
Here, we were indirectly testing the ChangeListPro
kinaba
2013/05/28 06:20:27
We are still testing ChangeListProcessor indirectl
| |
669 google_apis::GDataErrorCode error = google_apis::GDATA_OTHER_ERROR; | |
670 scoped_ptr<google_apis::ResourceEntry> entry; | |
671 fake_drive_service_->AddNewDirectory( | |
672 fake_drive_service_->GetRootResourceId(), | |
673 "New Directory", | |
674 google_apis::test_util::CreateCopyResultCallback(&error, &entry)); | |
675 google_apis::test_util::RunBlockingPoolTask(); | |
676 ASSERT_EQ(google_apis::HTTP_CREATED, error); | |
667 | 677 |
678 error = google_apis::GDATA_OTHER_ERROR; | |
679 fake_drive_service_->AddNewFile( | |
680 "text/plain", | |
681 "hello world", | |
682 entry->resource_id(), | |
683 "New File.txt", | |
684 false, | |
685 google_apis::test_util::CreateCopyResultCallback(&error, &entry)); | |
686 google_apis::test_util::RunBlockingPoolTask(); | |
687 ASSERT_EQ(google_apis::HTTP_CREATED, error); | |
688 | |
689 // Load the change list. | |
690 file_system_->CheckForUpdates(); | |
691 google_apis::test_util::RunBlockingPoolTask(); | |
692 | |
693 // Verify that the update is reflected. | |
668 EXPECT_TRUE( | 694 EXPECT_TRUE( |
669 EntryExists(base::FilePath( | 695 EntryExists(base::FilePath( |
670 FILE_PATH_LITERAL("drive/root/New Directory")))); | 696 FILE_PATH_LITERAL("drive/root/New Directory")))); |
671 EXPECT_TRUE(EntryExists(base::FilePath( | 697 EXPECT_TRUE(EntryExists(base::FilePath( |
672 FILE_PATH_LITERAL("drive/root/New Directory/File in new dir.gdoc")))); | 698 FILE_PATH_LITERAL("drive/root/New Directory/New File.txt")))); |
673 } | 699 } |
674 | 700 |
675 TEST_F(FileSystemTest, ChangeFeed_AddFileToNewButDeletedDirectory) { | 701 TEST_F(FileSystemTest, ChangeFeed_AddFileToNewButDeletedDirectory) { |
676 ASSERT_TRUE(LoadRootFeedDocument()); | 702 ASSERT_TRUE(LoadRootFeedDocument()); |
677 | 703 |
678 // This feed contains the following updates: | 704 // This feed contains the following updates: |
679 // 1) A new PDF file is added to a new directory | 705 // 1) A new PDF file is added to a new directory |
680 // 2) but the new directory is marked "deleted" (i.e. moved to Trash) | 706 // 2) but the new directory is marked "deleted" (i.e. moved to Trash) |
681 // Hence, the PDF file should be just ignored. | 707 // Hence, the PDF file should be just ignored. |
682 ASSERT_TRUE(LoadChangeFeed( | 708 ASSERT_TRUE(LoadChangeFeed( |
683 "chromeos/gdata/delta_file_added_in_new_but_deleted_directory.json")); | 709 "chromeos/gdata/delta_file_added_in_new_but_deleted_directory.json")); |
684 } | 710 } |
685 | 711 |
686 TEST_F(FileSystemTest, ChangeFeed_DirectoryMovedFromRootToDirectory) { | 712 TEST_F(FileSystemTest, ChangeFeed_DirectoryMovedFromRootToDirectory) { |
687 ASSERT_TRUE(LoadRootFeedDocument()); | 713 ASSERT_TRUE(LoadRootFeedDocument()); |
714 ASSERT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
715 "drive/root/Directory 1")))); | |
688 | 716 |
689 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
690 "drive/root/Directory 2 excludeDir-test")))); | |
691 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
692 "drive/root/Directory 1")))); | |
693 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
694 "drive/root/Directory 1/SubDirectory File 1.txt")))); | |
695 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
696 "drive/root/Directory 1/Sub Directory Folder")))); | |
697 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
698 "drive/root/Directory 1/Sub Directory Folder/" | |
699 "Sub Sub Directory Folder")))); | |
700 | |
701 // This will move "Directory 1" from "drive/root/" to | |
702 // "drive/root/Directory 2/". | |
703 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 717 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
704 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); | 718 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); |
705 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 719 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
706 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1"))))) | 720 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1"))))) |
707 .Times(1); | 721 .Times(1); |
708 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 722 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
709 Eq(base::FilePath(FILE_PATH_LITERAL( | 723 Eq(base::FilePath(FILE_PATH_LITERAL( |
710 "drive/root/Directory 2 excludeDir-test"))))).Times(1); | 724 "drive/root/Directory 2 excludeDir-test"))))).Times(1); |
711 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 725 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
712 Eq(base::FilePath(FILE_PATH_LITERAL( | 726 Eq(base::FilePath(FILE_PATH_LITERAL( |
713 "drive/root/Directory 2 excludeDir-test/Directory 1"))))).Times(1); | 727 "drive/root/Directory 2 excludeDir-test/Directory 1"))))).Times(1); |
714 ASSERT_TRUE(LoadChangeFeed( | |
715 "chromeos/gdata/delta_dir_moved_from_root_to_directory.json")); | |
716 | 728 |
717 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 729 // This will move "Directory 1" from "drive/root/" to |
718 "drive/root/Directory 2 excludeDir-test")))); | 730 // "drive/root/Directory 2 excludeDir-test/" on the server. |
731 google_apis::GDataErrorCode error = google_apis::GDATA_OTHER_ERROR; | |
732 fake_drive_service_->AddResourceToDirectory( | |
733 "folder:sub_dir_folder_2_self_link", | |
734 "folder:1_folder_resource_id", | |
735 google_apis::test_util::CreateCopyResultCallback(&error)); | |
736 google_apis::test_util::RunBlockingPoolTask(); | |
737 ASSERT_EQ(google_apis::HTTP_SUCCESS, error); | |
738 | |
739 error = google_apis::GDATA_OTHER_ERROR; | |
740 fake_drive_service_->RemoveResourceFromDirectory( | |
741 fake_drive_service_->GetRootResourceId(), | |
742 "folder:1_folder_resource_id", | |
743 google_apis::test_util::CreateCopyResultCallback(&error)); | |
744 google_apis::test_util::RunBlockingPoolTask(); | |
745 ASSERT_EQ(google_apis::HTTP_SUCCESS, error); | |
746 | |
747 // Load the change list. | |
748 file_system_->CheckForUpdates(); | |
749 google_apis::test_util::RunBlockingPoolTask(); | |
750 | |
751 // Verify that the update is reflected. | |
719 EXPECT_FALSE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 752 EXPECT_FALSE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
720 "drive/root/Directory 1")))); | 753 "drive/root/Directory 1")))); |
721 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 754 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
722 "drive/root/Directory 2 excludeDir-test/Directory 1")))); | 755 "drive/root/Directory 2 excludeDir-test/Directory 1")))); |
723 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 756 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
724 "drive/root/Directory 2 excludeDir-test/Directory 1/" | 757 "drive/root/Directory 2 excludeDir-test/Directory 1/" |
725 "SubDirectory File 1.txt")))); | 758 "SubDirectory File 1.txt")))); |
726 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 759 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
727 "drive/root/Directory 2 excludeDir-test/Directory 1/" | 760 "drive/root/Directory 2 excludeDir-test/Directory 1/" |
728 "Sub Directory Folder")))); | 761 "Sub Directory Folder")))); |
729 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 762 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
730 "drive/root/Directory 2 excludeDir-test/Directory 1/Sub Directory Folder/" | 763 "drive/root/Directory 2 excludeDir-test/Directory 1/Sub Directory Folder/" |
731 "Sub Sub Directory Folder")))); | 764 "Sub Sub Directory Folder")))); |
732 } | 765 } |
733 | 766 |
734 TEST_F(FileSystemTest, ChangeFeed_FileMovedFromDirectoryToRoot) { | 767 TEST_F(FileSystemTest, ChangeFeed_FileMovedFromDirectoryToRoot) { |
735 ASSERT_TRUE(LoadRootFeedDocument()); | 768 ASSERT_TRUE(LoadRootFeedDocument()); |
736 | 769 ASSERT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
737 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
738 "drive/root/Directory 1")))); | |
739 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
740 "drive/root/Directory 1/Sub Directory Folder")))); | |
741 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
742 "drive/root/Directory 1/Sub Directory Folder/" | |
743 "Sub Sub Directory Folder")))); | |
744 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
745 "drive/root/Directory 1/SubDirectory File 1.txt")))); | 770 "drive/root/Directory 1/SubDirectory File 1.txt")))); |
746 | 771 |
747 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 772 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
748 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); | 773 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); |
749 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 774 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
750 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1"))))) | 775 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1"))))) |
751 .Times(1); | 776 .Times(1); |
752 ASSERT_TRUE(LoadChangeFeed( | |
753 "chromeos/gdata/delta_file_moved_from_directory_to_root.json")); | |
754 | 777 |
755 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 778 // This will move "drive/root/Directory 1/SubDirectory File 1.txt" |
756 "drive/root/Directory 1")))); | 779 // to "drive/root/SubDirectory File 1.txt" on the server. |
757 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 780 google_apis::GDataErrorCode error = google_apis::GDATA_OTHER_ERROR; |
758 "drive/root/Directory 1/Sub Directory Folder")))); | 781 fake_drive_service_->AddResourceToDirectory( |
759 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 782 fake_drive_service_->GetRootResourceId(), |
760 "drive/root/Directory 1/Sub Directory Folder/" | 783 "file:subdirectory_file_1_id", |
761 "Sub Sub Directory Folder")))); | 784 google_apis::test_util::CreateCopyResultCallback(&error)); |
785 google_apis::test_util::RunBlockingPoolTask(); | |
786 ASSERT_EQ(google_apis::HTTP_SUCCESS, error); | |
787 | |
788 error = google_apis::GDATA_OTHER_ERROR; | |
789 fake_drive_service_->RemoveResourceFromDirectory( | |
790 "folder:1_folder_resource_id", | |
791 "file:subdirectory_file_1_id", | |
792 google_apis::test_util::CreateCopyResultCallback(&error)); | |
793 google_apis::test_util::RunBlockingPoolTask(); | |
794 ASSERT_EQ(google_apis::HTTP_SUCCESS, error); | |
795 | |
796 // Load the change list. | |
797 file_system_->CheckForUpdates(); | |
798 google_apis::test_util::RunBlockingPoolTask(); | |
799 | |
800 // Verify that the update is reflected. | |
762 EXPECT_FALSE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 801 EXPECT_FALSE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
763 "drive/root/Directory 1/SubDirectory File 1.txt")))); | 802 "drive/root/Directory 1/SubDirectory File 1.txt")))); |
764 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 803 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
765 "drive/root/SubDirectory File 1.txt")))); | 804 "drive/root/SubDirectory File 1.txt")))); |
766 } | 805 } |
767 | 806 |
768 TEST_F(FileSystemTest, ChangeFeed_FileRenamedInDirectory) { | 807 TEST_F(FileSystemTest, ChangeFeed_FileRenamedInDirectory) { |
769 ASSERT_TRUE(LoadRootFeedDocument()); | 808 ASSERT_TRUE(LoadRootFeedDocument()); |
770 | 809 ASSERT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
771 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
772 "drive/root/Directory 1")))); | |
773 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | |
774 "drive/root/Directory 1/SubDirectory File 1.txt")))); | 810 "drive/root/Directory 1/SubDirectory File 1.txt")))); |
775 | 811 |
776 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | 812 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( |
777 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root"))))).Times(1); | |
778 EXPECT_CALL(*mock_directory_observer_, OnDirectoryChanged( | |
779 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1"))))) | 813 Eq(base::FilePath(FILE_PATH_LITERAL("drive/root/Directory 1"))))) |
780 .Times(1); | 814 .Times(1); |
781 ASSERT_TRUE(LoadChangeFeed( | |
782 "chromeos/gdata/delta_file_renamed_in_directory.json")); | |
783 | 815 |
784 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 816 // Rename on the server. |
785 "drive/root/Directory 1")))); | 817 google_apis::GDataErrorCode error = google_apis::GDATA_OTHER_ERROR; |
818 fake_drive_service_->RenameResource( | |
819 "file:subdirectory_file_1_id", | |
820 "New SubDirectory File 1.txt", | |
821 google_apis::test_util::CreateCopyResultCallback(&error)); | |
822 google_apis::test_util::RunBlockingPoolTask(); | |
823 ASSERT_EQ(google_apis::HTTP_SUCCESS, error); | |
824 | |
825 // Load the change list. | |
826 file_system_->CheckForUpdates(); | |
827 google_apis::test_util::RunBlockingPoolTask(); | |
828 | |
829 // Verify that the update is reflected. | |
786 EXPECT_FALSE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 830 EXPECT_FALSE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
787 "drive/root/Directory 1/SubDirectory File 1.txt")))); | 831 "drive/root/Directory 1/SubDirectory File 1.txt")))); |
788 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( | 832 EXPECT_TRUE(EntryExists(base::FilePath(FILE_PATH_LITERAL( |
789 "drive/root/Directory 1/New SubDirectory File 1.txt")))); | 833 "drive/root/Directory 1/New SubDirectory File 1.txt")))); |
790 } | 834 } |
791 | 835 |
792 TEST_F(FileSystemTest, CachedFeedLoadingThenServerFeedLoading) { | 836 TEST_F(FileSystemTest, CachedFeedLoadingThenServerFeedLoading) { |
793 ASSERT_TRUE(SetUpTestFileSystem(USE_SERVER_TIMESTAMP)); | 837 ASSERT_TRUE(SetUpTestFileSystem(USE_SERVER_TIMESTAMP)); |
794 | 838 |
795 // Kicks loading of cached file system and query for server update. | 839 // Kicks loading of cached file system and query for server update. |
(...skipping 976 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1772 entry->resource_id(), | 1816 entry->resource_id(), |
1773 entry->file_specific_info().file_md5(), | 1817 entry->file_specific_info().file_md5(), |
1774 google_apis::test_util::CreateCopyResultCallback(&success, &cache_entry)); | 1818 google_apis::test_util::CreateCopyResultCallback(&success, &cache_entry)); |
1775 google_apis::test_util::RunBlockingPoolTask(); | 1819 google_apis::test_util::RunBlockingPoolTask(); |
1776 | 1820 |
1777 EXPECT_TRUE(success); | 1821 EXPECT_TRUE(success); |
1778 EXPECT_FALSE(cache_entry.is_mounted()); | 1822 EXPECT_FALSE(cache_entry.is_mounted()); |
1779 } | 1823 } |
1780 | 1824 |
1781 } // namespace drive | 1825 } // namespace drive |
OLD | NEW |