@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,586 @@
1
+ use endpoint_v2::OutboundPacket;
2
+ use message_lib_common::{errors::WorkerOptionsError, testing_utils::create_type3_options};
3
+ use soroban_sdk::{
4
+ log,
5
+ testutils::{Address as _, MockAuth, MockAuthInvoke},
6
+ vec, Address, Bytes, BytesN, Env, IntoVal, Vec,
7
+ };
8
+
9
+ use crate::{
10
+ errors::Uln302Error,
11
+ interfaces::{ExecutorConfig, UlnConfig},
12
+ tests::setup::{
13
+ setup, CONFIRMATIONS, DVN_FEE, EXECUTOR_FEE, LOCAL_EID as EID, MAX_MESSAGE_SIZE, REMOTE_EID as DST_EID,
14
+ TREASURY_NATIVE_FEE, TREASURY_ZRO_FEE,
15
+ },
16
+ };
17
+
18
+ #[test]
19
+ fn test_quote_single_dvn() {
20
+ let mut setup = setup();
21
+ let oapp = Address::generate(&setup.env);
22
+
23
+ // setup workers
24
+ let mut dvns = Vec::new(&setup.env);
25
+ DVN_FEE.iter().for_each(|fee| {
26
+ let dvn = setup.register_dvn(*fee);
27
+ dvns.push_back(dvn);
28
+ });
29
+ let executor = setup.register_executor(EXECUTOR_FEE);
30
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
31
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
32
+
33
+ // setup configs
34
+ setup.set_default_send_uln_config(
35
+ DST_EID,
36
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env, dvns.get_unchecked(0)], &vec![&setup.env], 0),
37
+ );
38
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
39
+
40
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
41
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
42
+
43
+ // quote
44
+ let packet = OutboundPacket {
45
+ nonce: 1,
46
+ src_eid: EID,
47
+ sender: oapp,
48
+ dst_eid: DST_EID,
49
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
50
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
51
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
52
+ };
53
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0)], true);
54
+ let pay_in_zro = false;
55
+
56
+ setup.env.mock_auths(&[MockAuth {
57
+ address: &setup.endpoint.address,
58
+ invoke: &MockAuthInvoke {
59
+ contract: &setup.uln302.address,
60
+ fn_name: "quote",
61
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
62
+ sub_invokes: &[],
63
+ },
64
+ }]);
65
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
66
+ assert_eq!(fee.native_fee, EXECUTOR_FEE + DVN_FEE[0] + TREASURY_NATIVE_FEE);
67
+ assert_eq!(fee.zro_fee, 0);
68
+ }
69
+
70
+ #[test]
71
+ fn test_quote_with_zro_fee() {
72
+ let mut setup = setup();
73
+ let oapp = Address::generate(&setup.env);
74
+
75
+ // setup workers
76
+ let mut dvns = Vec::new(&setup.env);
77
+ DVN_FEE.iter().for_each(|fee| {
78
+ let dvn = setup.register_dvn(*fee);
79
+ dvns.push_back(dvn);
80
+ });
81
+ let executor = setup.register_executor(EXECUTOR_FEE);
82
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
83
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
84
+
85
+ // setup configs
86
+ setup.set_default_send_uln_config(
87
+ DST_EID,
88
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env, dvns.get_unchecked(0)], &vec![&setup.env], 0),
89
+ );
90
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
91
+
92
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
93
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
94
+
95
+ // quote
96
+ let packet = OutboundPacket {
97
+ nonce: 1,
98
+ src_eid: EID,
99
+ sender: oapp,
100
+ dst_eid: DST_EID,
101
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
102
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
103
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
104
+ };
105
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0)], true);
106
+ let pay_in_zro = true;
107
+
108
+ setup.env.mock_auths(&[MockAuth {
109
+ address: &setup.endpoint.address,
110
+ invoke: &MockAuthInvoke {
111
+ contract: &setup.uln302.address,
112
+ fn_name: "quote",
113
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
114
+ sub_invokes: &[],
115
+ },
116
+ }]);
117
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
118
+ assert_eq!(fee.native_fee, EXECUTOR_FEE + DVN_FEE[0]);
119
+ assert_eq!(fee.zro_fee, TREASURY_ZRO_FEE);
120
+ }
121
+
122
+ #[test]
123
+ fn test_quote_multiple_dvns() {
124
+ let mut setup = setup();
125
+ let oapp = Address::generate(&setup.env);
126
+
127
+ // setup workers
128
+ let mut dvns = Vec::new(&setup.env);
129
+ DVN_FEE.iter().for_each(|fee| {
130
+ let dvn = setup.register_dvn(*fee);
131
+ dvns.push_back(dvn);
132
+ });
133
+ let executor = setup.register_executor(EXECUTOR_FEE);
134
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
135
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
136
+
137
+ // setup configs
138
+ setup.set_default_send_uln_config(
139
+ DST_EID,
140
+ UlnConfig::new(
141
+ CONFIRMATIONS,
142
+ &vec![&setup.env, dvns.get_unchecked(0), dvns.get_unchecked(1)],
143
+ &vec![&setup.env],
144
+ 0,
145
+ ),
146
+ );
147
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
148
+
149
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
150
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
151
+
152
+ // quote
153
+ let packet = OutboundPacket {
154
+ nonce: 1,
155
+ src_eid: EID,
156
+ sender: oapp,
157
+ dst_eid: DST_EID,
158
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
159
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
160
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
161
+ };
162
+ let options =
163
+ create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0), dvns.get_unchecked(1)], true);
164
+ let pay_in_zro = false;
165
+
166
+ setup.env.mock_auths(&[MockAuth {
167
+ address: &setup.endpoint.address,
168
+ invoke: &MockAuthInvoke {
169
+ contract: &setup.uln302.address,
170
+ fn_name: "quote",
171
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
172
+ sub_invokes: &[],
173
+ },
174
+ }]);
175
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
176
+ assert_eq!(fee.native_fee, EXECUTOR_FEE + DVN_FEE[0] + DVN_FEE[1] + TREASURY_NATIVE_FEE);
177
+ assert_eq!(fee.zro_fee, 0);
178
+ }
179
+
180
+ #[test]
181
+ fn test_quote_with_only_optional_dvns() {
182
+ let mut setup = setup();
183
+ let oapp = Address::generate(&setup.env);
184
+
185
+ // setup workers
186
+ let mut dvns = Vec::new(&setup.env);
187
+ DVN_FEE.iter().for_each(|fee| {
188
+ let dvn = setup.register_dvn(*fee);
189
+ dvns.push_back(dvn);
190
+ });
191
+ let executor = setup.register_executor(EXECUTOR_FEE);
192
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
193
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
194
+
195
+ // setup configs
196
+ setup.set_default_send_uln_config(
197
+ DST_EID,
198
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env], &vec![&setup.env, dvns.get_unchecked(0)], 1),
199
+ );
200
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
201
+
202
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
203
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
204
+
205
+ // quote
206
+ let packet = OutboundPacket {
207
+ nonce: 1,
208
+ src_eid: EID,
209
+ sender: oapp,
210
+ dst_eid: DST_EID,
211
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
212
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
213
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
214
+ };
215
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0)], true);
216
+ let pay_in_zro = false;
217
+
218
+ setup.env.mock_auths(&[MockAuth {
219
+ address: &setup.endpoint.address,
220
+ invoke: &MockAuthInvoke {
221
+ contract: &setup.uln302.address,
222
+ fn_name: "quote",
223
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
224
+ sub_invokes: &[],
225
+ },
226
+ }]);
227
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
228
+ assert_eq!(fee.native_fee, EXECUTOR_FEE + DVN_FEE[0] + TREASURY_NATIVE_FEE);
229
+ assert_eq!(fee.zro_fee, 0);
230
+ }
231
+
232
+ #[test]
233
+ fn test_quote_with_bad_options() {
234
+ let mut setup = setup();
235
+ let oapp = Address::generate(&setup.env);
236
+
237
+ // setup workers
238
+ let mut dvns = Vec::new(&setup.env);
239
+ DVN_FEE.iter().for_each(|fee| {
240
+ let dvn = setup.register_dvn(*fee);
241
+ dvns.push_back(dvn);
242
+ });
243
+ let executor = setup.register_executor(EXECUTOR_FEE);
244
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
245
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
246
+
247
+ // setup configs
248
+ setup.set_default_send_uln_config(
249
+ DST_EID,
250
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env], &vec![&setup.env, dvns.get_unchecked(0)], 1),
251
+ );
252
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
253
+
254
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
255
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
256
+
257
+ // quote
258
+ let packet = OutboundPacket {
259
+ nonce: 1,
260
+ src_eid: EID,
261
+ sender: oapp,
262
+ dst_eid: DST_EID,
263
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
264
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
265
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
266
+ };
267
+ let options = Bytes::from_array(&setup.env, b"ensure bad options can be captured");
268
+ let pay_in_zro = false;
269
+
270
+ setup.env.mock_auths(&[MockAuth {
271
+ address: &setup.endpoint.address,
272
+ invoke: &MockAuthInvoke {
273
+ contract: &setup.uln302.address,
274
+ fn_name: "quote",
275
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
276
+ sub_invokes: &[],
277
+ },
278
+ }]);
279
+ let result = setup.uln302.try_quote(&packet, &options, &pay_in_zro);
280
+ assert_eq!(result.err().unwrap().ok().unwrap(), WorkerOptionsError::InvalidOptionType.into());
281
+ }
282
+
283
+ #[test]
284
+ fn test_quote_exceeding_message_size() {
285
+ let mut setup = setup();
286
+ let oapp = Address::generate(&setup.env);
287
+
288
+ // setup workers
289
+ let mut dvns = Vec::new(&setup.env);
290
+ DVN_FEE.iter().for_each(|fee| {
291
+ let dvn = setup.register_dvn(*fee);
292
+ dvns.push_back(dvn);
293
+ });
294
+ let executor = setup.register_executor(EXECUTOR_FEE);
295
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
296
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
297
+
298
+ // setup configs
299
+ setup.set_default_send_uln_config(
300
+ DST_EID,
301
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env], &vec![&setup.env, dvns.get_unchecked(0)], 1),
302
+ );
303
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(2, &executor));
304
+
305
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
306
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
307
+
308
+ // quote
309
+ let packet = OutboundPacket {
310
+ nonce: 1,
311
+ src_eid: EID,
312
+ sender: oapp,
313
+ dst_eid: DST_EID,
314
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
315
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
316
+ // message length bigger than max_message_size=2
317
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
318
+ };
319
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0)], true);
320
+ let pay_in_zro = false;
321
+
322
+ setup.env.mock_auths(&[MockAuth {
323
+ address: &setup.endpoint.address,
324
+ invoke: &MockAuthInvoke {
325
+ contract: &setup.uln302.address,
326
+ fn_name: "quote",
327
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
328
+ sub_invokes: &[],
329
+ },
330
+ }]);
331
+ let result = setup.uln302.try_quote(&packet, &options, &pay_in_zro);
332
+ assert_eq!(result.err().unwrap().ok().unwrap(), Uln302Error::InvalidMessageSize.into());
333
+ }
334
+
335
+ #[test]
336
+ fn test_quote_with_missing_dvn_options() {
337
+ let mut setup = setup();
338
+ let oapp = Address::generate(&setup.env);
339
+
340
+ // setup workers
341
+ let mut dvns = Vec::new(&setup.env);
342
+ DVN_FEE.iter().for_each(|fee| {
343
+ let dvn = setup.register_dvn(*fee);
344
+ dvns.push_back(dvn);
345
+ });
346
+ let executor = setup.register_executor(EXECUTOR_FEE);
347
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
348
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
349
+
350
+ // setup configs
351
+ setup.set_default_send_uln_config(
352
+ DST_EID,
353
+ UlnConfig::new(
354
+ CONFIRMATIONS,
355
+ &vec![&setup.env, dvns.get_unchecked(0)],
356
+ &vec![&setup.env, dvns.get_unchecked(1)],
357
+ 1,
358
+ ),
359
+ );
360
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
361
+
362
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
363
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
364
+
365
+ // quote
366
+ let packet = OutboundPacket {
367
+ nonce: 1,
368
+ src_eid: EID,
369
+ sender: oapp,
370
+ dst_eid: DST_EID,
371
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
372
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
373
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
374
+ };
375
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0)], true); // only provide dvn option for index 0
376
+ let pay_in_zro = false;
377
+
378
+ setup.env.mock_auths(&[MockAuth {
379
+ address: &setup.endpoint.address,
380
+ invoke: &MockAuthInvoke {
381
+ contract: &setup.uln302.address,
382
+ fn_name: "quote",
383
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
384
+ sub_invokes: &[],
385
+ },
386
+ }]);
387
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
388
+ assert_eq!(fee.native_fee, EXECUTOR_FEE + DVN_FEE[0] + DVN_FEE[1] + TREASURY_NATIVE_FEE);
389
+ assert_eq!(fee.zro_fee, 0);
390
+ }
391
+
392
+ #[test]
393
+ fn test_quote_with_missing_executor_options() {
394
+ let mut setup = setup();
395
+ let oapp = Address::generate(&setup.env);
396
+
397
+ // setup workers
398
+ let mut dvns = Vec::new(&setup.env);
399
+ DVN_FEE.iter().for_each(|fee| {
400
+ let dvn = setup.register_dvn(*fee);
401
+ dvns.push_back(dvn);
402
+ });
403
+ let executor = setup.register_executor(EXECUTOR_FEE);
404
+ setup.treasury.set_native_fee(&TREASURY_NATIVE_FEE);
405
+ setup.treasury.set_zro_fee(&TREASURY_ZRO_FEE);
406
+
407
+ // setup configs
408
+ setup.set_default_send_uln_config(
409
+ DST_EID,
410
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env, dvns.get_unchecked(0)], &vec![&setup.env], 0),
411
+ );
412
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
413
+
414
+ let effective_send_uln_config = setup.uln302.effective_send_uln_config(&oapp, &DST_EID);
415
+ log!(&setup.env, "effective_send_uln_config: {:?}", effective_send_uln_config);
416
+
417
+ // quote
418
+ let packet = OutboundPacket {
419
+ nonce: 1,
420
+ src_eid: EID,
421
+ sender: oapp,
422
+ dst_eid: DST_EID,
423
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
424
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
425
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
426
+ };
427
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvns.get_unchecked(0)], false); // only provide executor option
428
+ let pay_in_zro = false;
429
+ setup.env.mock_auths(&[MockAuth {
430
+ address: &setup.endpoint.address,
431
+ invoke: &MockAuthInvoke {
432
+ contract: &setup.uln302.address,
433
+ fn_name: "quote",
434
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
435
+ sub_invokes: &[],
436
+ },
437
+ }]);
438
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
439
+ assert_eq!(fee.native_fee, EXECUTOR_FEE + DVN_FEE[0] + TREASURY_NATIVE_FEE);
440
+ assert_eq!(fee.zro_fee, 0);
441
+ }
442
+
443
+ #[test]
444
+ fn test_quote_edge_case_executor_only_charges() {
445
+ // Sui equivalent: test_edge_case_fee_scenarios - Scenario 1
446
+ // Tests fee distribution when only executor charges, DVNs are free
447
+ let mut setup = setup();
448
+ let oapp = Address::generate(&setup.env);
449
+
450
+ // setup workers - DVN with 0 fee, executor with fee
451
+ let dvn = setup.register_dvn(0i128); // DVN charges 0
452
+ let executor = setup.register_executor(500i128); // Only executor charges
453
+ setup.treasury.set_native_fee(&0i128); // No treasury fee for simplicity
454
+ setup.treasury.set_zro_fee(&0i128);
455
+
456
+ // setup configs
457
+ setup.set_default_send_uln_config(
458
+ DST_EID,
459
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env, dvn.clone()], &vec![&setup.env], 0),
460
+ );
461
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
462
+
463
+ // quote
464
+ let packet = OutboundPacket {
465
+ nonce: 1,
466
+ src_eid: EID,
467
+ sender: oapp,
468
+ dst_eid: DST_EID,
469
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
470
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
471
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
472
+ };
473
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvn], true);
474
+ let pay_in_zro = false;
475
+
476
+ setup.env.mock_auths(&[MockAuth {
477
+ address: &setup.endpoint.address,
478
+ invoke: &MockAuthInvoke {
479
+ contract: &setup.uln302.address,
480
+ fn_name: "quote",
481
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
482
+ sub_invokes: &[],
483
+ },
484
+ }]);
485
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
486
+ // Only executor fee (500) + 0 DVN + 0 treasury
487
+ assert_eq!(fee.native_fee, 500);
488
+ assert_eq!(fee.zro_fee, 0);
489
+ }
490
+
491
+ #[test]
492
+ fn test_quote_edge_case_everything_free() {
493
+ // Sui equivalent: test_edge_case_fee_scenarios - Scenario 2
494
+ // Tests fee distribution when everything is free
495
+ let mut setup = setup();
496
+ let oapp = Address::generate(&setup.env);
497
+
498
+ // setup workers - all 0 fees
499
+ let dvn = setup.register_dvn(0i128); // DVN charges 0
500
+ let executor = setup.register_executor(0i128); // Executor charges 0
501
+ setup.treasury.set_native_fee(&0i128); // No treasury fee
502
+ setup.treasury.set_zro_fee(&0i128);
503
+
504
+ // setup configs
505
+ setup.set_default_send_uln_config(
506
+ DST_EID,
507
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env, dvn.clone()], &vec![&setup.env], 0),
508
+ );
509
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
510
+
511
+ // quote
512
+ let packet = OutboundPacket {
513
+ nonce: 1,
514
+ src_eid: EID,
515
+ sender: oapp,
516
+ dst_eid: DST_EID,
517
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
518
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
519
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
520
+ };
521
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvn], true);
522
+ let pay_in_zro = false;
523
+
524
+ setup.env.mock_auths(&[MockAuth {
525
+ address: &setup.endpoint.address,
526
+ invoke: &MockAuthInvoke {
527
+ contract: &setup.uln302.address,
528
+ fn_name: "quote",
529
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
530
+ sub_invokes: &[],
531
+ },
532
+ }]);
533
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
534
+ // All fees are 0
535
+ assert_eq!(fee.native_fee, 0);
536
+ assert_eq!(fee.zro_fee, 0);
537
+ }
538
+
539
+ #[test]
540
+ fn test_quote_edge_case_zero_dvn_fees_multiple_dvns() {
541
+ // Sui equivalent: test_edge_case_fee_scenarios
542
+ // Tests fee distribution with multiple DVNs all charging 0
543
+ let mut setup = setup();
544
+ let oapp = Address::generate(&setup.env);
545
+
546
+ // setup workers - DVNs with 0 fee
547
+ let dvn1 = setup.register_dvn(0i128);
548
+ let dvn2 = setup.register_dvn(0i128);
549
+ let executor = setup.register_executor(100i128);
550
+ setup.treasury.set_native_fee(&10i128);
551
+ setup.treasury.set_zro_fee(&0i128);
552
+
553
+ // setup configs
554
+ setup.set_default_send_uln_config(
555
+ DST_EID,
556
+ UlnConfig::new(CONFIRMATIONS, &vec![&setup.env, dvn1.clone(), dvn2.clone()], &vec![&setup.env], 0),
557
+ );
558
+ setup.set_default_executor_config(DST_EID, ExecutorConfig::new(MAX_MESSAGE_SIZE, &executor));
559
+
560
+ // quote
561
+ let packet = OutboundPacket {
562
+ nonce: 1,
563
+ src_eid: EID,
564
+ sender: oapp,
565
+ dst_eid: DST_EID,
566
+ receiver: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
567
+ guid: BytesN::<32>::from_array(&setup.env, &[0u8; 32]),
568
+ message: Bytes::from_array(&setup.env, b"dummy testing message"),
569
+ };
570
+ let options = create_type3_options(&setup.env, &vec![&setup.env, dvn1, dvn2], true);
571
+ let pay_in_zro = false;
572
+
573
+ setup.env.mock_auths(&[MockAuth {
574
+ address: &setup.endpoint.address,
575
+ invoke: &MockAuthInvoke {
576
+ contract: &setup.uln302.address,
577
+ fn_name: "quote",
578
+ args: (&packet, &options, &pay_in_zro).into_val(&setup.env),
579
+ sub_invokes: &[],
580
+ },
581
+ }]);
582
+ let fee = setup.uln302.quote(&packet, &options, &pay_in_zro);
583
+ // executor (100) + 0 DVNs + treasury (10)
584
+ assert_eq!(fee.native_fee, 110);
585
+ assert_eq!(fee.zro_fee, 0);
586
+ }