045-diff-advance.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. // SPDX-FileCopyrightText: 2025 Ivan Baidakou
  3. #include "test-utils.h"
  4. #include "access.h"
  5. #include "diff-builder.h"
  6. #include "model/cluster.h"
  7. using namespace syncspirit;
  8. using namespace syncspirit::model;
  9. using namespace syncspirit::proto;
  10. using namespace syncspirit::test;
  11. TEST_CASE("remove folder", "[model]") {
  12. test::init_logging();
  13. auto my_id = device_id_t::from_string("KHQNO2S-5QSILRK-YX4JZZ4-7L77APM-QNVGZJT-EKU7IFI-PNEPBMY-4MXFMQD").value();
  14. auto peer_id = device_id_t::from_string("VUV42CZ-IQD5A37-RPEBPM4-VVQK6E4-6WSKC7B-PVJQHHD-4PZD44V-ENC6WAZ").value();
  15. auto my_device = device_ptr_t{};
  16. my_device = new model::local_device_t(my_id, "my-device", "my-device");
  17. auto peer_device = device_t::create(peer_id, "peer-device").value();
  18. auto cluster = cluster_ptr_t(new cluster_t(my_device, 1));
  19. auto sequencer = make_sequencer(4);
  20. auto &devices = cluster->get_devices();
  21. devices.put(my_device);
  22. devices.put(peer_device);
  23. proto::FileInfo pr_fi;
  24. pr_fi.set_name("a.txt");
  25. pr_fi.set_block_size(0);
  26. pr_fi.set_size(0);
  27. auto counter = pr_fi.mutable_version()->add_counters();
  28. counter->set_id(peer_device->device_id().get_uint());
  29. counter->set_value(5);
  30. auto builder = diff_builder_t(*cluster);
  31. REQUIRE(builder.upsert_folder("f1", "some/path-1", "my-label-1").apply());
  32. REQUIRE(builder.share_folder(peer_id.get_sha256(), "f1").apply());
  33. auto folder = cluster->get_folders().by_id("f1");
  34. auto folder_peer = folder->get_folder_infos().by_device(*peer_device);
  35. auto folder_my = folder->get_folder_infos().by_device(*my_device);
  36. auto &files_my = folder_my->get_file_infos();
  37. auto file_peer = file_info_t::create(sequencer->next_uuid(), pr_fi, folder_peer).value();
  38. SECTION("local update") {
  39. SECTION("all ok") {
  40. REQUIRE(builder.local_update(folder->get_id(), pr_fi).apply());
  41. REQUIRE(files_my.size() == 1);
  42. }
  43. SECTION("after suspending") {
  44. REQUIRE(builder.suspend(*folder).local_update(folder->get_id(), pr_fi).apply());
  45. REQUIRE(files_my.size() == 0);
  46. }
  47. SECTION("after removing") {
  48. REQUIRE(builder.remove_folder(*folder).local_update(folder->get_id(), pr_fi).apply());
  49. REQUIRE(files_my.size() == 0);
  50. }
  51. }
  52. SECTION("remote copy") {
  53. SECTION("all ok") {
  54. REQUIRE(builder.remote_copy(*file_peer).apply());
  55. REQUIRE(files_my.size() == 1);
  56. }
  57. SECTION("after unsharing") {
  58. REQUIRE(builder.unshare_folder(*folder_peer).remote_copy(*file_peer).apply());
  59. REQUIRE(files_my.size() == 0);
  60. }
  61. SECTION("after suspending") {
  62. REQUIRE(builder.suspend(*folder).remote_copy(*file_peer).apply());
  63. REQUIRE(files_my.size() == 0);
  64. }
  65. SECTION("after removing") {
  66. REQUIRE(builder.remove_folder(*folder).remote_copy(*file_peer).apply());
  67. REQUIRE(files_my.size() == 0);
  68. }
  69. }
  70. SECTION("remote win") {
  71. auto pr_fi_local = pr_fi;
  72. pr_fi_local.mutable_version()->mutable_counters(0)->set_value(3);
  73. SECTION("all ok") {
  74. REQUIRE(builder.advance(*file_peer).apply());
  75. REQUIRE(files_my.size() == 1);
  76. }
  77. SECTION("after unsharing") {
  78. REQUIRE(builder.unshare_folder(*folder_peer).advance(*file_peer).apply());
  79. REQUIRE(files_my.size() == 0);
  80. }
  81. SECTION("after suspending") {
  82. REQUIRE(builder.suspend(*folder).advance(*file_peer).apply());
  83. REQUIRE(files_my.size() == 0);
  84. }
  85. SECTION("after removing") {
  86. REQUIRE(builder.remove_folder(*folder).advance(*file_peer).apply());
  87. REQUIRE(files_my.size() == 0);
  88. }
  89. }
  90. }