050-file_iterator.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. #include "catch.hpp"
  2. #include "test-utils.h"
  3. #include "model/cluster.h"
  4. #include "model/diff/modify/create_folder.h"
  5. #include "model/diff/modify/share_folder.h"
  6. #include "model/diff/peer/cluster_update.h"
  7. #include "model/diff/peer/update_folder.h"
  8. using namespace syncspirit;
  9. using namespace syncspirit::test;
  10. using namespace syncspirit::model;
  11. TEST_CASE("file iterator", "[model]") {
  12. auto my_id = device_id_t::from_string("KHQNO2S-5QSILRK-YX4JZZ4-7L77APM-QNVGZJT-EKU7IFI-PNEPBMY-4MXFMQD").value();
  13. auto my_device = device_t::create(my_id, "my-device").value();
  14. auto peer_id = device_id_t::from_string("VUV42CZ-IQD5A37-RPEBPM4-VVQK6E4-6WSKC7B-PVJQHHD-4PZD44V-ENC6WAZ").value();
  15. auto peer_device = device_t::create(peer_id, "peer-device").value();
  16. auto cluster = cluster_ptr_t(new cluster_t(my_device, 1));
  17. cluster->get_devices().put(my_device);
  18. cluster->get_devices().put(peer_device);
  19. auto& folders = cluster->get_folders();
  20. db::Folder db_folder;
  21. db_folder.set_id("1234-5678");
  22. db_folder.set_label("my-label");
  23. db_folder.set_path("/my/path");
  24. auto diff = diff::cluster_diff_ptr_t(new diff::modify::create_folder_t(db_folder));
  25. REQUIRE(diff->apply(*cluster));
  26. auto folder = folders.by_id(db_folder.id());
  27. diff = diff::cluster_diff_ptr_t(new diff::modify::share_folder_t(peer_id.get_sha256(), db_folder.id()));
  28. REQUIRE(diff->apply(*cluster));
  29. SECTION("check when no files") {
  30. CHECK(!cluster->next_file(peer_device));
  31. CHECK(!cluster->next_file(peer_device, true));
  32. }
  33. auto cc = std::make_unique<proto::ClusterConfig>();
  34. auto p_folder = cc->add_folders();
  35. p_folder->set_id(std::string(folder->get_id()));
  36. p_folder->set_label(std::string(folder->get_label()));
  37. auto p_peer = p_folder->add_devices();
  38. p_peer->set_id(std::string(peer_id.get_sha256()));
  39. p_peer->set_name(std::string(peer_device->get_name()));
  40. p_peer->set_max_sequence(10u);
  41. p_peer->set_index_id(123u);
  42. diff = diff::peer::cluster_update_t::create(*cluster, *peer_device, *cc).value();
  43. REQUIRE(diff->apply(*cluster));
  44. proto::Index idx;
  45. idx.set_folder(db_folder.id());
  46. SECTION("2 files at peer") {
  47. auto file_1 = idx.add_files();
  48. file_1->set_name("a.txt");
  49. file_1->set_sequence(10ul);
  50. SECTION("simple_cases") {
  51. auto file_2 = idx.add_files();
  52. file_2->set_name("b.txt");
  53. file_2->set_sequence(9ul);
  54. diff = diff::peer::update_folder_t::create(*cluster, *peer_device, idx).value();
  55. REQUIRE(diff->apply(*cluster));
  56. SECTION("files are missing at my side") {
  57. auto f1 = cluster->next_file(peer_device, true);
  58. REQUIRE(f1);
  59. CHECK(f1->get_name() == "a.txt");
  60. auto f2 = cluster->next_file(peer_device);
  61. REQUIRE(f2);
  62. CHECK(f2->get_name() == "b.txt");
  63. REQUIRE(!cluster->next_file(peer_device));
  64. }
  65. SECTION("one file is already exists on my side") {
  66. auto& folder_infos = cluster->get_folders().by_id(db_folder.id())->get_folder_infos();
  67. auto my_folder = folder_infos.by_device(my_device);
  68. auto pr_file = proto::FileInfo();
  69. pr_file.set_name("a.txt");
  70. auto my_file = file_info_t::create(cluster->next_uuid(), pr_file, my_folder).value();
  71. my_folder->add(my_file);
  72. auto peer_folder = folder_infos.by_device(peer_device);
  73. REQUIRE(peer_folder->get_file_infos().size() == 2);
  74. auto f2 = cluster->next_file(peer_device, true);
  75. REQUIRE(f2);
  76. CHECK(f2->get_name() == "b.txt");
  77. REQUIRE(!cluster->next_file(peer_device));
  78. }
  79. }
  80. SECTION("a file on peer side is newer then on my") {
  81. auto oth_version = file_1->mutable_version();
  82. auto counter = oth_version->add_counters();
  83. counter->set_id(12345ul);
  84. counter->set_value(1233ul);
  85. diff = diff::peer::update_folder_t::create(*cluster, *peer_device, idx).value();
  86. REQUIRE(diff->apply(*cluster));
  87. auto& folder_infos = cluster->get_folders().by_id(db_folder.id())->get_folder_infos();
  88. proto::Vector my_version;
  89. auto my_folder = folder_infos.by_device(my_device);
  90. auto pr_file = proto::FileInfo();
  91. pr_file.set_name("a.txt");
  92. my_folder->add(file_info_t::create(cluster->next_uuid(), pr_file, my_folder).value());
  93. auto f = cluster->next_file(peer_device, true);
  94. REQUIRE(f);
  95. CHECK(f->get_name() == "a.txt");
  96. REQUIRE(!cluster->next_file(peer_device));
  97. }
  98. SECTION("a file on peer side is incomplete") {
  99. file_1->set_size(5ul);
  100. file_1->set_block_size(5ul);
  101. auto b = file_1->add_blocks();
  102. b->set_hash("123");
  103. diff = diff::peer::update_folder_t::create(*cluster, *peer_device, idx).value();
  104. REQUIRE(diff->apply(*cluster));
  105. auto& folder_infos = cluster->get_folders().by_id(db_folder.id())->get_folder_infos();
  106. auto my_folder = folder_infos.by_device(my_device);
  107. my_folder->add(file_info_t::create(cluster->next_uuid(), *file_1, my_folder).value());
  108. auto f = cluster->next_file(peer_device, true);
  109. REQUIRE(f);
  110. CHECK(f->get_name() == "a.txt");
  111. REQUIRE(!cluster->next_file(peer_device));
  112. }
  113. SECTION("folder info is non-actual") {
  114. file_1->set_size(5ul);
  115. file_1->set_block_size(5ul);
  116. diff = diff::peer::update_folder_t::create(*cluster, *peer_device, idx).value();
  117. REQUIRE(diff->apply(*cluster));
  118. auto& folder_infos = cluster->get_folders().by_id(db_folder.id())->get_folder_infos();
  119. auto peer_folder = folder_infos.by_device(peer_device);
  120. peer_folder->add(file_info_t::create(cluster->next_uuid(), *file_1, peer_folder).value());
  121. peer_folder->set_remote_max_sequence(peer_folder->get_max_sequence() + 1);
  122. REQUIRE(!peer_folder->is_actual());
  123. REQUIRE(!cluster->next_file(peer_device, true));
  124. }
  125. }
  126. }