@layerzerolabs/protocol-stellar-v2 0.2.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (265) hide show
  1. package/.turbo/turbo-build.log +727 -0
  2. package/.turbo/turbo-lint.log +158 -0
  3. package/.turbo/turbo-test.log +796 -0
  4. package/Cargo.lock +2237 -0
  5. package/Cargo.toml +63 -0
  6. package/clippy.toml +7 -0
  7. package/contracts/common-macros/Cargo.toml +20 -0
  8. package/contracts/common-macros/src/error.rs +53 -0
  9. package/contracts/common-macros/src/event.rs +16 -0
  10. package/contracts/common-macros/src/lib.rs +255 -0
  11. package/contracts/common-macros/src/ownable.rs +63 -0
  12. package/contracts/common-macros/src/snapshots/common_macros__tests__tests__snapshot_generated_storage_code.snap +310 -0
  13. package/contracts/common-macros/src/storage.rs +439 -0
  14. package/contracts/common-macros/src/tests.rs +287 -0
  15. package/contracts/common-macros/src/ttl_configurable.rs +60 -0
  16. package/contracts/endpoint-v2/ARCHITECTURE.md +233 -0
  17. package/contracts/endpoint-v2/Cargo.toml +30 -0
  18. package/contracts/endpoint-v2/src/constants.rs +52 -0
  19. package/contracts/endpoint-v2/src/endpoint_v2.rs +305 -0
  20. package/contracts/endpoint-v2/src/errors.rs +29 -0
  21. package/contracts/endpoint-v2/src/events.rs +207 -0
  22. package/contracts/endpoint-v2/src/interfaces/layerzero_composer.rs +26 -0
  23. package/contracts/endpoint-v2/src/interfaces/layerzero_endpoint_v2.rs +170 -0
  24. package/contracts/endpoint-v2/src/interfaces/layerzero_receiver.rs +43 -0
  25. package/contracts/endpoint-v2/src/interfaces/message_lib.rs +62 -0
  26. package/contracts/endpoint-v2/src/interfaces/message_lib_manager.rs +220 -0
  27. package/contracts/endpoint-v2/src/interfaces/messaging_channel.rs +121 -0
  28. package/contracts/endpoint-v2/src/interfaces/messaging_composer.rs +63 -0
  29. package/contracts/endpoint-v2/src/interfaces/mod.rs +17 -0
  30. package/contracts/endpoint-v2/src/interfaces/send_lib.rs +70 -0
  31. package/contracts/endpoint-v2/src/lib.rs +22 -0
  32. package/contracts/endpoint-v2/src/message_lib_manager.rs +315 -0
  33. package/contracts/endpoint-v2/src/messaging_channel.rs +218 -0
  34. package/contracts/endpoint-v2/src/messaging_composer.rs +76 -0
  35. package/contracts/endpoint-v2/src/storage.rs +78 -0
  36. package/contracts/endpoint-v2/src/tests/endpoint_setup.rs +131 -0
  37. package/contracts/endpoint-v2/src/tests/endpoint_v2/clear.rs +237 -0
  38. package/contracts/endpoint-v2/src/tests/endpoint_v2/delegate.rs +42 -0
  39. package/contracts/endpoint-v2/src/tests/endpoint_v2/initializable.rs +76 -0
  40. package/contracts/endpoint-v2/src/tests/endpoint_v2/lz_receive_alert.rs +211 -0
  41. package/contracts/endpoint-v2/src/tests/endpoint_v2/mod.rs +18 -0
  42. package/contracts/endpoint-v2/src/tests/endpoint_v2/native_token.rs +10 -0
  43. package/contracts/endpoint-v2/src/tests/endpoint_v2/owner.rs +10 -0
  44. package/contracts/endpoint-v2/src/tests/endpoint_v2/pay_messaging_fees.rs +424 -0
  45. package/contracts/endpoint-v2/src/tests/endpoint_v2/quote.rs +144 -0
  46. package/contracts/endpoint-v2/src/tests/endpoint_v2/recover_token.rs +72 -0
  47. package/contracts/endpoint-v2/src/tests/endpoint_v2/require_oapp_auth.rs +29 -0
  48. package/contracts/endpoint-v2/src/tests/endpoint_v2/send.rs +513 -0
  49. package/contracts/endpoint-v2/src/tests/endpoint_v2/set_delegate.rs +43 -0
  50. package/contracts/endpoint-v2/src/tests/endpoint_v2/set_zro.rs +27 -0
  51. package/contracts/endpoint-v2/src/tests/endpoint_v2/transfer_ownership.rs +30 -0
  52. package/contracts/endpoint-v2/src/tests/endpoint_v2/ttl_config.rs +202 -0
  53. package/contracts/endpoint-v2/src/tests/endpoint_v2/verifiable.rs +59 -0
  54. package/contracts/endpoint-v2/src/tests/endpoint_v2/verify.rs +172 -0
  55. package/contracts/endpoint-v2/src/tests/endpoint_v2/zro.rs +23 -0
  56. package/contracts/endpoint-v2/src/tests/message_lib_manager/mod.rs +10 -0
  57. package/contracts/endpoint-v2/src/tests/message_lib_manager/register_library.rs +131 -0
  58. package/contracts/endpoint-v2/src/tests/message_lib_manager/require_registered.rs +35 -0
  59. package/contracts/endpoint-v2/src/tests/message_lib_manager/require_supported_eid.rs +28 -0
  60. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_config.rs +79 -0
  61. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_receive_lib_timeout.rs +246 -0
  62. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_receive_library.rs +285 -0
  63. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_send_library.rs +180 -0
  64. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_receive_library.rs +405 -0
  65. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_receive_library_timeout.rs +80 -0
  66. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_send_library.rs +131 -0
  67. package/contracts/endpoint-v2/src/tests/messaging_channel/burn.rs +358 -0
  68. package/contracts/endpoint-v2/src/tests/messaging_channel/clear.rs +316 -0
  69. package/contracts/endpoint-v2/src/tests/messaging_channel/inbound_nonce.rs +288 -0
  70. package/contracts/endpoint-v2/src/tests/messaging_channel/inbound_payload_hash.rs +316 -0
  71. package/contracts/endpoint-v2/src/tests/messaging_channel/internal.rs +388 -0
  72. package/contracts/endpoint-v2/src/tests/messaging_channel/lazy_inbound_nonce.rs +307 -0
  73. package/contracts/endpoint-v2/src/tests/messaging_channel/mod.rs +10 -0
  74. package/contracts/endpoint-v2/src/tests/messaging_channel/next_guid.rs +239 -0
  75. package/contracts/endpoint-v2/src/tests/messaging_channel/nilify.rs +324 -0
  76. package/contracts/endpoint-v2/src/tests/messaging_channel/outbound_nonce.rs +242 -0
  77. package/contracts/endpoint-v2/src/tests/messaging_channel/skip.rs +232 -0
  78. package/contracts/endpoint-v2/src/tests/messaging_composer/clear_compose.rs +212 -0
  79. package/contracts/endpoint-v2/src/tests/messaging_composer/compose_queue.rs +213 -0
  80. package/contracts/endpoint-v2/src/tests/messaging_composer/lz_compose_alert.rs +269 -0
  81. package/contracts/endpoint-v2/src/tests/messaging_composer/mod.rs +4 -0
  82. package/contracts/endpoint-v2/src/tests/messaging_composer/send_compose.rs +173 -0
  83. package/contracts/endpoint-v2/src/tests/mock.rs +132 -0
  84. package/contracts/endpoint-v2/src/tests/mod.rs +12 -0
  85. package/contracts/endpoint-v2/src/tests/util/build_payload.rs +126 -0
  86. package/contracts/endpoint-v2/src/tests/util/compute_guid.rs +82 -0
  87. package/contracts/endpoint-v2/src/tests/util/keccak256.rs +115 -0
  88. package/contracts/endpoint-v2/src/tests/util/mod.rs +3 -0
  89. package/contracts/endpoint-v2/src/util.rs +52 -0
  90. package/contracts/message-libs/Cargo.toml +12 -0
  91. package/contracts/message-libs/block-message-lib/Cargo.toml +19 -0
  92. package/contracts/message-libs/block-message-lib/src/lib.rs +70 -0
  93. package/contracts/message-libs/lib.rs +2 -0
  94. package/contracts/message-libs/message-lib-common/Cargo.toml +24 -0
  95. package/contracts/message-libs/message-lib-common/src/errors.rs +20 -0
  96. package/contracts/message-libs/message-lib-common/src/interfaces/dvn.rs +55 -0
  97. package/contracts/message-libs/message-lib-common/src/interfaces/executor.rs +46 -0
  98. package/contracts/message-libs/message-lib-common/src/interfaces/mod.rs +7 -0
  99. package/contracts/message-libs/message-lib-common/src/interfaces/treasury.rs +17 -0
  100. package/contracts/message-libs/message-lib-common/src/lib.rs +14 -0
  101. package/contracts/message-libs/message-lib-common/src/packet_codec_v1.rs +99 -0
  102. package/contracts/message-libs/message-lib-common/src/testing_utils.rs +27 -0
  103. package/contracts/message-libs/message-lib-common/src/tests/mod.rs +2 -0
  104. package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1.rs +162 -0
  105. package/contracts/message-libs/message-lib-common/src/tests/worker_options.rs +319 -0
  106. package/contracts/message-libs/message-lib-common/src/worker_options.rs +190 -0
  107. package/contracts/message-libs/simple-message-lib/Cargo.toml +26 -0
  108. package/contracts/message-libs/simple-message-lib/src/errors.rs +11 -0
  109. package/contracts/message-libs/simple-message-lib/src/lib.rs +14 -0
  110. package/contracts/message-libs/simple-message-lib/src/simple_message_lib.rs +136 -0
  111. package/contracts/message-libs/simple-message-lib/src/storage.rs +27 -0
  112. package/contracts/message-libs/simple-message-lib/src/test.rs +280 -0
  113. package/contracts/message-libs/treasury/Cargo.toml +27 -0
  114. package/contracts/message-libs/treasury/src/errors.rs +10 -0
  115. package/contracts/message-libs/treasury/src/events.rs +28 -0
  116. package/contracts/message-libs/treasury/src/interfaces/mod.rs +3 -0
  117. package/contracts/message-libs/treasury/src/interfaces/zro_fee_lib.rs +20 -0
  118. package/contracts/message-libs/treasury/src/lib.rs +20 -0
  119. package/contracts/message-libs/treasury/src/storage.rs +18 -0
  120. package/contracts/message-libs/treasury/src/tests/mod.rs +2 -0
  121. package/contracts/message-libs/treasury/src/tests/setup.rs +112 -0
  122. package/contracts/message-libs/treasury/src/tests/treasury_tests.rs +562 -0
  123. package/contracts/message-libs/treasury/src/treasury.rs +140 -0
  124. package/contracts/message-libs/uln-302/Cargo.toml +28 -0
  125. package/contracts/message-libs/uln-302/src/config_validation.rs +173 -0
  126. package/contracts/message-libs/uln-302/src/errors.rs +29 -0
  127. package/contracts/message-libs/uln-302/src/events.rs +72 -0
  128. package/contracts/message-libs/uln-302/src/interfaces/mod.rs +5 -0
  129. package/contracts/message-libs/uln-302/src/interfaces/receive.rs +82 -0
  130. package/contracts/message-libs/uln-302/src/interfaces/send.rs +159 -0
  131. package/contracts/message-libs/uln-302/src/lib.rs +20 -0
  132. package/contracts/message-libs/uln-302/src/receive.rs +199 -0
  133. package/contracts/message-libs/uln-302/src/send.rs +349 -0
  134. package/contracts/message-libs/uln-302/src/storage.rs +47 -0
  135. package/contracts/message-libs/uln-302/src/tests/config/mod.rs +2 -0
  136. package/contracts/message-libs/uln-302/src/tests/config/oapp_uln_config.rs +291 -0
  137. package/contracts/message-libs/uln-302/src/tests/config/uln_config.rs +163 -0
  138. package/contracts/message-libs/uln-302/src/tests/mod.rs +7 -0
  139. package/contracts/message-libs/uln-302/src/tests/receive_uln302/commit_verification.rs +183 -0
  140. package/contracts/message-libs/uln-302/src/tests/receive_uln302/confirmations.rs +128 -0
  141. package/contracts/message-libs/uln-302/src/tests/receive_uln302/effective_receive_uln_config.rs +104 -0
  142. package/contracts/message-libs/uln-302/src/tests/receive_uln302/mod.rs +66 -0
  143. package/contracts/message-libs/uln-302/src/tests/receive_uln302/set_default_receive_uln_configs.rs +79 -0
  144. package/contracts/message-libs/uln-302/src/tests/receive_uln302/verifiable.rs +463 -0
  145. package/contracts/message-libs/uln-302/src/tests/receive_uln302/verify.rs +173 -0
  146. package/contracts/message-libs/uln-302/src/tests/send_uln302/effective_executor_config.rs +132 -0
  147. package/contracts/message-libs/uln-302/src/tests/send_uln302/effective_send_uln_config.rs +117 -0
  148. package/contracts/message-libs/uln-302/src/tests/send_uln302/mod.rs +6 -0
  149. package/contracts/message-libs/uln-302/src/tests/send_uln302/quote.rs +586 -0
  150. package/contracts/message-libs/uln-302/src/tests/send_uln302/send.rs +834 -0
  151. package/contracts/message-libs/uln-302/src/tests/send_uln302/set_default_executor_configs.rs +95 -0
  152. package/contracts/message-libs/uln-302/src/tests/send_uln302/set_default_send_uln_configs.rs +80 -0
  153. package/contracts/message-libs/uln-302/src/tests/setup.rs +268 -0
  154. package/contracts/message-libs/uln-302/src/tests/testing_utils.rs +47 -0
  155. package/contracts/message-libs/uln-302/src/tests/uln302/get_app_receive_uln_config.rs +51 -0
  156. package/contracts/message-libs/uln-302/src/tests/uln302/get_app_send_uln_config.rs +51 -0
  157. package/contracts/message-libs/uln-302/src/tests/uln302/get_oapp_executor_config.rs +48 -0
  158. package/contracts/message-libs/uln-302/src/tests/uln302/mod.rs +4 -0
  159. package/contracts/message-libs/uln-302/src/tests/uln302/set_config.rs +998 -0
  160. package/contracts/message-libs/uln-302/src/uln302.rs +117 -0
  161. package/contracts/oapp-macros/Cargo.toml +21 -0
  162. package/contracts/oapp-macros/src/lib.rs +408 -0
  163. package/contracts/oapp-macros/src/oapp_core.rs +49 -0
  164. package/contracts/oapp-macros/src/oapp_full.rs +15 -0
  165. package/contracts/oapp-macros/src/oapp_options_type3.rs +46 -0
  166. package/contracts/oapp-macros/src/oapp_receiver.rs +67 -0
  167. package/contracts/oapp-macros/src/oapp_sender.rs +23 -0
  168. package/contracts/oapp-macros/src/util.rs +103 -0
  169. package/contracts/oapp-macros/tests/test_macros.rs +522 -0
  170. package/contracts/oapps/Cargo.toml +12 -0
  171. package/contracts/oapps/counter/Cargo.toml +24 -0
  172. package/contracts/oapps/counter/integration_tests/mod.rs +3 -0
  173. package/contracts/oapps/counter/integration_tests/setup.rs +201 -0
  174. package/contracts/oapps/counter/integration_tests/test_with_sml.rs +166 -0
  175. package/contracts/oapps/counter/integration_tests/utils.rs +144 -0
  176. package/contracts/oapps/counter/src/codec.rs +63 -0
  177. package/contracts/oapps/counter/src/counter.rs +235 -0
  178. package/contracts/oapps/counter/src/errors.rs +9 -0
  179. package/contracts/oapps/counter/src/lib.rs +16 -0
  180. package/contracts/oapps/counter/src/options.rs +30 -0
  181. package/contracts/oapps/counter/src/storage.rs +33 -0
  182. package/contracts/oapps/counter/src/tests/mod.rs +37 -0
  183. package/contracts/oapps/counter/src/tests/test_codec.rs +64 -0
  184. package/contracts/oapps/counter/src/tests/test_counter.rs +390 -0
  185. package/contracts/oapps/counter/src/u256_ext.rs +21 -0
  186. package/contracts/oapps/lib.rs +2 -0
  187. package/contracts/oapps/oapp/Cargo.toml +21 -0
  188. package/contracts/oapps/oapp/src/errors.rs +9 -0
  189. package/contracts/oapps/oapp/src/lib.rs +10 -0
  190. package/contracts/oapps/oapp/src/oapp_core.rs +92 -0
  191. package/contracts/oapps/oapp/src/oapp_options_type3.rs +89 -0
  192. package/contracts/oapps/oapp/src/oapp_receiver.rs +72 -0
  193. package/contracts/oapps/oapp/src/oapp_sender.rs +66 -0
  194. package/contracts/oapps/oapp/src/tests/mod.rs +4 -0
  195. package/contracts/oapps/oapp/src/tests/test_oapp_core.rs +162 -0
  196. package/contracts/oapps/oapp/src/tests/test_oapp_options_type3.rs +180 -0
  197. package/contracts/oapps/oapp/src/tests/test_oapp_receiver.rs +157 -0
  198. package/contracts/oapps/oapp/src/tests/test_oapp_sender.rs +283 -0
  199. package/contracts/utils/Cargo.toml +21 -0
  200. package/contracts/utils/src/buffer_reader.rs +143 -0
  201. package/contracts/utils/src/buffer_writer.rs +117 -0
  202. package/contracts/utils/src/bytes_ext.rs +19 -0
  203. package/contracts/utils/src/errors.rs +30 -0
  204. package/contracts/utils/src/lib.rs +15 -0
  205. package/contracts/utils/src/option_ext.rs +38 -0
  206. package/contracts/utils/src/ownable.rs +88 -0
  207. package/contracts/utils/src/testing_utils.rs +100 -0
  208. package/contracts/utils/src/tests/buffer_reader.rs +1006 -0
  209. package/contracts/utils/src/tests/buffer_writer.rs +330 -0
  210. package/contracts/utils/src/tests/bytes_ext.rs +77 -0
  211. package/contracts/utils/src/tests/mod.rs +4 -0
  212. package/contracts/utils/src/tests/ownable.rs +149 -0
  213. package/contracts/utils/src/ttl.rs +164 -0
  214. package/contracts/workers/Cargo.toml +13 -0
  215. package/contracts/workers/executor/Cargo.toml +26 -0
  216. package/contracts/workers/executor/src/events.rs +22 -0
  217. package/contracts/workers/executor/src/executor.rs +347 -0
  218. package/contracts/workers/executor/src/interfaces/executor.rs +40 -0
  219. package/contracts/workers/executor/src/interfaces/mod.rs +5 -0
  220. package/contracts/workers/executor/src/interfaces/types.rs +51 -0
  221. package/contracts/workers/executor/src/lib.rs +10 -0
  222. package/contracts/workers/executor/src/storage.rs +23 -0
  223. package/contracts/workers/lib.rs +2 -0
  224. package/contracts/workers/worker-common/Cargo.toml +18 -0
  225. package/contracts/workers/worker-common/src/constants.rs +17 -0
  226. package/contracts/workers/worker-common/src/errors.rs +6 -0
  227. package/contracts/workers/worker-common/src/events.rs +34 -0
  228. package/contracts/workers/worker-common/src/interfaces/executor_fee_lib.rs +35 -0
  229. package/contracts/workers/worker-common/src/interfaces/mod.rs +7 -0
  230. package/contracts/workers/worker-common/src/interfaces/price_feed.rs +40 -0
  231. package/contracts/workers/worker-common/src/interfaces/worker.rs +60 -0
  232. package/contracts/workers/worker-common/src/lib.rs +19 -0
  233. package/contracts/workers/worker-common/src/storage.rs +32 -0
  234. package/contracts/workers/worker-common/src/worker_common.rs +166 -0
  235. package/package.json +25 -0
  236. package/rust-toolchain.toml +4 -0
  237. package/rustfmt.toml +17 -0
  238. package/sdk/.turbo/turbo-build.log +4 -0
  239. package/sdk/dist/generated/bml.d.ts +452 -0
  240. package/sdk/dist/generated/bml.js +72 -0
  241. package/sdk/dist/generated/counter.d.ts +824 -0
  242. package/sdk/dist/generated/counter.js +125 -0
  243. package/sdk/dist/generated/endpoint.d.ts +1676 -0
  244. package/sdk/dist/generated/endpoint.js +216 -0
  245. package/sdk/dist/generated/sml.d.ts +810 -0
  246. package/sdk/dist/generated/sml.js +132 -0
  247. package/sdk/dist/generated/uln302.d.ts +1227 -0
  248. package/sdk/dist/generated/uln302.js +185 -0
  249. package/sdk/dist/index.d.ts +5 -0
  250. package/sdk/dist/index.js +5 -0
  251. package/sdk/node_modules/.bin/tsc +21 -0
  252. package/sdk/node_modules/.bin/tsserver +21 -0
  253. package/sdk/node_modules/.bin/vitest +21 -0
  254. package/sdk/node_modules/.bin/zx +21 -0
  255. package/sdk/package.json +40 -0
  256. package/sdk/src/index.ts +5 -0
  257. package/sdk/test/index.test.ts +271 -0
  258. package/sdk/test/suites/constants.ts +13 -0
  259. package/sdk/test/suites/deploy.ts +277 -0
  260. package/sdk/test/suites/localnet.ts +42 -0
  261. package/sdk/test/suites/scan.ts +189 -0
  262. package/sdk/tsconfig.json +106 -0
  263. package/tools/ts-bindings-gen/Cargo.toml +14 -0
  264. package/tools/ts-bindings-gen/src/main.rs +147 -0
  265. package/turbo.json +12 -0
@@ -0,0 +1,213 @@
1
+ use crate::{tests::endpoint_setup::setup, util::keccak256};
2
+ use soroban_sdk::{
3
+ testutils::{Address as _, MockAuth, MockAuthInvoke},
4
+ Address, Bytes, BytesN, IntoVal,
5
+ };
6
+
7
+ #[test]
8
+ fn test_compose_queue_none_initially() {
9
+ let context = setup();
10
+ let env = &context.env;
11
+ let endpoint_client = &context.endpoint_client;
12
+
13
+ let from = Address::generate(env);
14
+ let to = Address::generate(env);
15
+ let guid = BytesN::from_array(env, &[1u8; 32]);
16
+ let index = 0u32;
17
+
18
+ // Query compose queue before any message is sent
19
+ let result = endpoint_client.compose_queue(&from, &to, &guid, &index);
20
+ assert_eq!(result, None);
21
+ }
22
+
23
+ #[test]
24
+ fn test_compose_queue_after_send() {
25
+ let context = setup();
26
+ let env = &context.env;
27
+ let endpoint_client = &context.endpoint_client;
28
+
29
+ let from = Address::generate(env);
30
+ let to = Address::generate(env);
31
+ let guid = BytesN::from_array(env, &[1u8; 32]);
32
+ let index = 0u32;
33
+ let message = Bytes::from_array(env, &[1, 2, 3, 4, 5]);
34
+
35
+ // Send compose
36
+ env.mock_auths(&[MockAuth {
37
+ address: &from,
38
+ invoke: &MockAuthInvoke {
39
+ contract: &endpoint_client.address,
40
+ fn_name: "send_compose",
41
+ args: (&from, &to, &guid, &index, &message).into_val(env),
42
+ sub_invokes: &[],
43
+ },
44
+ }]);
45
+ endpoint_client.send_compose(&from, &to, &guid, &index, &message);
46
+
47
+ // Query compose queue
48
+ let expected_hash = keccak256(env, &message);
49
+ let result = endpoint_client.compose_queue(&from, &to, &guid, &index);
50
+ assert_eq!(result, Some(expected_hash));
51
+ }
52
+
53
+ #[test]
54
+ fn test_compose_queue_different_keys() {
55
+ let context = setup();
56
+ let env = &context.env;
57
+ let endpoint_client = &context.endpoint_client;
58
+
59
+ let from1 = Address::generate(env);
60
+ let from2 = Address::generate(env);
61
+ let to1 = Address::generate(env);
62
+ let to2 = Address::generate(env);
63
+ let guid1 = BytesN::from_array(env, &[1u8; 32]);
64
+ let guid2 = BytesN::from_array(env, &[2u8; 32]);
65
+ let message = Bytes::from_array(env, &[1, 2, 3]);
66
+
67
+ // Send compose with from1, to1, guid1, index 0
68
+ env.mock_auths(&[MockAuth {
69
+ address: &from1,
70
+ invoke: &MockAuthInvoke {
71
+ contract: &endpoint_client.address,
72
+ fn_name: "send_compose",
73
+ args: (&from1, &to1, &guid1, &0u32, &message).into_val(env),
74
+ sub_invokes: &[],
75
+ },
76
+ }]);
77
+ endpoint_client.send_compose(&from1, &to1, &guid1, &0, &message);
78
+
79
+ let expected_hash = keccak256(env, &message);
80
+
81
+ // Query with correct keys
82
+ assert_eq!(endpoint_client.compose_queue(&from1, &to1, &guid1, &0), Some(expected_hash.clone()));
83
+
84
+ // Query with different from
85
+ assert_eq!(endpoint_client.compose_queue(&from2, &to1, &guid1, &0), None);
86
+
87
+ // Query with different to
88
+ assert_eq!(endpoint_client.compose_queue(&from1, &to2, &guid1, &0), None);
89
+
90
+ // Query with different guid
91
+ assert_eq!(endpoint_client.compose_queue(&from1, &to1, &guid2, &0), None);
92
+
93
+ // Query with different index
94
+ assert_eq!(endpoint_client.compose_queue(&from1, &to1, &guid1, &1), None);
95
+ }
96
+
97
+ #[test]
98
+ fn test_compose_queue_after_clear() {
99
+ let context = setup();
100
+ let env = &context.env;
101
+ let endpoint_client = &context.endpoint_client;
102
+
103
+ let from = Address::generate(env);
104
+ let composer = Address::generate(env);
105
+ let guid = BytesN::from_array(env, &[1u8; 32]);
106
+ let index = 0u32;
107
+ let message = Bytes::from_array(env, &[1, 2, 3, 4, 5]);
108
+
109
+ // Send compose
110
+ env.mock_auths(&[MockAuth {
111
+ address: &from,
112
+ invoke: &MockAuthInvoke {
113
+ contract: &endpoint_client.address,
114
+ fn_name: "send_compose",
115
+ args: (&from, &composer, &guid, &index, &message).into_val(env),
116
+ sub_invokes: &[],
117
+ },
118
+ }]);
119
+ endpoint_client.send_compose(&from, &composer, &guid, &index, &message);
120
+
121
+ // Verify it exists
122
+ let message_hash = keccak256(env, &message);
123
+ assert_eq!(endpoint_client.compose_queue(&from, &composer, &guid, &index), Some(message_hash));
124
+
125
+ // Clear compose
126
+ env.mock_auths(&[MockAuth {
127
+ address: &composer,
128
+ invoke: &MockAuthInvoke {
129
+ contract: &endpoint_client.address,
130
+ fn_name: "clear_compose",
131
+ args: (&composer, &from, &guid, &index, &message).into_val(env),
132
+ sub_invokes: &[],
133
+ },
134
+ }]);
135
+ endpoint_client.clear_compose(&composer, &from, &guid, &index, &message);
136
+
137
+ // Query compose queue after clear - should be marked as received
138
+ const RECEIVED_MESSAGE_HASH_BYTES: [u8; 32] =
139
+ [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1];
140
+ let received_hash = BytesN::from_array(env, &RECEIVED_MESSAGE_HASH_BYTES);
141
+ let result = endpoint_client.compose_queue(&from, &composer, &guid, &index);
142
+ assert_eq!(result, Some(received_hash));
143
+ }
144
+
145
+ #[test]
146
+ fn test_compose_queue_multiple_indices() {
147
+ let context = setup();
148
+ let env = &context.env;
149
+ let endpoint_client = &context.endpoint_client;
150
+
151
+ let from = Address::generate(env);
152
+ let to = Address::generate(env);
153
+ let guid = BytesN::from_array(env, &[1u8; 32]);
154
+ let message1 = Bytes::from_array(env, &[1, 2, 3]);
155
+ let message2 = Bytes::from_array(env, &[4, 5, 6]);
156
+ let message3 = Bytes::from_array(env, &[7, 8, 9]);
157
+
158
+ // Send three compose messages with different indices
159
+ for (idx, msg) in [(0u32, &message1), (1u32, &message2), (2u32, &message3)] {
160
+ env.mock_auths(&[MockAuth {
161
+ address: &from,
162
+ invoke: &MockAuthInvoke {
163
+ contract: &endpoint_client.address,
164
+ fn_name: "send_compose",
165
+ args: (&from, &to, &guid, &idx, msg).into_val(env),
166
+ sub_invokes: &[],
167
+ },
168
+ }]);
169
+ endpoint_client.send_compose(&from, &to, &guid, &idx, msg);
170
+ }
171
+
172
+ // Query each index and verify correct hash
173
+ let hash1 = keccak256(env, &message1);
174
+ let hash2 = keccak256(env, &message2);
175
+ let hash3 = keccak256(env, &message3);
176
+
177
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid, &0), Some(hash1));
178
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid, &1), Some(hash2));
179
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid, &2), Some(hash3));
180
+
181
+ // Non-existent index should return None
182
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid, &3), None);
183
+ }
184
+
185
+ #[test]
186
+ fn test_compose_queue_empty_message() {
187
+ let context = setup();
188
+ let env = &context.env;
189
+ let endpoint_client = &context.endpoint_client;
190
+
191
+ let from = Address::generate(env);
192
+ let to = Address::generate(env);
193
+ let guid = BytesN::from_array(env, &[1u8; 32]);
194
+ let index = 0u32;
195
+ let message = Bytes::new(env);
196
+
197
+ // Send compose with empty message
198
+ env.mock_auths(&[MockAuth {
199
+ address: &from,
200
+ invoke: &MockAuthInvoke {
201
+ contract: &endpoint_client.address,
202
+ fn_name: "send_compose",
203
+ args: (&from, &to, &guid, &index, &message).into_val(env),
204
+ sub_invokes: &[],
205
+ },
206
+ }]);
207
+ endpoint_client.send_compose(&from, &to, &guid, &index, &message);
208
+
209
+ // Query compose queue with empty message
210
+ let expected_hash = keccak256(env, &message);
211
+ let result = endpoint_client.compose_queue(&from, &to, &guid, &index);
212
+ assert_eq!(result, Some(expected_hash));
213
+ }
@@ -0,0 +1,269 @@
1
+ use crate::{events::LzComposeAlert, tests::endpoint_setup::setup};
2
+ use soroban_sdk::{
3
+ testutils::{Address as _, MockAuth, MockAuthInvoke},
4
+ Address, Bytes, BytesN, IntoVal,
5
+ };
6
+ use utils::testing_utils::assert_event;
7
+
8
+ #[test]
9
+ fn test_lz_compose_alert_success() {
10
+ let context = setup();
11
+ let env = &context.env;
12
+ let endpoint_client = &context.endpoint_client;
13
+
14
+ let executor = Address::generate(env);
15
+ let from = Address::generate(env);
16
+ let to = Address::generate(env);
17
+ let guid = BytesN::from_array(env, &[1u8; 32]);
18
+ let index = 0u32;
19
+ let gas = 1000i128;
20
+ let value = 500i128;
21
+ let message = Bytes::from_array(env, &[1, 2, 3, 4, 5]);
22
+ let extra_data = Bytes::from_array(env, &[6, 7, 8]);
23
+ let reason = Bytes::from_array(env, &[9, 10]);
24
+
25
+ // Mock auth for executor
26
+ env.mock_auths(&[MockAuth {
27
+ address: &executor,
28
+ invoke: &MockAuthInvoke {
29
+ contract: &endpoint_client.address,
30
+ fn_name: "lz_compose_alert",
31
+ args: (&executor, &from, &to, &guid, &index, &gas, &value, &message, &extra_data, &reason).into_val(env),
32
+ sub_invokes: &[],
33
+ },
34
+ }]);
35
+
36
+ endpoint_client.lz_compose_alert(
37
+ &executor,
38
+ &from,
39
+ &to,
40
+ &guid,
41
+ &index,
42
+ &gas,
43
+ &value,
44
+ &message,
45
+ &extra_data,
46
+ &reason,
47
+ );
48
+
49
+ // Verify the event was published
50
+ assert_event(
51
+ env,
52
+ &endpoint_client.address,
53
+ LzComposeAlert {
54
+ from: from.clone(),
55
+ to: to.clone(),
56
+ executor: executor.clone(),
57
+ guid: guid.clone(),
58
+ index,
59
+ gas,
60
+ value,
61
+ message: message.clone(),
62
+ extra_data: extra_data.clone(),
63
+ reason: reason.clone(),
64
+ },
65
+ );
66
+ }
67
+
68
+ #[test]
69
+ fn test_lz_compose_alert_zero_values() {
70
+ let context = setup();
71
+ let env = &context.env;
72
+ let endpoint_client = &context.endpoint_client;
73
+
74
+ let executor = Address::generate(env);
75
+ let from = Address::generate(env);
76
+ let to = Address::generate(env);
77
+ let guid = BytesN::from_array(env, &[1u8; 32]);
78
+ let index = 0u32;
79
+ let gas = 0i128;
80
+ let value = 0i128;
81
+ let message = Bytes::new(env);
82
+ let extra_data = Bytes::new(env);
83
+ let reason = Bytes::new(env);
84
+
85
+ // Mock auth for executor
86
+ env.mock_auths(&[MockAuth {
87
+ address: &executor,
88
+ invoke: &MockAuthInvoke {
89
+ contract: &endpoint_client.address,
90
+ fn_name: "lz_compose_alert",
91
+ args: (&executor, &from, &to, &guid, &index, &gas, &value, &message, &extra_data, &reason).into_val(env),
92
+ sub_invokes: &[],
93
+ },
94
+ }]);
95
+
96
+ endpoint_client.lz_compose_alert(
97
+ &executor,
98
+ &from,
99
+ &to,
100
+ &guid,
101
+ &index,
102
+ &gas,
103
+ &value,
104
+ &message,
105
+ &extra_data,
106
+ &reason,
107
+ );
108
+
109
+ // Verify the event was published with zero values
110
+ assert_event(
111
+ env,
112
+ &endpoint_client.address,
113
+ LzComposeAlert {
114
+ from: from.clone(),
115
+ to: to.clone(),
116
+ executor: executor.clone(),
117
+ guid: guid.clone(),
118
+ index,
119
+ gas,
120
+ value,
121
+ message: message.clone(),
122
+ extra_data: extra_data.clone(),
123
+ reason: reason.clone(),
124
+ },
125
+ );
126
+ }
127
+
128
+ #[test]
129
+ fn test_lz_compose_alert_large_values() {
130
+ let context = setup();
131
+ let env = &context.env;
132
+ let endpoint_client = &context.endpoint_client;
133
+
134
+ let executor = Address::generate(env);
135
+ let from = Address::generate(env);
136
+ let to = Address::generate(env);
137
+ let guid = BytesN::from_array(env, &[255u8; 32]);
138
+ let index = u16::MAX as u32;
139
+ let gas = i128::MAX;
140
+ let value = i128::MAX;
141
+ let message = Bytes::from_array(env, &[255u8; 100]);
142
+ let extra_data = Bytes::from_array(env, &[128u8; 50]);
143
+ let reason = Bytes::from_array(env, &[64u8; 25]);
144
+
145
+ // Mock auth for executor
146
+ env.mock_auths(&[MockAuth {
147
+ address: &executor,
148
+ invoke: &MockAuthInvoke {
149
+ contract: &endpoint_client.address,
150
+ fn_name: "lz_compose_alert",
151
+ args: (&executor, &from, &to, &guid, &index, &gas, &value, &message, &extra_data, &reason).into_val(env),
152
+ sub_invokes: &[],
153
+ },
154
+ }]);
155
+
156
+ endpoint_client.lz_compose_alert(
157
+ &executor,
158
+ &from,
159
+ &to,
160
+ &guid,
161
+ &index,
162
+ &gas,
163
+ &value,
164
+ &message,
165
+ &extra_data,
166
+ &reason,
167
+ );
168
+
169
+ // Verify the event was published with large values
170
+ assert_event(
171
+ env,
172
+ &endpoint_client.address,
173
+ LzComposeAlert {
174
+ from: from.clone(),
175
+ to: to.clone(),
176
+ executor: executor.clone(),
177
+ guid: guid.clone(),
178
+ index,
179
+ gas,
180
+ value,
181
+ message: message.clone(),
182
+ extra_data: extra_data.clone(),
183
+ reason: reason.clone(),
184
+ },
185
+ );
186
+ }
187
+
188
+ #[test]
189
+ fn test_lz_compose_alert_multiple_alerts() {
190
+ let context = setup();
191
+ let env = &context.env;
192
+ let endpoint_client = &context.endpoint_client;
193
+
194
+ let executor = Address::generate(env);
195
+ let from = Address::generate(env);
196
+ let to = Address::generate(env);
197
+ let guid1 = BytesN::from_array(env, &[1u8; 32]);
198
+ let guid2 = BytesN::from_array(env, &[2u8; 32]);
199
+ let index = 0u32;
200
+ let gas = 1000i128;
201
+ let value = 500i128;
202
+ let message = Bytes::from_array(env, &[1, 2, 3]);
203
+ let extra_data = Bytes::from_array(env, &[4, 5]);
204
+ let reason = Bytes::from_array(env, &[6]);
205
+
206
+ // Send first alert
207
+ env.mock_auths(&[MockAuth {
208
+ address: &executor,
209
+ invoke: &MockAuthInvoke {
210
+ contract: &endpoint_client.address,
211
+ fn_name: "lz_compose_alert",
212
+ args: (&executor, &from, &to, &guid1, &index, &gas, &value, &message, &extra_data, &reason).into_val(env),
213
+ sub_invokes: &[],
214
+ },
215
+ }]);
216
+ endpoint_client.lz_compose_alert(
217
+ &executor,
218
+ &from,
219
+ &to,
220
+ &guid1,
221
+ &index,
222
+ &gas,
223
+ &value,
224
+ &message,
225
+ &extra_data,
226
+ &reason,
227
+ );
228
+
229
+ // Send second alert
230
+ env.mock_auths(&[MockAuth {
231
+ address: &executor,
232
+ invoke: &MockAuthInvoke {
233
+ contract: &endpoint_client.address,
234
+ fn_name: "lz_compose_alert",
235
+ args: (&executor, &from, &to, &guid2, &index, &gas, &value, &message, &extra_data, &reason).into_val(env),
236
+ sub_invokes: &[],
237
+ },
238
+ }]);
239
+ endpoint_client.lz_compose_alert(
240
+ &executor,
241
+ &from,
242
+ &to,
243
+ &guid2,
244
+ &index,
245
+ &gas,
246
+ &value,
247
+ &message,
248
+ &extra_data,
249
+ &reason,
250
+ );
251
+
252
+ // Both alerts should succeed - verify at least one event was published
253
+ assert_event(
254
+ env,
255
+ &endpoint_client.address,
256
+ LzComposeAlert {
257
+ from: from.clone(),
258
+ to: to.clone(),
259
+ executor: executor.clone(),
260
+ guid: guid2.clone(),
261
+ index,
262
+ gas,
263
+ value,
264
+ message: message.clone(),
265
+ extra_data: extra_data.clone(),
266
+ reason: reason.clone(),
267
+ },
268
+ );
269
+ }
@@ -0,0 +1,4 @@
1
+ mod clear_compose;
2
+ mod compose_queue;
3
+ mod lz_compose_alert;
4
+ mod send_compose;
@@ -0,0 +1,173 @@
1
+ use crate::{events::ComposeSent, storage, tests::endpoint_setup::setup, util::keccak256};
2
+ use soroban_sdk::{
3
+ testutils::{Address as _, MockAuth, MockAuthInvoke},
4
+ Address, Bytes, BytesN, IntoVal,
5
+ };
6
+ use utils::testing_utils::assert_event;
7
+
8
+ #[test]
9
+ fn test_send_compose_success() {
10
+ let context = setup();
11
+ let env = &context.env;
12
+ let endpoint_client = &context.endpoint_client;
13
+
14
+ let from = Address::generate(env);
15
+ let to = Address::generate(env);
16
+ let guid = BytesN::from_array(env, &[1u8; 32]);
17
+ let index = 1u32;
18
+ let message = Bytes::from_array(env, &[1, 2, 3, 4, 5]);
19
+
20
+ // Verify initial state - compose queue should not exist
21
+ let initial_queue = env.as_contract(&endpoint_client.address, || {
22
+ storage::EndpointStorage::compose_queue(env, &from, &to, &guid, index)
23
+ });
24
+ assert_eq!(initial_queue, None, "Initial compose queue should be None");
25
+
26
+ // Mock auth for 'from' address
27
+ env.mock_auths(&[MockAuth {
28
+ address: &from,
29
+ invoke: &MockAuthInvoke {
30
+ contract: &endpoint_client.address,
31
+ fn_name: "send_compose",
32
+ args: (&from, &to, &guid, &index, &message).into_val(env),
33
+ sub_invokes: &[],
34
+ },
35
+ }]);
36
+
37
+ endpoint_client.send_compose(&from, &to, &guid, &index, &message);
38
+
39
+ // Verify the event was published
40
+ assert_event(
41
+ env,
42
+ &endpoint_client.address,
43
+ ComposeSent { from: from.clone(), to: to.clone(), guid: guid.clone(), index, message: message.clone() },
44
+ );
45
+
46
+ // Verify the compose queue was set via public interface
47
+ let message_hash = keccak256(env, &message);
48
+ let stored_hash = endpoint_client.compose_queue(&from, &to, &guid, &index);
49
+ assert_eq!(stored_hash, Some(message_hash.clone()));
50
+
51
+ // Assert storage change directly
52
+ let stored_hash_direct = env.as_contract(&endpoint_client.address, || {
53
+ storage::EndpointStorage::compose_queue(env, &from, &to, &guid, index)
54
+ });
55
+ assert_eq!(stored_hash_direct, Some(message_hash), "Storage should contain the message hash in compose queue");
56
+ }
57
+
58
+ #[test]
59
+ fn test_send_compose_different_indices() {
60
+ let context = setup();
61
+ let env = &context.env;
62
+ let endpoint_client = &context.endpoint_client;
63
+
64
+ let from = Address::generate(env);
65
+ let to = Address::generate(env);
66
+ let guid = BytesN::from_array(env, &[1u8; 32]);
67
+ let message1 = Bytes::from_array(env, &[1, 2, 3]);
68
+ let message2 = Bytes::from_array(env, &[4, 5, 6]);
69
+
70
+ // Send compose with index 0
71
+ env.mock_auths(&[MockAuth {
72
+ address: &from,
73
+ invoke: &MockAuthInvoke {
74
+ contract: &endpoint_client.address,
75
+ fn_name: "send_compose",
76
+ args: (&from, &to, &guid, &0u32, &message1).into_val(env),
77
+ sub_invokes: &[],
78
+ },
79
+ }]);
80
+ endpoint_client.send_compose(&from, &to, &guid, &0, &message1);
81
+
82
+ // Send compose with index 1
83
+ env.mock_auths(&[MockAuth {
84
+ address: &from,
85
+ invoke: &MockAuthInvoke {
86
+ contract: &endpoint_client.address,
87
+ fn_name: "send_compose",
88
+ args: (&from, &to, &guid, &1u32, &message2).into_val(env),
89
+ sub_invokes: &[],
90
+ },
91
+ }]);
92
+ endpoint_client.send_compose(&from, &to, &guid, &1, &message2);
93
+
94
+ // Verify both compose queues exist
95
+ let hash1 = keccak256(env, &message1);
96
+ let hash2 = keccak256(env, &message2);
97
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid, &0), Some(hash1));
98
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid, &1), Some(hash2));
99
+ }
100
+
101
+ #[test]
102
+ fn test_send_compose_different_guids() {
103
+ let context = setup();
104
+ let env = &context.env;
105
+ let endpoint_client = &context.endpoint_client;
106
+
107
+ let from = Address::generate(env);
108
+ let to = Address::generate(env);
109
+ let guid1 = BytesN::from_array(env, &[1u8; 32]);
110
+ let guid2 = BytesN::from_array(env, &[2u8; 32]);
111
+ let index = 0u32;
112
+ let message = Bytes::from_array(env, &[1, 2, 3]);
113
+
114
+ // Send compose with guid1
115
+ env.mock_auths(&[MockAuth {
116
+ address: &from,
117
+ invoke: &MockAuthInvoke {
118
+ contract: &endpoint_client.address,
119
+ fn_name: "send_compose",
120
+ args: (&from, &to, &guid1, &index, &message).into_val(env),
121
+ sub_invokes: &[],
122
+ },
123
+ }]);
124
+ endpoint_client.send_compose(&from, &to, &guid1, &index, &message);
125
+
126
+ // Send compose with guid2
127
+ env.mock_auths(&[MockAuth {
128
+ address: &from,
129
+ invoke: &MockAuthInvoke {
130
+ contract: &endpoint_client.address,
131
+ fn_name: "send_compose",
132
+ args: (&from, &to, &guid2, &index, &message).into_val(env),
133
+ sub_invokes: &[],
134
+ },
135
+ }]);
136
+ endpoint_client.send_compose(&from, &to, &guid2, &index, &message);
137
+
138
+ // Verify both compose queues exist
139
+ let message_hash = keccak256(env, &message);
140
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid1, &index), Some(message_hash.clone()));
141
+ assert_eq!(endpoint_client.compose_queue(&from, &to, &guid2, &index), Some(message_hash));
142
+ }
143
+
144
+ #[test]
145
+ fn test_send_compose_empty_message() {
146
+ let context = setup();
147
+ let env = &context.env;
148
+ let endpoint_client = &context.endpoint_client;
149
+
150
+ let from = Address::generate(env);
151
+ let to = Address::generate(env);
152
+ let guid = BytesN::from_array(env, &[1u8; 32]);
153
+ let index = 0u32;
154
+ let message = Bytes::new(env);
155
+
156
+ // Mock auth for 'from' address
157
+ env.mock_auths(&[MockAuth {
158
+ address: &from,
159
+ invoke: &MockAuthInvoke {
160
+ contract: &endpoint_client.address,
161
+ fn_name: "send_compose",
162
+ args: (&from, &to, &guid, &index, &message).into_val(env),
163
+ sub_invokes: &[],
164
+ },
165
+ }]);
166
+
167
+ endpoint_client.send_compose(&from, &to, &guid, &index, &message);
168
+
169
+ // Verify the compose queue was set with empty message hash
170
+ let message_hash = keccak256(env, &message);
171
+ let stored_hash = endpoint_client.compose_queue(&from, &to, &guid, &index);
172
+ assert_eq!(stored_hash, Some(message_hash));
173
+ }