@ledgerhq/coin-aptos 1.10.0-nightly.0 → 1.10.0-nightly.2

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 (459) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/.unimportedrc.json +18 -6
  3. package/CHANGELOG.md +40 -9
  4. package/jest.config.js +1 -1
  5. package/jest.integ.config.js +8 -0
  6. package/lib/__tests__/api/craftTransaction.unit.test.d.ts +2 -0
  7. package/lib/__tests__/api/craftTransaction.unit.test.d.ts.map +1 -0
  8. package/lib/__tests__/api/craftTransaction.unit.test.js +50 -0
  9. package/lib/__tests__/api/craftTransaction.unit.test.js.map +1 -0
  10. package/lib/__tests__/api/getBalance.unit.test.d.ts +2 -0
  11. package/lib/__tests__/api/getBalance.unit.test.d.ts.map +1 -0
  12. package/lib/__tests__/api/getBalance.unit.test.js +41 -0
  13. package/lib/__tests__/api/getBalance.unit.test.js.map +1 -0
  14. package/lib/__tests__/api/index.integ.test.d.ts +2 -0
  15. package/lib/__tests__/api/index.integ.test.d.ts.map +1 -0
  16. package/lib/__tests__/api/index.integ.test.js +115 -0
  17. package/lib/__tests__/api/index.integ.test.js.map +1 -0
  18. package/lib/__tests__/api/index.test.js +48 -460
  19. package/lib/__tests__/api/index.test.js.map +1 -1
  20. package/lib/__tests__/bridge/broadcast.test.js +5 -5
  21. package/lib/__tests__/bridge/broadcast.test.js.map +1 -1
  22. package/lib/__tests__/bridge/getFeesForTransaction.test.js +9 -9
  23. package/lib/__tests__/bridge/getFeesForTransaction.test.js.map +1 -1
  24. package/lib/__tests__/bridge/logic.test.js +3 -553
  25. package/lib/__tests__/bridge/logic.test.js.map +1 -1
  26. package/lib/__tests__/bridge/prepareTransaction.test.js +3 -3
  27. package/lib/__tests__/bridge/prepareTransaction.test.js.map +1 -1
  28. package/lib/__tests__/bridge/signOperation.test.js +9 -12
  29. package/lib/__tests__/bridge/signOperation.test.js.map +1 -1
  30. package/lib/__tests__/bridge/synchronisation.test.js +6 -6
  31. package/lib/__tests__/bridge/synchronisation.test.js.map +1 -1
  32. package/lib/__tests__/index.test.js +1 -1
  33. package/lib/__tests__/index.test.js.map +1 -1
  34. package/lib/__tests__/logic/buildTransaction.test.d.ts.map +1 -0
  35. package/lib/__tests__/{bridge → logic}/buildTransaction.test.js +16 -12
  36. package/lib/__tests__/logic/buildTransaction.test.js.map +1 -0
  37. package/lib/__tests__/logic/calculateAmount.unit.test.d.ts +2 -0
  38. package/lib/__tests__/logic/calculateAmount.unit.test.d.ts.map +1 -0
  39. package/lib/__tests__/logic/calculateAmount.unit.test.js +45 -0
  40. package/lib/__tests__/logic/calculateAmount.unit.test.js.map +1 -0
  41. package/lib/__tests__/logic/combine.unit.test.d.ts +2 -0
  42. package/lib/__tests__/logic/combine.unit.test.d.ts.map +1 -0
  43. package/lib/__tests__/logic/combine.unit.test.js +47 -0
  44. package/lib/__tests__/logic/combine.unit.test.js.map +1 -0
  45. package/lib/__tests__/logic/compareAddress.unit.test.d.ts +2 -0
  46. package/lib/__tests__/logic/compareAddress.unit.test.d.ts.map +1 -0
  47. package/lib/__tests__/logic/compareAddress.unit.test.js +26 -0
  48. package/lib/__tests__/logic/compareAddress.unit.test.js.map +1 -0
  49. package/lib/__tests__/logic/createTransaction.test.d.ts.map +1 -0
  50. package/lib/__tests__/{bridge → logic}/createTransaction.test.js +2 -2
  51. package/lib/__tests__/logic/createTransaction.test.js.map +1 -0
  52. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.d.ts +2 -0
  53. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.d.ts.map +1 -0
  54. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.js +186 -0
  55. package/lib/__tests__/logic/getCoinAndAmounts.unit.test.js.map +1 -0
  56. package/lib/__tests__/logic/getFunctionAddress.unit.test.d.ts +2 -0
  57. package/lib/__tests__/logic/getFunctionAddress.unit.test.d.ts.map +1 -0
  58. package/lib/__tests__/logic/getFunctionAddress.unit.test.js +29 -0
  59. package/lib/__tests__/logic/getFunctionAddress.unit.test.js.map +1 -0
  60. package/lib/__tests__/logic/getResourceAddress.unit.test.d.ts +2 -0
  61. package/lib/__tests__/logic/getResourceAddress.unit.test.d.ts.map +1 -0
  62. package/lib/__tests__/logic/getResourceAddress.unit.test.js +218 -0
  63. package/lib/__tests__/logic/getResourceAddress.unit.test.js.map +1 -0
  64. package/lib/__tests__/logic/isTestnet.unit.test.d.ts +2 -0
  65. package/lib/__tests__/logic/isTestnet.unit.test.d.ts.map +1 -0
  66. package/lib/__tests__/logic/isTestnet.unit.test.js +12 -0
  67. package/lib/__tests__/logic/isTestnet.unit.test.js.map +1 -0
  68. package/lib/__tests__/logic/processRecipients.unit.test.d.ts +2 -0
  69. package/lib/__tests__/logic/processRecipients.unit.test.d.ts.map +1 -0
  70. package/lib/__tests__/logic/processRecipients.unit.test.js +79 -0
  71. package/lib/__tests__/logic/processRecipients.unit.test.js.map +1 -0
  72. package/lib/__tests__/network/client.test.d.ts +2 -0
  73. package/lib/__tests__/network/client.test.d.ts.map +1 -0
  74. package/lib/__tests__/network/client.test.js +992 -0
  75. package/lib/__tests__/network/client.test.js.map +1 -0
  76. package/lib/api/index.d.ts +4 -33
  77. package/lib/api/index.d.ts.map +1 -1
  78. package/lib/api/index.js +19 -196
  79. package/lib/api/index.js.map +1 -1
  80. package/lib/bridge/broadcast.d.ts +3 -2
  81. package/lib/bridge/broadcast.d.ts.map +1 -1
  82. package/lib/bridge/broadcast.js +4 -3
  83. package/lib/bridge/broadcast.js.map +1 -1
  84. package/lib/bridge/estimateMaxSpendable.d.ts.map +1 -1
  85. package/lib/bridge/estimateMaxSpendable.js +5 -4
  86. package/lib/bridge/estimateMaxSpendable.js.map +1 -1
  87. package/lib/bridge/getFeesForTransaction.d.ts +1 -1
  88. package/lib/bridge/getFeesForTransaction.d.ts.map +1 -1
  89. package/lib/bridge/getFeesForTransaction.js +8 -7
  90. package/lib/bridge/getFeesForTransaction.js.map +1 -1
  91. package/lib/bridge/index.d.ts +1 -1
  92. package/lib/bridge/index.d.ts.map +1 -1
  93. package/lib/bridge/index.js +1 -1
  94. package/lib/bridge/index.js.map +1 -1
  95. package/lib/bridge/logic.d.ts +1 -20
  96. package/lib/bridge/logic.d.ts.map +1 -1
  97. package/lib/bridge/logic.js +12 -207
  98. package/lib/bridge/logic.js.map +1 -1
  99. package/lib/bridge/prepareTransaction.d.ts.map +1 -1
  100. package/lib/bridge/prepareTransaction.js +4 -3
  101. package/lib/bridge/prepareTransaction.js.map +1 -1
  102. package/lib/bridge/signOperation.d.ts.map +1 -1
  103. package/lib/bridge/signOperation.js +4 -4
  104. package/lib/bridge/signOperation.js.map +1 -1
  105. package/lib/bridge/synchronisation.js +3 -3
  106. package/lib/bridge/synchronisation.js.map +1 -1
  107. package/lib/config.d.ts +13 -0
  108. package/lib/config.d.ts.map +1 -0
  109. package/lib/config.js +9 -0
  110. package/lib/config.js.map +1 -0
  111. package/lib/constants.d.ts +5 -1
  112. package/lib/constants.d.ts.map +1 -1
  113. package/lib/constants.js +8 -1
  114. package/lib/constants.js.map +1 -1
  115. package/lib/{bridge → logic}/buildTransaction.d.ts +1 -1
  116. package/lib/logic/buildTransaction.d.ts.map +1 -0
  117. package/lib/{bridge → logic}/buildTransaction.js +2 -2
  118. package/lib/logic/buildTransaction.js.map +1 -0
  119. package/lib/logic/calculateAmount.d.ts +3 -0
  120. package/lib/logic/calculateAmount.d.ts.map +1 -0
  121. package/lib/logic/calculateAmount.js +13 -0
  122. package/lib/logic/calculateAmount.js.map +1 -0
  123. package/lib/logic/combine.d.ts +4 -0
  124. package/lib/logic/combine.d.ts.map +1 -0
  125. package/lib/logic/combine.js +34 -0
  126. package/lib/logic/combine.js.map +1 -0
  127. package/lib/logic/craftTransaction.d.ts +5 -0
  128. package/lib/logic/craftTransaction.d.ts.map +1 -0
  129. package/lib/logic/craftTransaction.js +23 -0
  130. package/lib/logic/craftTransaction.js.map +1 -0
  131. package/lib/logic/createTransaction.d.ts.map +1 -0
  132. package/lib/{bridge → logic}/createTransaction.js +3 -3
  133. package/lib/logic/createTransaction.js.map +1 -0
  134. package/lib/logic/getBalance.d.ts +5 -0
  135. package/lib/logic/getBalance.d.ts.map +1 -0
  136. package/lib/logic/getBalance.js +12 -0
  137. package/lib/logic/getBalance.js.map +1 -0
  138. package/lib/logic/getCoinAndAmounts.d.ts +13 -0
  139. package/lib/logic/getCoinAndAmounts.d.ts.map +1 -0
  140. package/lib/logic/getCoinAndAmounts.js +112 -0
  141. package/lib/logic/getCoinAndAmounts.js.map +1 -0
  142. package/lib/logic/getFunctionAddress.d.ts +3 -0
  143. package/lib/logic/getFunctionAddress.d.ts.map +1 -0
  144. package/lib/logic/getFunctionAddress.js +12 -0
  145. package/lib/logic/getFunctionAddress.js.map +1 -0
  146. package/lib/logic/getResourceAddress.d.ts +4 -0
  147. package/lib/logic/getResourceAddress.d.ts.map +1 -0
  148. package/lib/logic/getResourceAddress.js +17 -0
  149. package/lib/logic/getResourceAddress.js.map +1 -0
  150. package/lib/logic/isTestnet.d.ts +2 -0
  151. package/lib/logic/isTestnet.d.ts.map +1 -0
  152. package/lib/logic/isTestnet.js +9 -0
  153. package/lib/logic/isTestnet.js.map +1 -0
  154. package/lib/logic/isWriteSetChangeWriteResource.d.ts +3 -0
  155. package/lib/logic/isWriteSetChangeWriteResource.d.ts.map +1 -0
  156. package/lib/logic/isWriteSetChangeWriteResource.js +8 -0
  157. package/lib/logic/isWriteSetChangeWriteResource.js.map +1 -0
  158. package/lib/logic/normalizeTransactionOptions.d.ts +3 -0
  159. package/lib/logic/normalizeTransactionOptions.d.ts.map +1 -0
  160. package/lib/logic/normalizeTransactionOptions.js +21 -0
  161. package/lib/logic/normalizeTransactionOptions.js.map +1 -0
  162. package/lib/logic/processRecipients.d.ts +6 -0
  163. package/lib/logic/processRecipients.d.ts.map +1 -0
  164. package/lib/logic/processRecipients.js +57 -0
  165. package/lib/logic/processRecipients.js.map +1 -0
  166. package/lib/logic/transactionsToOperations.d.ts +7 -0
  167. package/lib/logic/transactionsToOperations.d.ts.map +1 -0
  168. package/lib/logic/transactionsToOperations.js +85 -0
  169. package/lib/logic/transactionsToOperations.js.map +1 -0
  170. package/lib/network/client.d.ts +38 -0
  171. package/lib/network/client.d.ts.map +1 -0
  172. package/lib/network/client.js +266 -0
  173. package/lib/network/client.js.map +1 -0
  174. package/lib/network/graphql/queries.d.ts.map +1 -0
  175. package/lib/network/graphql/queries.js.map +1 -0
  176. package/lib/network/graphql/types.d.ts.map +1 -0
  177. package/lib/{api → network}/graphql/types.js.map +1 -1
  178. package/lib/network/index.d.ts +2 -1
  179. package/lib/network/index.d.ts.map +1 -1
  180. package/lib/network/index.js +19 -7
  181. package/lib/network/index.js.map +1 -1
  182. package/lib/types/assets.d.ts +12 -0
  183. package/lib/types/assets.d.ts.map +1 -0
  184. package/lib/types/assets.js +3 -0
  185. package/lib/types/assets.js.map +1 -0
  186. package/lib/types/index.d.ts +4 -0
  187. package/lib/types/index.d.ts.map +1 -1
  188. package/lib-es/__tests__/api/craftTransaction.unit.test.d.ts +2 -0
  189. package/lib-es/__tests__/api/craftTransaction.unit.test.d.ts.map +1 -0
  190. package/lib-es/__tests__/api/craftTransaction.unit.test.js +48 -0
  191. package/lib-es/__tests__/api/craftTransaction.unit.test.js.map +1 -0
  192. package/lib-es/__tests__/api/getBalance.unit.test.d.ts +2 -0
  193. package/lib-es/__tests__/api/getBalance.unit.test.d.ts.map +1 -0
  194. package/lib-es/__tests__/api/getBalance.unit.test.js +36 -0
  195. package/lib-es/__tests__/api/getBalance.unit.test.js.map +1 -0
  196. package/lib-es/__tests__/api/index.integ.test.d.ts +2 -0
  197. package/lib-es/__tests__/api/index.integ.test.d.ts.map +1 -0
  198. package/lib-es/__tests__/api/index.integ.test.js +113 -0
  199. package/lib-es/__tests__/api/index.integ.test.js.map +1 -0
  200. package/lib-es/__tests__/api/index.test.js +52 -464
  201. package/lib-es/__tests__/api/index.test.js.map +1 -1
  202. package/lib-es/__tests__/bridge/broadcast.test.js +2 -2
  203. package/lib-es/__tests__/bridge/broadcast.test.js.map +1 -1
  204. package/lib-es/__tests__/bridge/getFeesForTransaction.test.js +2 -2
  205. package/lib-es/__tests__/bridge/getFeesForTransaction.test.js.map +1 -1
  206. package/lib-es/__tests__/bridge/logic.test.js +3 -553
  207. package/lib-es/__tests__/bridge/logic.test.js.map +1 -1
  208. package/lib-es/__tests__/bridge/prepareTransaction.test.js +2 -2
  209. package/lib-es/__tests__/bridge/prepareTransaction.test.js.map +1 -1
  210. package/lib-es/__tests__/bridge/signOperation.test.js +9 -12
  211. package/lib-es/__tests__/bridge/signOperation.test.js.map +1 -1
  212. package/lib-es/__tests__/bridge/synchronisation.test.js +3 -3
  213. package/lib-es/__tests__/bridge/synchronisation.test.js.map +1 -1
  214. package/lib-es/__tests__/index.test.js +1 -1
  215. package/lib-es/__tests__/index.test.js.map +1 -1
  216. package/lib-es/__tests__/logic/buildTransaction.test.d.ts.map +1 -0
  217. package/lib-es/__tests__/{bridge → logic}/buildTransaction.test.js +9 -5
  218. package/lib-es/__tests__/logic/buildTransaction.test.js.map +1 -0
  219. package/lib-es/__tests__/logic/calculateAmount.unit.test.d.ts +2 -0
  220. package/lib-es/__tests__/logic/calculateAmount.unit.test.d.ts.map +1 -0
  221. package/lib-es/__tests__/logic/calculateAmount.unit.test.js +40 -0
  222. package/lib-es/__tests__/logic/calculateAmount.unit.test.js.map +1 -0
  223. package/lib-es/__tests__/logic/combine.unit.test.d.ts +2 -0
  224. package/lib-es/__tests__/logic/combine.unit.test.d.ts.map +1 -0
  225. package/lib-es/__tests__/logic/combine.unit.test.js +45 -0
  226. package/lib-es/__tests__/logic/combine.unit.test.js.map +1 -0
  227. package/lib-es/__tests__/logic/compareAddress.unit.test.d.ts +2 -0
  228. package/lib-es/__tests__/logic/compareAddress.unit.test.d.ts.map +1 -0
  229. package/lib-es/__tests__/logic/compareAddress.unit.test.js +24 -0
  230. package/lib-es/__tests__/logic/compareAddress.unit.test.js.map +1 -0
  231. package/lib-es/__tests__/logic/createTransaction.test.d.ts.map +1 -0
  232. package/lib-es/__tests__/{bridge → logic}/createTransaction.test.js +2 -2
  233. package/lib-es/__tests__/logic/createTransaction.test.js.map +1 -0
  234. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.d.ts +2 -0
  235. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.d.ts.map +1 -0
  236. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.js +181 -0
  237. package/lib-es/__tests__/logic/getCoinAndAmounts.unit.test.js.map +1 -0
  238. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.d.ts +2 -0
  239. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.d.ts.map +1 -0
  240. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.js +27 -0
  241. package/lib-es/__tests__/logic/getFunctionAddress.unit.test.js.map +1 -0
  242. package/lib-es/__tests__/logic/getResourceAddress.unit.test.d.ts +2 -0
  243. package/lib-es/__tests__/logic/getResourceAddress.unit.test.d.ts.map +1 -0
  244. package/lib-es/__tests__/logic/getResourceAddress.unit.test.js +216 -0
  245. package/lib-es/__tests__/logic/getResourceAddress.unit.test.js.map +1 -0
  246. package/lib-es/__tests__/logic/isTestnet.unit.test.d.ts +2 -0
  247. package/lib-es/__tests__/logic/isTestnet.unit.test.d.ts.map +1 -0
  248. package/lib-es/__tests__/logic/isTestnet.unit.test.js +10 -0
  249. package/lib-es/__tests__/logic/isTestnet.unit.test.js.map +1 -0
  250. package/lib-es/__tests__/logic/processRecipients.unit.test.d.ts +2 -0
  251. package/lib-es/__tests__/logic/processRecipients.unit.test.d.ts.map +1 -0
  252. package/lib-es/__tests__/logic/processRecipients.unit.test.js +74 -0
  253. package/lib-es/__tests__/logic/processRecipients.unit.test.js.map +1 -0
  254. package/lib-es/__tests__/network/client.test.d.ts +2 -0
  255. package/lib-es/__tests__/network/client.test.d.ts.map +1 -0
  256. package/lib-es/__tests__/network/client.test.js +987 -0
  257. package/lib-es/__tests__/network/client.test.js.map +1 -0
  258. package/lib-es/api/index.d.ts +4 -33
  259. package/lib-es/api/index.d.ts.map +1 -1
  260. package/lib-es/api/index.js +17 -194
  261. package/lib-es/api/index.js.map +1 -1
  262. package/lib-es/bridge/broadcast.d.ts +3 -2
  263. package/lib-es/bridge/broadcast.d.ts.map +1 -1
  264. package/lib-es/bridge/broadcast.js +4 -3
  265. package/lib-es/bridge/broadcast.js.map +1 -1
  266. package/lib-es/bridge/estimateMaxSpendable.d.ts.map +1 -1
  267. package/lib-es/bridge/estimateMaxSpendable.js +3 -2
  268. package/lib-es/bridge/estimateMaxSpendable.js.map +1 -1
  269. package/lib-es/bridge/getFeesForTransaction.d.ts +1 -1
  270. package/lib-es/bridge/getFeesForTransaction.d.ts.map +1 -1
  271. package/lib-es/bridge/getFeesForTransaction.js +3 -2
  272. package/lib-es/bridge/getFeesForTransaction.js.map +1 -1
  273. package/lib-es/bridge/index.d.ts +1 -1
  274. package/lib-es/bridge/index.d.ts.map +1 -1
  275. package/lib-es/bridge/index.js +1 -1
  276. package/lib-es/bridge/index.js.map +1 -1
  277. package/lib-es/bridge/logic.d.ts +1 -20
  278. package/lib-es/bridge/logic.d.ts.map +1 -1
  279. package/lib-es/bridge/logic.js +6 -190
  280. package/lib-es/bridge/logic.js.map +1 -1
  281. package/lib-es/bridge/prepareTransaction.d.ts.map +1 -1
  282. package/lib-es/bridge/prepareTransaction.js +3 -2
  283. package/lib-es/bridge/prepareTransaction.js.map +1 -1
  284. package/lib-es/bridge/signOperation.d.ts.map +1 -1
  285. package/lib-es/bridge/signOperation.js +2 -2
  286. package/lib-es/bridge/signOperation.js.map +1 -1
  287. package/lib-es/bridge/synchronisation.js +1 -1
  288. package/lib-es/bridge/synchronisation.js.map +1 -1
  289. package/lib-es/config.d.ts +13 -0
  290. package/lib-es/config.d.ts.map +1 -0
  291. package/lib-es/config.js +4 -0
  292. package/lib-es/config.js.map +1 -0
  293. package/lib-es/constants.d.ts +5 -1
  294. package/lib-es/constants.d.ts.map +1 -1
  295. package/lib-es/constants.js +4 -0
  296. package/lib-es/constants.js.map +1 -1
  297. package/lib-es/{bridge → logic}/buildTransaction.d.ts +1 -1
  298. package/lib-es/logic/buildTransaction.d.ts.map +1 -0
  299. package/lib-es/{bridge → logic}/buildTransaction.js +1 -1
  300. package/lib-es/logic/buildTransaction.js.map +1 -0
  301. package/lib-es/logic/calculateAmount.d.ts +3 -0
  302. package/lib-es/logic/calculateAmount.d.ts.map +1 -0
  303. package/lib-es/logic/calculateAmount.js +9 -0
  304. package/lib-es/logic/calculateAmount.js.map +1 -0
  305. package/lib-es/logic/combine.d.ts +4 -0
  306. package/lib-es/logic/combine.d.ts.map +1 -0
  307. package/lib-es/logic/combine.js +29 -0
  308. package/lib-es/logic/combine.js.map +1 -0
  309. package/lib-es/logic/craftTransaction.d.ts +5 -0
  310. package/lib-es/logic/craftTransaction.d.ts.map +1 -0
  311. package/lib-es/logic/craftTransaction.js +16 -0
  312. package/lib-es/logic/craftTransaction.js.map +1 -0
  313. package/lib-es/logic/createTransaction.d.ts.map +1 -0
  314. package/lib-es/{bridge → logic}/createTransaction.js +1 -1
  315. package/lib-es/logic/createTransaction.js.map +1 -0
  316. package/lib-es/logic/getBalance.d.ts +5 -0
  317. package/lib-es/logic/getBalance.d.ts.map +1 -0
  318. package/lib-es/logic/getBalance.js +8 -0
  319. package/lib-es/logic/getBalance.js.map +1 -0
  320. package/lib-es/logic/getCoinAndAmounts.d.ts +13 -0
  321. package/lib-es/logic/getCoinAndAmounts.d.ts.map +1 -0
  322. package/lib-es/logic/getCoinAndAmounts.js +101 -0
  323. package/lib-es/logic/getCoinAndAmounts.js.map +1 -0
  324. package/lib-es/logic/getFunctionAddress.d.ts +3 -0
  325. package/lib-es/logic/getFunctionAddress.d.ts.map +1 -0
  326. package/lib-es/logic/getFunctionAddress.js +8 -0
  327. package/lib-es/logic/getFunctionAddress.js.map +1 -0
  328. package/lib-es/logic/getResourceAddress.d.ts +4 -0
  329. package/lib-es/logic/getResourceAddress.d.ts.map +1 -0
  330. package/lib-es/logic/getResourceAddress.js +13 -0
  331. package/lib-es/logic/getResourceAddress.js.map +1 -0
  332. package/lib-es/logic/isTestnet.d.ts +2 -0
  333. package/lib-es/logic/isTestnet.d.ts.map +1 -0
  334. package/lib-es/logic/isTestnet.js +5 -0
  335. package/lib-es/logic/isTestnet.js.map +1 -0
  336. package/lib-es/logic/isWriteSetChangeWriteResource.d.ts +3 -0
  337. package/lib-es/logic/isWriteSetChangeWriteResource.d.ts.map +1 -0
  338. package/lib-es/logic/isWriteSetChangeWriteResource.js +4 -0
  339. package/lib-es/logic/isWriteSetChangeWriteResource.js.map +1 -0
  340. package/lib-es/logic/normalizeTransactionOptions.d.ts +3 -0
  341. package/lib-es/logic/normalizeTransactionOptions.d.ts.map +1 -0
  342. package/lib-es/logic/normalizeTransactionOptions.js +17 -0
  343. package/lib-es/logic/normalizeTransactionOptions.js.map +1 -0
  344. package/lib-es/logic/processRecipients.d.ts +6 -0
  345. package/lib-es/logic/processRecipients.d.ts.map +1 -0
  346. package/lib-es/logic/processRecipients.js +53 -0
  347. package/lib-es/logic/processRecipients.js.map +1 -0
  348. package/lib-es/logic/transactionsToOperations.d.ts +7 -0
  349. package/lib-es/logic/transactionsToOperations.d.ts.map +1 -0
  350. package/lib-es/logic/transactionsToOperations.js +77 -0
  351. package/lib-es/logic/transactionsToOperations.js.map +1 -0
  352. package/lib-es/network/client.d.ts +38 -0
  353. package/lib-es/network/client.d.ts.map +1 -0
  354. package/lib-es/network/client.js +259 -0
  355. package/lib-es/network/client.js.map +1 -0
  356. package/lib-es/network/graphql/queries.d.ts.map +1 -0
  357. package/lib-es/network/graphql/queries.js.map +1 -0
  358. package/lib-es/network/graphql/types.d.ts.map +1 -0
  359. package/lib-es/{api → network}/graphql/types.js.map +1 -1
  360. package/lib-es/network/index.d.ts +2 -1
  361. package/lib-es/network/index.d.ts.map +1 -1
  362. package/lib-es/network/index.js +6 -8
  363. package/lib-es/network/index.js.map +1 -1
  364. package/lib-es/types/assets.d.ts +12 -0
  365. package/lib-es/types/assets.d.ts.map +1 -0
  366. package/lib-es/types/assets.js +2 -0
  367. package/lib-es/types/assets.js.map +1 -0
  368. package/lib-es/types/index.d.ts +4 -0
  369. package/lib-es/types/index.d.ts.map +1 -1
  370. package/package.json +9 -8
  371. package/src/__tests__/api/craftTransaction.unit.test.ts +70 -0
  372. package/src/__tests__/api/getBalance.unit.test.ts +44 -0
  373. package/src/__tests__/api/index.integ.test.ts +139 -0
  374. package/src/__tests__/api/index.test.ts +60 -547
  375. package/src/__tests__/bridge/broadcast.test.ts +2 -2
  376. package/src/__tests__/bridge/getFeesForTransaction.test.ts +2 -2
  377. package/src/__tests__/bridge/logic.test.ts +4 -649
  378. package/src/__tests__/bridge/prepareTransaction.test.ts +2 -2
  379. package/src/__tests__/bridge/signOperation.test.ts +12 -13
  380. package/src/__tests__/bridge/synchronisation.test.ts +4 -4
  381. package/src/__tests__/index.test.ts +1 -1
  382. package/src/__tests__/{bridge → logic}/buildTransaction.test.ts +12 -7
  383. package/src/__tests__/logic/calculateAmount.unit.test.ts +51 -0
  384. package/src/__tests__/logic/combine.unit.test.ts +65 -0
  385. package/src/__tests__/logic/compareAddress.unit.test.ts +27 -0
  386. package/src/__tests__/{bridge → logic}/createTransaction.test.ts +2 -2
  387. package/src/__tests__/logic/getCoinAndAmounts.unit.test.ts +195 -0
  388. package/src/__tests__/logic/getFunctionAddress.unit.test.ts +33 -0
  389. package/src/__tests__/logic/getResourceAddress.unit.test.ts +241 -0
  390. package/src/__tests__/logic/isTestnet.unit.test.ts +11 -0
  391. package/src/__tests__/logic/processRecipients.unit.test.ts +87 -0
  392. package/src/__tests__/network/client.test.ts +1107 -0
  393. package/src/api/index.ts +29 -251
  394. package/src/bridge/broadcast.ts +7 -7
  395. package/src/bridge/estimateMaxSpendable.ts +3 -2
  396. package/src/bridge/getFeesForTransaction.ts +4 -3
  397. package/src/bridge/index.ts +2 -2
  398. package/src/bridge/logic.ts +8 -283
  399. package/src/bridge/prepareTransaction.ts +4 -2
  400. package/src/bridge/signOperation.ts +2 -2
  401. package/src/bridge/synchronisation.ts +1 -1
  402. package/src/config.ts +19 -0
  403. package/src/constants.ts +6 -1
  404. package/src/{bridge → logic}/buildTransaction.ts +2 -2
  405. package/src/logic/calculateAmount.ts +15 -0
  406. package/src/logic/combine.ts +51 -0
  407. package/src/logic/craftTransaction.ts +26 -0
  408. package/src/{bridge → logic}/createTransaction.ts +1 -1
  409. package/src/logic/getBalance.ts +15 -0
  410. package/src/logic/getCoinAndAmounts.ts +141 -0
  411. package/src/logic/getFunctionAddress.ts +9 -0
  412. package/src/logic/getResourceAddress.ts +24 -0
  413. package/src/logic/isTestnet.ts +5 -0
  414. package/src/logic/isWriteSetChangeWriteResource.ts +7 -0
  415. package/src/logic/normalizeTransactionOptions.ts +18 -0
  416. package/src/logic/processRecipients.ts +87 -0
  417. package/src/logic/transactionsToOperations.ts +105 -0
  418. package/src/network/client.ts +351 -0
  419. package/src/network/index.ts +6 -14
  420. package/src/types/assets.ts +15 -0
  421. package/src/types/index.ts +5 -0
  422. package/lib/__tests__/bridge/buildTransaction.test.d.ts.map +0 -1
  423. package/lib/__tests__/bridge/buildTransaction.test.js.map +0 -1
  424. package/lib/__tests__/bridge/createTransaction.test.d.ts.map +0 -1
  425. package/lib/__tests__/bridge/createTransaction.test.js.map +0 -1
  426. package/lib/api/graphql/queries.d.ts.map +0 -1
  427. package/lib/api/graphql/queries.js.map +0 -1
  428. package/lib/api/graphql/types.d.ts.map +0 -1
  429. package/lib/bridge/buildTransaction.d.ts.map +0 -1
  430. package/lib/bridge/buildTransaction.js.map +0 -1
  431. package/lib/bridge/createTransaction.d.ts.map +0 -1
  432. package/lib/bridge/createTransaction.js.map +0 -1
  433. package/lib-es/__tests__/bridge/buildTransaction.test.d.ts.map +0 -1
  434. package/lib-es/__tests__/bridge/buildTransaction.test.js.map +0 -1
  435. package/lib-es/__tests__/bridge/createTransaction.test.d.ts.map +0 -1
  436. package/lib-es/__tests__/bridge/createTransaction.test.js.map +0 -1
  437. package/lib-es/api/graphql/queries.d.ts.map +0 -1
  438. package/lib-es/api/graphql/queries.js.map +0 -1
  439. package/lib-es/api/graphql/types.d.ts.map +0 -1
  440. package/lib-es/bridge/buildTransaction.d.ts.map +0 -1
  441. package/lib-es/bridge/buildTransaction.js.map +0 -1
  442. package/lib-es/bridge/createTransaction.d.ts.map +0 -1
  443. package/lib-es/bridge/createTransaction.js.map +0 -1
  444. /package/lib/__tests__/{bridge → logic}/buildTransaction.test.d.ts +0 -0
  445. /package/lib/__tests__/{bridge → logic}/createTransaction.test.d.ts +0 -0
  446. /package/lib/{bridge → logic}/createTransaction.d.ts +0 -0
  447. /package/lib/{api → network}/graphql/queries.d.ts +0 -0
  448. /package/lib/{api → network}/graphql/queries.js +0 -0
  449. /package/lib/{api → network}/graphql/types.d.ts +0 -0
  450. /package/lib/{api → network}/graphql/types.js +0 -0
  451. /package/lib-es/__tests__/{bridge → logic}/buildTransaction.test.d.ts +0 -0
  452. /package/lib-es/__tests__/{bridge → logic}/createTransaction.test.d.ts +0 -0
  453. /package/lib-es/{bridge → logic}/createTransaction.d.ts +0 -0
  454. /package/lib-es/{api → network}/graphql/queries.d.ts +0 -0
  455. /package/lib-es/{api → network}/graphql/queries.js +0 -0
  456. /package/lib-es/{api → network}/graphql/types.d.ts +0 -0
  457. /package/lib-es/{api → network}/graphql/types.js +0 -0
  458. /package/src/{api → network}/graphql/queries.ts +0 -0
  459. /package/src/{api → network}/graphql/types.ts +0 -0
@@ -0,0 +1,113 @@
1
+ import { Deserializer, Hex, Network, RawTransaction } from "@aptos-labs/ts-sdk";
2
+ import { createApi } from "../../api";
3
+ import { getEnv } from "@ledgerhq/live-env";
4
+ import { DEFAULT_GAS, DEFAULT_GAS_PRICE } from "../../constants";
5
+ describe("createApi", () => {
6
+ const api = createApi({
7
+ aptosSettings: {
8
+ network: Network.MAINNET,
9
+ fullnode: getEnv("APTOS_API_ENDPOINT"),
10
+ indexer: getEnv("APTOS_INDEXER_ENDPOINT"),
11
+ },
12
+ });
13
+ const sender = {
14
+ xpub: "0xd1a8c6a1cdd52dd40c7ea61ee4571fb51fcae440a594c1eca18636928f1d3956",
15
+ freshAddress: "0x445fa0013887abd1a0c14acdec6e48090e0ad3fed3e08202aac15ca14f3be26b",
16
+ };
17
+ const recipient = {
18
+ xpub: "0x64159425ccc6e755b91dc801b93d182af978c4624d9064facaa9b147544db87f",
19
+ freshAddress: "0x24dbf71ba20209753035505c51d4607ed67aa0c81b930d9ef4483ec84b349fcb",
20
+ };
21
+ describe("lastBlock", () => {
22
+ it("returns the last block information", async () => {
23
+ const lastBlock = await api.lastBlock();
24
+ expect(lastBlock).toHaveProperty("hash");
25
+ expect(Hex.isValid(lastBlock.hash ?? "").valid).toBeTruthy();
26
+ expect(lastBlock).toHaveProperty("height");
27
+ expect(lastBlock.height).toBeGreaterThan(0);
28
+ expect(lastBlock).toHaveProperty("time");
29
+ expect(lastBlock.time).not.toBeUndefined();
30
+ expect(lastBlock.time?.getFullYear()).toBeGreaterThan(0);
31
+ expect(lastBlock.time?.getMonth()).toBeGreaterThan(0);
32
+ expect(lastBlock.time?.getDay()).toBeGreaterThan(0);
33
+ });
34
+ });
35
+ describe("estimateFees", () => {
36
+ it("returns a default value", async () => {
37
+ const amount = BigInt(100);
38
+ const fees = await api.estimateFees({
39
+ asset: {
40
+ type: "native",
41
+ },
42
+ type: "send",
43
+ sender,
44
+ amount,
45
+ recipient: recipient.freshAddress,
46
+ });
47
+ expect(fees.value).toBeGreaterThanOrEqual(0);
48
+ });
49
+ });
50
+ describe("craftTransaction", () => {
51
+ it("returns a RawTransaction serialized into an hexadecimal string", async () => {
52
+ const hex = await api.craftTransaction({
53
+ amount: 1n,
54
+ sender: sender,
55
+ recipient: recipient.freshAddress,
56
+ type: "send",
57
+ asset: { type: "native" },
58
+ }, 0n);
59
+ const rawTx = RawTransaction.deserialize(new Deserializer(Hex.fromHexString(hex).toUint8Array()));
60
+ expect(rawTx.sender.toString()).toBe(sender.freshAddress);
61
+ expect(rawTx.gas_unit_price.toString()).toBe(DEFAULT_GAS_PRICE.toString());
62
+ expect(rawTx.max_gas_amount.toString()).toBe(DEFAULT_GAS.toString());
63
+ });
64
+ });
65
+ describe("getBalance", () => {
66
+ it("return balances from account", async () => {
67
+ const balances = await api.getBalance(sender.freshAddress);
68
+ expect(balances.length).toBeGreaterThan(0);
69
+ expect(balances[0].value).toBeGreaterThan(0);
70
+ });
71
+ });
72
+ describe("listOperations", () => {
73
+ it("returns operations from account", async () => {
74
+ const block = await api.lastBlock();
75
+ const [operations] = await api.listOperations(sender.freshAddress, {
76
+ minHeight: block.height,
77
+ });
78
+ expect(operations).toBeInstanceOf(Array);
79
+ expect(operations.length).toBeGreaterThanOrEqual(1);
80
+ const txINHash = "0xf8c8a486c8e0c0c530f92ea5b26220829e8f8e24f8b0d9f35b57dbd804d36daf";
81
+ const txOUTHash = "0xf980601fe40ad1dab0cc68fe08d2bc95c73e2a21c6d257475e0879394638058e";
82
+ const operationIN = operations.find(operation => operation.id === txINHash);
83
+ const operationOUT = operations.find(operation => operation.id === txOUTHash);
84
+ expect(operationIN).toMatchObject({
85
+ type: "IN",
86
+ value: 20000000n,
87
+ recipients: [sender.freshAddress],
88
+ senders: ["0xa0d8abc262e3321f87d745bd5d687e8f3fb14c87d48f840b6b56867df0026ec8"],
89
+ asset: { type: "native" },
90
+ tx: {
91
+ hash: "0xf8c8a486c8e0c0c530f92ea5b26220829e8f8e24f8b0d9f35b57dbd804d36daf",
92
+ block: { height: 0 },
93
+ fees: 1100n,
94
+ date: new Date("2025-03-11T16:27:53.180Z"),
95
+ },
96
+ });
97
+ expect(operationOUT).toMatchObject({
98
+ type: "OUT",
99
+ value: 119900n,
100
+ recipients: ["0xd20fa44192f94ba086ab16bfdf57e43ff118ada69b4c66fa9b9a9223cbc068c1"],
101
+ senders: [sender.freshAddress],
102
+ asset: { type: "native" },
103
+ tx: {
104
+ hash: "0xf980601fe40ad1dab0cc68fe08d2bc95c73e2a21c6d257475e0879394638058e",
105
+ block: { height: 0 },
106
+ fees: 99900n,
107
+ date: new Date("2024-12-18T14:14:59.703Z"),
108
+ },
109
+ });
110
+ });
111
+ });
112
+ });
113
+ //# sourceMappingURL=index.integ.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.integ.test.js","sourceRoot":"","sources":["../../../src/__tests__/api/index.integ.test.ts"],"names":[],"mappings":"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"}
@@ -1,472 +1,60 @@
1
- import { ApolloClient } from "@apollo/client";
2
- import { AccountAddress, Aptos, Ed25519PublicKey, RawTransaction, post, } from "@aptos-labs/ts-sdk";
3
- import network from "@ledgerhq/live-network";
4
- import BigNumber from "bignumber.js";
5
- import { AptosAPI } from "../../api";
1
+ import { Aptos } from "@aptos-labs/ts-sdk";
2
+ import { createApi } from "../../api";
3
+ import coinConfig from "../../config";
6
4
  jest.mock("@aptos-labs/ts-sdk");
7
- jest.mock("@apollo/client");
8
5
  let mockedAptos;
9
- let mockedApolloClient;
10
- let mockedPost = jest.fn();
11
- jest.mock("@ledgerhq/live-network/network");
12
- const mockedNetwork = jest.mocked(network);
13
- describe("Aptos API", () => {
14
- beforeEach(() => {
15
- mockedAptos = jest.mocked(Aptos);
16
- mockedApolloClient = jest.mocked(ApolloClient);
17
- mockedPost = jest.mocked(post);
18
- });
19
- afterEach(() => jest.clearAllMocks());
20
- it("builds the client properly for mainnet", () => {
21
- const api = new AptosAPI("aptos");
6
+ jest.mock("../../config", () => ({
7
+ setCoinConfig: jest.fn(),
8
+ }));
9
+ const mockAptosConfig = {};
10
+ describe("createApi", () => {
11
+ it("should set the coin config value", () => {
12
+ const setCoinConfigSpy = jest.spyOn(coinConfig, "setCoinConfig");
13
+ createApi(mockAptosConfig);
14
+ const config = setCoinConfigSpy.mock.calls[0][0]();
15
+ expect(setCoinConfigSpy).toHaveBeenCalled();
16
+ expect(config).toEqual(expect.objectContaining({
17
+ ...mockAptosConfig,
18
+ status: { type: "active" },
19
+ }));
20
+ });
21
+ it("should return an API object with alpaca api methods", () => {
22
+ const api = createApi(mockAptosConfig);
23
+ // Check that methods are set with what we expect
22
24
  expect(api.broadcast).toBeDefined();
23
- expect(typeof api.broadcast).toBe("function");
24
- expect(api.estimateGasPrice).toBeDefined();
25
- expect(typeof api.estimateGasPrice).toBe("function");
26
- expect(api.generateTransaction).toBeDefined();
27
- expect(typeof api.generateTransaction).toBe("function");
28
- expect(api.getAccount).toBeDefined();
29
- expect(typeof api.getAccount).toBe("function");
30
- expect(api.getAccountInfo).toBeDefined();
31
- expect(typeof api.getAccountInfo).toBe("function");
32
- expect(api.simulateTransaction).toBeDefined();
33
- expect(typeof api.simulateTransaction).toBe("function");
34
- });
35
- it("builds the client properly for testnet", () => {
36
- const api = new AptosAPI("aptos_testnet");
37
- expect(api.broadcast).toBeDefined();
38
- expect(typeof api.broadcast).toBe("function");
39
- expect(api.estimateGasPrice).toBeDefined();
40
- expect(typeof api.estimateGasPrice).toBe("function");
41
- expect(api.generateTransaction).toBeDefined();
42
- expect(typeof api.generateTransaction).toBe("function");
43
- expect(api.getAccount).toBeDefined();
44
- expect(typeof api.getAccount).toBe("function");
45
- expect(api.getAccountInfo).toBeDefined();
46
- expect(typeof api.getAccountInfo).toBe("function");
47
- expect(api.simulateTransaction).toBeDefined();
48
- expect(typeof api.simulateTransaction).toBe("function");
49
- });
50
- describe("getAccount", () => {
51
- it("calls getAccountInfo", async () => {
52
- const mockGetAccountInfo = jest.fn();
53
- mockedAptos.mockImplementation(() => ({
54
- getAccountInfo: mockGetAccountInfo,
55
- }));
56
- const mockGetAccountSpy = jest.spyOn({ getAccount: mockGetAccountInfo }, "getAccount");
57
- const api = new AptosAPI("aptos");
58
- await api.getAccount("address");
59
- expect(mockGetAccountSpy).toHaveBeenCalledWith({
60
- accountAddress: "address",
61
- });
62
- });
25
+ expect(api.combine).toBeDefined();
26
+ expect(api.craftTransaction).toBeDefined();
27
+ expect(api.estimateFees).toBeDefined();
28
+ expect(api.getBalance).toBeDefined();
29
+ expect(api.lastBlock).toBeDefined();
30
+ expect(api.listOperations).toBeDefined();
63
31
  });
64
- describe("getBalance", () => {
65
- let token;
66
- beforeEach(() => {
67
- token = {
68
- type: "TokenCurrency",
69
- id: "aptos_token",
70
- name: "Aptos Token",
71
- ticker: "APT",
72
- units: [{ name: "APT", code: "APT", magnitude: 6 }],
73
- contractAddress: "APTOS_1_ADDRESS",
74
- tokenType: "fungible_asset",
75
- parentCurrency: {
76
- type: "CryptoCurrency",
77
- id: "aptos",
78
- name: "Aptos",
79
- ticker: "APT",
80
- units: [{ name: "APT", code: "APT", magnitude: 6 }],
81
- color: "#000000",
82
- family: "aptos",
83
- scheme: "aptos",
84
- explorerViews: [],
85
- managerAppName: "Aptos",
86
- coinType: 637,
87
- },
88
- };
89
- });
90
- it("get coin balance", async () => {
91
- mockedAptos.mockImplementation(() => ({
92
- view: jest.fn().mockReturnValue(["1234"]),
93
- }));
94
- token.tokenType = "coin";
95
- const api = new AptosAPI("aptos");
96
- const balance = await api.getBalance("address", token);
97
- expect(balance).toEqual(new BigNumber(1234));
98
- });
99
- it("get fungible assets balance", async () => {
100
- mockedAptos.mockImplementation(() => ({
101
- view: jest.fn().mockReturnValue(["12345"]),
102
- }));
103
- token.tokenType = "fungible_asset";
104
- const api = new AptosAPI("aptos");
105
- const balance = await api.getBalance("address", token);
106
- expect(balance).toEqual(new BigNumber(12345));
107
- });
108
- it("return 0 balace if could not retrieve proper balance of fungible assets", async () => {
109
- mockedAptos.mockImplementation(() => ({
110
- view: jest.fn().mockImplementation(() => {
111
- throw new Error("error");
112
- }),
113
- }));
114
- token.tokenType = "fungible_asset";
115
- const api = new AptosAPI("aptos");
116
- const balance = await api.getBalance("address", token);
117
- expect(balance).toEqual(new BigNumber(0));
118
- });
119
- });
120
- describe("getAccountInfo", () => {
121
- it("calls getCoinBalance, fetchTransactions and getHeight", async () => {
122
- mockedAptos.mockImplementation(() => ({
123
- view: jest.fn().mockReturnValue(["123"]),
124
- getTransactionByVersion: jest.fn().mockReturnValue({
125
- type: "user_transaction",
126
- version: "v1",
127
- }),
128
- getBlockByVersion: jest.fn().mockReturnValue({
129
- block_height: "1",
130
- block_hash: "83ca6d",
131
- }),
132
- }));
133
- mockedNetwork.mockResolvedValue(Promise.resolve({
134
- data: {
135
- account: {
136
- account_number: 1,
137
- sequence: 0,
138
- pub_key: { key: "k", "@type": "type" },
139
- base_account: {
140
- account_number: 2,
141
- sequence: 42,
142
- pub_key: { key: "k2", "@type": "type2" },
143
- },
144
- },
145
- block_height: "999",
146
- },
147
- status: 200,
148
- headers: {},
149
- statusText: "",
150
- config: {
151
- headers: {},
152
- },
153
- }));
154
- mockedApolloClient.mockImplementation(() => ({
155
- query: async () => ({
156
- data: {
157
- account_transactions: [{ transaction_version: 1 }],
158
- },
159
- loading: false,
160
- networkStatus: 7,
161
- }),
162
- }));
163
- const api = new AptosAPI("aptos");
164
- const accountInfo = await api.getAccountInfo("APTOS_1_ADDRESS", "1");
165
- expect(accountInfo.balance).toEqual(new BigNumber(123));
166
- expect(accountInfo.transactions).toEqual([
167
- {
168
- type: "user_transaction",
169
- version: "v1",
170
- block: {
171
- height: 1,
172
- hash: "83ca6d",
173
- },
174
- },
175
- ]);
176
- expect(accountInfo.blockHeight).toEqual(999);
177
- });
178
- it("return balance = 0 if it fails to fetch balance", async () => {
179
- mockedAptos.mockImplementation(() => ({
180
- view: jest.fn().mockImplementation(() => {
181
- throw new Error("error");
182
- }),
183
- getTransactionByVersion: jest.fn().mockReturnValue({
184
- type: "user_transaction",
185
- version: "v1",
186
- }),
187
- getBlockByVersion: jest.fn().mockReturnValue({
188
- block_height: "1",
189
- block_hash: "83ca6d",
190
- }),
191
- }));
192
- mockedNetwork.mockResolvedValue(Promise.resolve({
193
- data: {
194
- account: {
195
- account_number: 1,
196
- sequence: 0,
197
- pub_key: { key: "k", "@type": "type" },
198
- base_account: {
199
- account_number: 2,
200
- sequence: 42,
201
- pub_key: { key: "k2", "@type": "type2" },
202
- },
203
- },
204
- block_height: "999",
205
- },
206
- status: 200,
207
- headers: {},
208
- statusText: "",
209
- config: {
210
- headers: {},
211
- },
212
- }));
213
- mockedApolloClient.mockImplementation(() => ({
214
- query: async () => ({
215
- data: {
216
- account_transactions: [{ transaction_version: 1 }],
217
- },
218
- loading: false,
219
- networkStatus: 7,
220
- }),
221
- }));
222
- const api = new AptosAPI("aptos");
223
- const accountInfo = await api.getAccountInfo("APTOS_1_ADDRESS", "1");
224
- expect(accountInfo.balance).toEqual(new BigNumber(0));
225
- expect(accountInfo.transactions).toEqual([
226
- {
227
- type: "user_transaction",
228
- version: "v1",
229
- block: {
230
- height: 1,
231
- hash: "83ca6d",
232
- },
233
- },
234
- ]);
235
- expect(accountInfo.blockHeight).toEqual(999);
236
- });
237
- it("returns no transactions if it the address is empty", async () => {
238
- mockedAptos.mockImplementation(() => ({
239
- view: jest.fn().mockReturnValue(["123"]),
240
- getTransactionByVersion: jest.fn().mockReturnValue({
241
- type: "user_transaction",
242
- version: "v1",
243
- }),
244
- getBlockByVersion: jest.fn().mockReturnValue({
245
- block_height: "1",
246
- block_hash: "83ca6d",
247
- }),
248
- }));
249
- mockedNetwork.mockResolvedValue(Promise.resolve({
250
- data: {
251
- account: {
252
- account_number: 1,
253
- sequence: 0,
254
- pub_key: { key: "k", "@type": "type" },
255
- base_account: {
256
- account_number: 2,
257
- sequence: 42,
258
- pub_key: { key: "k2", "@type": "type2" },
259
- },
260
- },
261
- block_height: "999",
262
- },
263
- status: 200,
264
- headers: {},
265
- statusText: "",
266
- config: {
267
- headers: {},
268
- },
269
- }));
270
- mockedApolloClient.mockImplementation(() => ({
271
- query: async () => ({
272
- data: {
273
- account_transactions: [{ transaction_version: 1 }],
274
- },
275
- loading: false,
276
- networkStatus: 7,
277
- }),
278
- }));
279
- const api = new AptosAPI("aptos");
280
- const accountInfo = await api.getAccountInfo("", "1");
281
- expect(accountInfo.balance).toEqual(new BigNumber(123));
282
- expect(accountInfo.transactions).toEqual([]);
283
- expect(accountInfo.blockHeight).toEqual(999);
284
- });
285
- it("returns a null transaction if it fails to getTransactionByVersion", async () => {
286
- mockedAptos.mockImplementation(() => ({
287
- view: jest.fn().mockReturnValue(["123"]),
288
- getTransactionByVersion: jest.fn().mockImplementation(() => {
289
- throw new Error("error");
290
- }),
291
- getBlockByVersion: jest.fn().mockReturnValue({
292
- block_height: "1",
293
- block_hash: "83ca6d",
294
- }),
295
- }));
296
- mockedNetwork.mockResolvedValue(Promise.resolve({
297
- data: {
298
- account: {
299
- account_number: 1,
300
- sequence: 0,
301
- pub_key: { key: "k", "@type": "type" },
302
- base_account: {
303
- account_number: 2,
304
- sequence: 42,
305
- pub_key: { key: "k2", "@type": "type2" },
306
- },
307
- },
308
- block_height: "999",
309
- },
310
- status: 200,
311
- headers: {},
312
- statusText: "",
313
- config: {
314
- headers: {},
315
- },
316
- }));
317
- mockedApolloClient.mockImplementation(() => ({
318
- query: async () => ({
319
- data: {
320
- account_transactions: [{ transaction_version: 1 }],
321
- },
322
- loading: false,
323
- networkStatus: 7,
324
- }),
325
- }));
326
- const api = new AptosAPI("aptos");
327
- const accountInfo = await api.getAccountInfo("APTOS_1_ADDRESS", "1");
328
- expect(accountInfo.balance).toEqual(new BigNumber(123));
329
- expect(accountInfo.transactions).toEqual([null]);
330
- expect(accountInfo.blockHeight).toEqual(999);
331
- });
332
- });
333
- describe("estimateGasPrice", () => {
334
- it("estimates the gas price", async () => {
335
- const gasEstimation = { gas_estimate: 100 };
336
- mockedAptos.mockImplementation(() => ({
337
- getGasPriceEstimation: jest.fn().mockReturnValue(gasEstimation),
338
- }));
339
- const api = new AptosAPI("aptos");
340
- const gasPrice = await api.estimateGasPrice();
341
- expect(gasPrice.gas_estimate).toEqual(100);
342
- });
343
- });
344
- describe("generateTransaction", () => {
345
- const payload = {
346
- function: "0x1::coin::transfer",
347
- functionArguments: ["0x13", 1],
348
- };
349
- it("generates a transaction without expireTimestamp", async () => {
350
- const options = {
351
- maxGasAmount: "100",
352
- gasUnitPrice: "50",
353
- };
354
- const mockSimple = jest.fn().mockImplementation(async () => ({
355
- rawTransaction: null,
356
- }));
357
- mockedAptos.mockImplementation(() => ({
358
- transaction: {
359
- build: {
360
- simple: mockSimple,
361
- },
362
- },
363
- }));
364
- const mockSimpleSpy = jest.spyOn({ simple: mockSimple }, "simple");
365
- const api = new AptosAPI("aptos");
366
- await api.generateTransaction("APTOS_1_ADDRESS", payload, options);
367
- expect(mockSimpleSpy).toHaveBeenCalledWith({
368
- data: payload,
369
- options: {
370
- maxGasAmount: Number(options.maxGasAmount),
371
- gasUnitPrice: Number(options.gasUnitPrice),
372
- },
373
- sender: "APTOS_1_ADDRESS",
374
- });
375
- });
376
- it("generates a transaction with default expireTimestamp", async () => {
377
- const options = {
378
- maxGasAmount: "100",
379
- gasUnitPrice: "50",
380
- };
381
- const mockSimple = jest.fn().mockImplementation(async () => ({
382
- rawTransaction: null,
383
- }));
384
- const mockGetLedgerInfo = jest.fn().mockImplementation(async () => ({
385
- ledger_timestamp: "0",
386
- }));
387
- mockedAptos.mockImplementation(() => ({
388
- transaction: {
389
- build: {
390
- simple: mockSimple,
391
- },
392
- },
393
- getLedgerInfo: mockGetLedgerInfo,
394
- }));
395
- const mockSimpleSpy = jest.spyOn({ simple: mockSimple }, "simple");
396
- const api = new AptosAPI("aptos");
397
- await api.generateTransaction("APTOS_1_ADDRESS", payload, options);
398
- expect(mockSimpleSpy).toHaveBeenCalledWith({
399
- data: payload,
400
- options: {
401
- maxGasAmount: Number(options.maxGasAmount),
402
- gasUnitPrice: Number(options.gasUnitPrice),
403
- expireTimestamp: 120,
404
- },
405
- sender: "APTOS_1_ADDRESS",
406
- });
407
- });
408
- it("throws an error when failing to build a transaction", async () => {
409
- const options = {
410
- maxGasAmount: "100",
411
- gasUnitPrice: "50",
412
- };
413
- const mockSimple = jest.fn().mockImplementation(async () => null);
414
- mockedAptos.mockImplementation(() => ({
415
- transaction: {
416
- build: {
417
- simple: mockSimple,
418
- },
419
- },
420
- }));
421
- const api = new AptosAPI("aptos");
422
- expect(async () => await api.generateTransaction("APTOS_1_ADDRESS", payload, options)).rejects.toThrow();
423
- });
424
- });
425
- describe("simulateTransaction", () => {
426
- it("simulates a transaction with the correct options", async () => {
427
- const mockSimple = jest.fn().mockImplementation(async () => ({
428
- rawTransaction: null,
429
- }));
430
- mockedAptos.mockImplementation(() => ({
431
- transaction: {
432
- simulate: {
433
- simple: mockSimple,
434
- },
435
- },
436
- }));
437
- const mockSimpleSpy = jest.spyOn({ simple: mockSimple }, "simple");
438
- const api = new AptosAPI("aptos");
439
- const address = new Ed25519PublicKey("APTOS_1_ADDRESS");
440
- const tx = new RawTransaction(new AccountAddress(Uint8Array.from(Buffer.from("APTOS_2_ADDRESS"))), BigInt(1), "", BigInt(100), BigInt(50), BigInt(1), { chainId: 1 });
441
- await api.simulateTransaction(address, tx);
442
- expect(mockSimpleSpy).toHaveBeenCalledWith({
443
- signerPublicKey: address,
444
- transaction: { rawTransaction: tx },
445
- options: {
446
- estimateGasUnitPrice: true,
447
- estimateMaxGasAmount: true,
448
- estimatePrioritizedGasUnitPrice: false,
449
- },
450
- });
451
- });
32
+ });
33
+ describe("lastBlock", () => {
34
+ beforeEach(() => {
35
+ mockedAptos = jest.mocked(Aptos);
452
36
  });
453
- describe("broadcast", () => {
454
- it("broadcasts the transaction", async () => {
455
- mockedPost.mockImplementation(async () => ({ data: { hash: "ok" } }));
456
- const mockedPostSpy = jest.spyOn({ post: mockedPost }, "post");
457
- mockedAptos.mockImplementation(() => ({
458
- config: "config",
459
- }));
460
- const api = new AptosAPI("aptos");
461
- await api.broadcast("signature");
462
- expect(mockedPostSpy).toHaveBeenCalledWith({
463
- contentType: "application/x.aptos.signed_transaction+bcs",
464
- aptosConfig: "config",
465
- body: Uint8Array.from(Buffer.from("signature", "hex")),
466
- path: "transactions",
467
- type: "Fullnode",
468
- originMethod: "",
469
- });
37
+ afterEach(() => {
38
+ jest.resetAllMocks();
39
+ });
40
+ it("returns the last block information", async () => {
41
+ mockedAptos.mockImplementation(() => ({
42
+ getLedgerInfo: jest.fn().mockReturnValue({
43
+ block_height: "123",
44
+ }),
45
+ getBlockByHeight: jest.fn().mockReturnValue({
46
+ block_height: "123",
47
+ block_hash: "123hash",
48
+ block_timestamp: "1746021098623892",
49
+ first_version: "1",
50
+ last_version: "1",
51
+ }),
52
+ }));
53
+ const api = createApi(mockAptosConfig);
54
+ expect(await api.lastBlock()).toStrictEqual({
55
+ height: 123,
56
+ hash: "123hash",
57
+ time: new Date(1746021098623892),
470
58
  });
471
59
  });
472
60
  });