033-diffs-trivial.cpp 5.1 KB

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