033-diffs-trivial.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. // SPDX-FileCopyrightText: 2019-2025 Ivan Baidakou
  3. #include "test-utils.h"
  4. #include "access.h"
  5. #include "diff-builder.h"
  6. #include "model/cluster.h"
  7. #include "model/diff/modify/lock_file.h"
  8. #include "model/diff/local/file_availability.h"
  9. #include "model/diff/contact/update_contact.h"
  10. using namespace syncspirit;
  11. using namespace syncspirit::model;
  12. using namespace syncspirit::proto;
  13. using namespace syncspirit::test;
  14. TEST_CASE("peer state update", "[model]") {
  15. auto my_id = device_id_t::from_string("KHQNO2S-5QSILRK-YX4JZZ4-7L77APM-QNVGZJT-EKU7IFI-PNEPBMY-4MXFMQD").value();
  16. auto my_device = device_t::create(my_id, "my-device").value();
  17. auto peer_id = device_id_t::from_string("VUV42CZ-IQD5A37-RPEBPM4-VVQK6E4-6WSKC7B-PVJQHHD-4PZD44V-ENC6WAZ").value();
  18. auto peer_device = device_t::create(peer_id, "peer-device").value();
  19. auto cluster = cluster_ptr_t(new cluster_t(my_device, 1));
  20. cluster->get_devices().put(my_device);
  21. cluster->get_devices().put(peer_device);
  22. rotor::address_ptr_t addr;
  23. auto builder = diff_builder_t(*cluster);
  24. REQUIRE(peer_device->get_state() == model::device_state_t::offline);
  25. auto connection_id = std::string("tcp://1.1.1.1:1");
  26. REQUIRE(builder.update_state(*peer_device, addr, device_state_t::online, connection_id).apply());
  27. CHECK(peer_device->get_state() == model::device_state_t::online);
  28. REQUIRE(builder.update_state(*peer_device, addr, device_state_t::offline, connection_id).apply());
  29. CHECK(peer_device->get_state() == model::device_state_t::offline);
  30. }
  31. TEST_CASE("with file", "[model]") {
  32. auto my_id = device_id_t::from_string("KHQNO2S-5QSILRK-YX4JZZ4-7L77APM-QNVGZJT-EKU7IFI-PNEPBMY-4MXFMQD").value();
  33. auto my_device = device_t::create(my_id, "my-device").value();
  34. auto cluster = cluster_ptr_t(new cluster_t(my_device, 1));
  35. cluster->get_devices().put(my_device);
  36. auto builder = diff_builder_t(*cluster);
  37. builder.upsert_folder("1234-5678", "some/path", "my-label");
  38. REQUIRE(builder.apply());
  39. auto folder = cluster->get_folders().by_id("1234-5678");
  40. auto folder_info = folder->get_folder_infos().by_device(*my_device);
  41. proto::FileInfo pr_file_info;
  42. pr_file_info.set_name("a.txt");
  43. pr_file_info.set_type(proto::FileInfoType::SYMLINK);
  44. pr_file_info.set_symlink_target("/some/where");
  45. pr_file_info.set_block_size(5);
  46. pr_file_info.set_size(5);
  47. auto b1_hash = utils::sha256_digest("12345").value();
  48. auto b1 = pr_file_info.add_blocks();
  49. b1->set_hash(b1_hash);
  50. b1->set_offset(0);
  51. b1->set_size(5);
  52. REQUIRE(builder.local_update(folder->get_id(), pr_file_info).apply());
  53. auto file = folder_info->get_file_infos().by_name("a.txt");
  54. REQUIRE(file);
  55. auto v = file->get_version();
  56. REQUIRE(v->counters_size() == 1);
  57. REQUIRE(v->get_counter(0).id() == my_device->device_id().get_uint());
  58. SECTION("lock/unlock") {
  59. auto diff = diff::cluster_diff_ptr_t(new diff::modify::lock_file_t(*file, true));
  60. REQUIRE(diff->apply(*cluster, get_apply_controller()));
  61. auto file = folder_info->get_file_infos().by_name(pr_file_info.name());
  62. REQUIRE(file->is_locked());
  63. diff = diff::cluster_diff_ptr_t(new diff::modify::lock_file_t(*file, false));
  64. REQUIRE(diff->apply(*cluster, get_apply_controller()));
  65. REQUIRE(!file->is_locked());
  66. }
  67. SECTION("file_availability") {
  68. auto block = cluster->get_blocks().get(b1_hash);
  69. file->remove_blocks();
  70. file->assign_block(block, 0);
  71. REQUIRE(!file->is_locally_available());
  72. auto diff = diff::cluster_diff_ptr_t(new diff::local::file_availability_t(file));
  73. REQUIRE(diff->apply(*cluster, get_apply_controller()));
  74. REQUIRE(file->is_locally_available());
  75. }
  76. }
  77. TEST_CASE("update_contact_t", "[model]") {
  78. auto my_id = device_id_t::from_string("KHQNO2S-5QSILRK-YX4JZZ4-7L77APM-QNVGZJT-EKU7IFI-PNEPBMY-4MXFMQD").value();
  79. auto my_device = device_t::create(my_id, "my-device").value();
  80. auto peer_id = device_id_t::from_string("VUV42CZ-IQD5A37-RPEBPM4-VVQK6E4-6WSKC7B-PVJQHHD-4PZD44V-ENC6WAZ").value();
  81. auto peer_device = device_t::create(peer_id, "peer-device").value();
  82. auto cluster = cluster_ptr_t(new cluster_t(my_device, 1));
  83. cluster->get_devices().put(my_device);
  84. cluster->get_devices().put(peer_device);
  85. {
  86. auto url_1 = utils::parse("tcp://192.168.100.6:22000");
  87. auto url_2 = utils::parse("tcp://192.168.100.6:22001");
  88. auto url_3 = utils::parse("tcp://192.168.100.6:22001");
  89. auto update_peer = diff::cluster_diff_ptr_t(
  90. new diff::contact::update_contact_t(*cluster, peer_id, utils::uri_container_t{url_1, url_1, url_2, url_3}));
  91. REQUIRE(update_peer->apply(*cluster, get_apply_controller()));
  92. auto &uris = peer_device->get_uris();
  93. REQUIRE(uris.size() == 2u);
  94. CHECK(*uris[0] == *url_1);
  95. CHECK(*uris[1] == *url_2);
  96. };
  97. }