trac-msb 0.2.4 → 0.2.6

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 (239) hide show
  1. package/.dockerignore +16 -0
  2. package/.github/workflows/acceptance-tests.yml +7 -0
  3. package/.github/workflows/publish.yml +40 -0
  4. package/.github/workflows/{CI.yml → unit-tests.yml} +1 -1
  5. package/README.md +175 -50
  6. package/docker-compose.yml +16 -0
  7. package/dockerfile +41 -0
  8. package/docs/fee_distribution.md +89 -0
  9. package/msb.mjs +12 -14
  10. package/package.json +8 -4
  11. package/rpc/constants.mjs +4 -1
  12. package/rpc/handlers.mjs +109 -66
  13. package/rpc/routes/v1.mjs +3 -1
  14. package/rpc/rpc_services.js +126 -0
  15. package/rpc/utils/confirmedParameter.mjs +17 -0
  16. package/rpc/utils/url.mjs +38 -0
  17. package/src/core/network/Network.js +27 -10
  18. package/src/core/network/identity/NetworkWalletFactory.js +78 -0
  19. package/src/core/network/services/ConnectionManager.js +2 -2
  20. package/src/core/network/services/ValidatorObserverService.js +7 -4
  21. package/src/core/state/State.js +28 -22
  22. package/src/index.js +197 -385
  23. package/src/utils/cliCommands.js +280 -0
  24. package/src/utils/constants.js +3 -1
  25. package/tests/acceptance/v1/account/account.test.mjs +123 -0
  26. package/tests/acceptance/v1/balance/balance.test.mjs +55 -0
  27. package/tests/acceptance/v1/broadcast-transaction/broadcast-transaction.test.mjs +111 -0
  28. package/tests/acceptance/v1/confirmed-length/confirmed-length.test.mjs +19 -0
  29. package/tests/acceptance/v1/fee/fee.test.mjs +11 -0
  30. package/tests/acceptance/v1/rpc.test.mjs +62 -291
  31. package/tests/acceptance/v1/tx/tx.test.mjs +98 -0
  32. package/tests/acceptance/v1/tx-details/tx-details.test.mjs +195 -0
  33. package/tests/acceptance/v1/tx-hashes/tx-hashes.test.mjs +72 -0
  34. package/tests/acceptance/v1/tx-payloads-bulk/tx-payloads-bulk.test.mjs +27 -0
  35. package/tests/acceptance/v1/txv/txv.test.mjs +11 -0
  36. package/tests/acceptance/v1/unconfirmed-length/unconfirmed-length.test.mjs +11 -0
  37. package/tests/helpers/StateNetworkFactory.js +157 -0
  38. package/tests/helpers/autobaseTestHelpers.js +369 -0
  39. package/tests/helpers/createTestSignature.js +12 -0
  40. package/tests/helpers/transactionPayloads.mjs +78 -0
  41. package/tests/unit/network/NetworkWalletFactory.test.js +156 -0
  42. package/tests/unit/state/apply/addAdmin/addAdminHappyPathScenario.js +38 -0
  43. package/tests/unit/state/apply/addAdmin/addAdminScenarioHelpers.js +273 -0
  44. package/tests/unit/state/apply/addAdmin/adminEntryEncodingFailureScenario.js +30 -0
  45. package/tests/unit/state/apply/addAdmin/adminEntryExistsScenario.js +78 -0
  46. package/tests/unit/state/apply/addAdmin/nodeEntryInitializationFailureScenario.js +30 -0
  47. package/tests/unit/state/apply/addAdmin/nonBootstrapNodeScenario.js +68 -0
  48. package/tests/unit/state/apply/addAdmin/state.apply.addAdmin.test.js +155 -0
  49. package/tests/unit/state/apply/addIndexer/addIndexerHappyPathScenario.js +39 -0
  50. package/tests/unit/state/apply/addIndexer/addIndexerMultipleIndexersInTheNetworkScenario.js +167 -0
  51. package/tests/unit/state/apply/addIndexer/addIndexerPretenderAlreadyIndexerScenario.js +21 -0
  52. package/tests/unit/state/apply/addIndexer/addIndexerPretenderNotWriterScenario.js +21 -0
  53. package/tests/unit/state/apply/addIndexer/addIndexerRemoveAndReAddScenario.js +186 -0
  54. package/tests/unit/state/apply/addIndexer/addIndexerScenarioHelpers.js +445 -0
  55. package/tests/unit/state/apply/addIndexer/addIndexerWriterKeyAlreadyRegisteredScenario.js +32 -0
  56. package/tests/unit/state/apply/addIndexer/state.apply.addIndexer.test.js +297 -0
  57. package/tests/unit/state/apply/addWriter/addWriterHappyPathScenario.js +41 -0
  58. package/tests/unit/state/apply/addWriter/addWriterInvalidValidatorSignatureScenario.js +32 -0
  59. package/tests/unit/state/apply/addWriter/addWriterNewWkScenario.js +149 -0
  60. package/tests/unit/state/apply/addWriter/addWriterRequesterAlreadyWriterScenario.js +21 -0
  61. package/tests/unit/state/apply/addWriter/addWriterRequesterBalanceInsufficientScenario.js +21 -0
  62. package/tests/unit/state/apply/addWriter/addWriterRequesterEntryDecodeFailureScenario.js +19 -0
  63. package/tests/unit/state/apply/addWriter/addWriterRequesterEntryMissingScenario.js +19 -0
  64. package/tests/unit/state/apply/addWriter/addWriterRequesterIndexerScenario.js +21 -0
  65. package/tests/unit/state/apply/addWriter/addWriterRequesterNotWhitelistedScenario.js +21 -0
  66. package/tests/unit/state/apply/addWriter/addWriterScenarioHelpers.js +757 -0
  67. package/tests/unit/state/apply/addWriter/addWriterStakeBalanceUpdateFailureScenario.js +50 -0
  68. package/tests/unit/state/apply/addWriter/addWriterStakeInsufficientBalanceScenario.js +29 -0
  69. package/tests/unit/state/apply/addWriter/addWriterStakeInvalidBalanceScenario.js +29 -0
  70. package/tests/unit/state/apply/addWriter/addWriterStakeInvalidEntryScenario.js +21 -0
  71. package/tests/unit/state/apply/addWriter/addWriterStakeStakedBalanceFailureScenario.js +37 -0
  72. package/tests/unit/state/apply/addWriter/addWriterStakeSubtractFailureScenario.js +42 -0
  73. package/tests/unit/state/apply/addWriter/addWriterValidatorRewardScenario.js +105 -0
  74. package/tests/unit/state/apply/addWriter/addWriterWriterKeyMismatchScenario.js +54 -0
  75. package/tests/unit/state/apply/addWriter/addWriterWriterKeyOwnershipScenario.js +54 -0
  76. package/tests/unit/state/apply/addWriter/addWriterZeroWriterKeyScenario.js +29 -0
  77. package/tests/unit/state/apply/addWriter/state.apply.addWriter.test.js +309 -0
  78. package/tests/unit/state/apply/adminRecovery/adminRecoveryHappyPathScenario.js +30 -0
  79. package/tests/unit/state/apply/adminRecovery/adminRecoveryScenarioHelpers.js +866 -0
  80. package/tests/unit/state/apply/adminRecovery/state.apply.adminRecovery.test.js +439 -0
  81. package/tests/unit/state/apply/appendWhitelist/appendWhitelistBanAndReapplyScenario.js +78 -0
  82. package/tests/unit/state/apply/appendWhitelist/appendWhitelistExistingReaderHappyPathScenario.js +98 -0
  83. package/tests/unit/state/apply/appendWhitelist/appendWhitelistFeeAfterDisableScenario.js +66 -0
  84. package/tests/unit/state/apply/appendWhitelist/appendWhitelistHappyPathScenario.js +55 -0
  85. package/tests/unit/state/apply/appendWhitelist/appendWhitelistInsufficientAdminBalanceScenario.js +103 -0
  86. package/tests/unit/state/apply/appendWhitelist/appendWhitelistNodeAlreadyWhitelistedScenario.js +60 -0
  87. package/tests/unit/state/apply/appendWhitelist/appendWhitelistScenarioHelpers.js +191 -0
  88. package/tests/unit/state/apply/appendWhitelist/state.apply.appendWhitelist.test.js +220 -0
  89. package/tests/unit/state/apply/balanceInitialization/balanceInitializationHappyPathScenario.js +82 -0
  90. package/tests/unit/state/apply/balanceInitialization/balanceInitializationScenarioHelpers.js +106 -0
  91. package/tests/unit/state/apply/balanceInitialization/invalidAmountScenario.js +45 -0
  92. package/tests/unit/state/apply/balanceInitialization/nodeEntryBalanceUpdateFailureScenario.js +81 -0
  93. package/tests/unit/state/apply/balanceInitialization/state.apply.balanceInitialization.test.js +189 -0
  94. package/tests/unit/state/apply/banValidator/banValidatorBanAndReWhitelistScenario.js +155 -0
  95. package/tests/unit/state/apply/banValidator/banValidatorHappyPathScenario.js +36 -0
  96. package/tests/unit/state/apply/banValidator/banValidatorScenarioHelpers.js +534 -0
  97. package/tests/unit/state/apply/banValidator/banValidatorSequentialBansScenario.js +74 -0
  98. package/tests/unit/state/apply/banValidator/banValidatorTargetDecodeFailureScenario.js +19 -0
  99. package/tests/unit/state/apply/banValidator/banValidatorTargetIndexerScenario.js +32 -0
  100. package/tests/unit/state/apply/banValidator/banValidatorTargetNodeEntryMissingScenario.js +19 -0
  101. package/tests/unit/state/apply/banValidator/banValidatorTargetRoleUpdateFailureScenario.js +19 -0
  102. package/tests/unit/state/apply/banValidator/banValidatorWhitelistedNonWriterScenario.js +38 -0
  103. package/tests/unit/state/apply/banValidator/banValidatorWhitelistedZeroBalanceScenario.js +91 -0
  104. package/tests/unit/state/apply/banValidator/banValidatorWithdrawFailureScenario.js +19 -0
  105. package/tests/unit/state/apply/banValidator/state.apply.banValidator.test.js +266 -0
  106. package/tests/unit/state/apply/bootstrapDeployment/bootstrapDeploymentDuplicateRegistrationScenario.js +142 -0
  107. package/tests/unit/state/apply/bootstrapDeployment/bootstrapDeploymentHappyPathScenario.js +26 -0
  108. package/tests/unit/state/apply/bootstrapDeployment/bootstrapDeploymentIncompleteOperationScenario.js +94 -0
  109. package/tests/unit/state/apply/bootstrapDeployment/bootstrapDeploymentInvalidDeploymentEntryScenario.js +37 -0
  110. package/tests/unit/state/apply/bootstrapDeployment/bootstrapDeploymentMultipleBootstrapScenario.js +86 -0
  111. package/tests/unit/state/apply/bootstrapDeployment/bootstrapDeploymentScenarioHelpers.js +344 -0
  112. package/tests/unit/state/apply/bootstrapDeployment/invalidValidatorNodeEntryScenario.js +57 -0
  113. package/tests/unit/state/apply/bootstrapDeployment/state.apply.bootstrapDeployment.test.js +429 -0
  114. package/tests/unit/state/apply/common/access-control/adminConsistencyMismatchScenario.js +119 -0
  115. package/tests/unit/state/apply/common/access-control/adminEntryDecodeFailureScenario.js +130 -0
  116. package/tests/unit/state/apply/common/access-control/adminEntryExistsScenario.js +93 -0
  117. package/tests/unit/state/apply/common/access-control/adminEntryMissingScenario.js +108 -0
  118. package/tests/unit/state/apply/common/access-control/adminOnlyGuardScenario.js +126 -0
  119. package/tests/unit/state/apply/common/access-control/adminPublicKeyDecodeFailureScenario.js +120 -0
  120. package/tests/unit/state/apply/common/access-control/roleAccessOperationValidationScenario.js +50 -0
  121. package/tests/unit/state/apply/common/adminControlOperationValidationScenario.js +56 -0
  122. package/tests/unit/state/apply/common/balances/adminEntryUpdateFailureScenario.js +52 -0
  123. package/tests/unit/state/apply/common/balances/base/requesterBalanceScenarioBase.js +197 -0
  124. package/tests/unit/state/apply/common/balances/feeDecodeFailureScenario.js +52 -0
  125. package/tests/unit/state/apply/common/balances/requesterBalanceDecodeFailureScenario.js +15 -0
  126. package/tests/unit/state/apply/common/balances/requesterBalanceFeeApplicationFailureScenario.js +11 -0
  127. package/tests/unit/state/apply/common/balances/requesterBalanceInsufficientScenario.js +15 -0
  128. package/tests/unit/state/apply/common/balances/requesterBalanceUpdateFailureScenario.js +11 -0
  129. package/tests/unit/state/apply/common/balances/validatorEntryRewardFailureScenario.js +11 -0
  130. package/tests/unit/state/apply/common/balances/validatorEntryUpdateFailureScenario.js +11 -0
  131. package/tests/unit/state/apply/common/balances/validatorNodeEntryDecodeFailureScenario.js +40 -0
  132. package/tests/unit/state/apply/common/base/OperationValidationScenarioBase.js +114 -0
  133. package/tests/unit/state/apply/common/commonScenarioHelper.js +103 -0
  134. package/tests/unit/state/apply/common/indexer/indexerNodeEntryDecodeFailureScenario.js +36 -0
  135. package/tests/unit/state/apply/common/indexer/indexerNodeEntryMissingScenario.js +36 -0
  136. package/tests/unit/state/apply/common/indexer/indexerRoleUpdateFailureScenario.js +29 -0
  137. package/tests/unit/state/apply/common/indexer/indexerSequenceStateInvalidScenario.js +66 -0
  138. package/tests/unit/state/apply/common/invalidMessageComponentValidationScenario.js +84 -0
  139. package/tests/unit/state/apply/common/nodeEntryInitializationFailureScenario.js +47 -0
  140. package/tests/unit/state/apply/common/operationAlreadyAppliedScenario.js +85 -0
  141. package/tests/unit/state/apply/common/payload-structure/addressWithInvalidPublicKeyScenario.js +52 -0
  142. package/tests/unit/state/apply/common/payload-structure/initializationDisabledScenario.js +49 -0
  143. package/tests/unit/state/apply/common/payload-structure/invalidAddressValidationScenario.js +73 -0
  144. package/tests/unit/state/apply/common/payload-structure/invalidHashValidationScenario.js +71 -0
  145. package/tests/unit/state/apply/common/payload-structure/invalidPayloadValidationScenario.js +31 -0
  146. package/tests/unit/state/apply/common/payload-structure/invalidSignatureValidationScenario.js +142 -0
  147. package/tests/unit/state/apply/common/payload-structure/partialOperationValidationScenario.js +87 -0
  148. package/tests/unit/state/apply/common/requester/requesterNodeEntryBufferMissingScenario.js +70 -0
  149. package/tests/unit/state/apply/common/requester/requesterNodeEntryDecodeFailureScenario.js +72 -0
  150. package/tests/unit/state/apply/common/requester/requesterNodeEntryMissingScenario.js +36 -0
  151. package/tests/unit/state/apply/common/requesterAddressValidationScenario.js +44 -0
  152. package/tests/unit/state/apply/common/requesterPublicKeyValidationScenario.js +25 -0
  153. package/tests/unit/state/apply/common/transactionValidityMismatchScenario.js +98 -0
  154. package/tests/unit/state/apply/common/validatorConsistency/base/validatorConsistencyScenarioBase.js +201 -0
  155. package/tests/unit/state/apply/common/validatorConsistency/validatorEntryDecodeFailureScenario.js +17 -0
  156. package/tests/unit/state/apply/common/validatorConsistency/validatorEntryMissingScenario.js +44 -0
  157. package/tests/unit/state/apply/common/validatorConsistency/validatorInactiveScenario.js +19 -0
  158. package/tests/unit/state/apply/common/validatorConsistency/validatorWriterKeyMismatchScenario.js +18 -0
  159. package/tests/unit/state/apply/common/validatorEntryValidation/base/validatorEntryValidationScenarioBase.js +314 -0
  160. package/tests/unit/state/apply/common/validatorEntryValidation/validatorEntryInvalidBalanceScenario.js +18 -0
  161. package/tests/unit/state/apply/common/writerKeyExistsValidationScenario.js +43 -0
  162. package/tests/unit/state/apply/disableInitialization/disableInitializationAlreadyDisabledScenario.js +53 -0
  163. package/tests/unit/state/apply/disableInitialization/disableInitializationHappyPathScenario.js +24 -0
  164. package/tests/unit/state/apply/disableInitialization/disableInitializationScenarioHelpers.js +197 -0
  165. package/tests/unit/state/apply/disableInitialization/state.apply.disableInitialization.test.js +161 -0
  166. package/tests/unit/state/apply/missing-tests.md +18 -0
  167. package/tests/unit/state/apply/removeIndexer/removeIndexerHappyPathScenario.js +58 -0
  168. package/tests/unit/state/apply/removeIndexer/removeIndexerReAddAndRemoveAgainScenario.js +98 -0
  169. package/tests/unit/state/apply/removeIndexer/removeIndexerRemoveMultipleIndexersScenario.js +167 -0
  170. package/tests/unit/state/apply/removeIndexer/removeIndexerScenarioHelpers.js +428 -0
  171. package/tests/unit/state/apply/removeIndexer/removeIndexerTargetNotIndexerScenario.js +22 -0
  172. package/tests/unit/state/apply/removeIndexer/removeIndexerWriterKeyMissingScenario.js +20 -0
  173. package/tests/unit/state/apply/removeIndexer/state.apply.removeIndexer.test.js +291 -0
  174. package/tests/unit/state/apply/removeWriter/removeWriterAndAddWriterAgainScenario.js +87 -0
  175. package/tests/unit/state/apply/removeWriter/removeWriterHappyPathScenario.js +38 -0
  176. package/tests/unit/state/apply/removeWriter/removeWriterInvalidValidatorSignatureScenario.js +32 -0
  177. package/tests/unit/state/apply/removeWriter/removeWriterRequesterBalanceInsufficientScenario.js +21 -0
  178. package/tests/unit/state/apply/removeWriter/removeWriterRequesterEntryDecodeFailureScenario.js +19 -0
  179. package/tests/unit/state/apply/removeWriter/removeWriterRequesterEntryMissingScenario.js +19 -0
  180. package/tests/unit/state/apply/removeWriter/removeWriterRequesterIndexerScenario.js +21 -0
  181. package/tests/unit/state/apply/removeWriter/removeWriterRequesterNotWriterScenario.js +21 -0
  182. package/tests/unit/state/apply/removeWriter/removeWriterRequesterRoleUpdateFailureScenario.js +19 -0
  183. package/tests/unit/state/apply/removeWriter/removeWriterScenarioHelpers.js +344 -0
  184. package/tests/unit/state/apply/removeWriter/removeWriterThroughWriterValidatorScenario.js +113 -0
  185. package/tests/unit/state/apply/removeWriter/removeWriterUnstakeFailureScenario.js +33 -0
  186. package/tests/unit/state/apply/removeWriter/removeWriterWriterKeyMismatchScenario.js +21 -0
  187. package/tests/unit/state/apply/removeWriter/removeWriterWriterKeyOwnershipScenario.js +26 -0
  188. package/tests/unit/state/apply/removeWriter/removeWriterWriterKeyRegistryMissingScenario.js +22 -0
  189. package/tests/unit/state/apply/removeWriter/state.apply.removeWriter.test.js +307 -0
  190. package/tests/unit/state/apply/state.apply.test.js +24 -0
  191. package/tests/unit/state/apply/transfer/state.apply.transfer.test.js +819 -0
  192. package/tests/unit/state/apply/transfer/transferContractSchemaValidationScenario.js +22 -0
  193. package/tests/unit/state/apply/transfer/transferDoubleSpendAcrossValidatorsScenario.js +137 -0
  194. package/tests/unit/state/apply/transfer/transferDoubleSpendSameBatchScenario.js +63 -0
  195. package/tests/unit/state/apply/transfer/transferDoubleSpendSingleValidatorScenario.js +67 -0
  196. package/tests/unit/state/apply/transfer/transferExistingRecipientAmountScenario.js +31 -0
  197. package/tests/unit/state/apply/transfer/transferExistingRecipientZeroAmountScenario.js +31 -0
  198. package/tests/unit/state/apply/transfer/transferHandlerGuardScenarios.js +22 -0
  199. package/tests/unit/state/apply/transfer/transferHappyPathScenario.js +8 -0
  200. package/tests/unit/state/apply/transfer/transferInvalidIncomingDataScenario.js +66 -0
  201. package/tests/unit/state/apply/transfer/transferNewRecipientAmountScenario.js +31 -0
  202. package/tests/unit/state/apply/transfer/transferNewRecipientZeroAmountScenario.js +31 -0
  203. package/tests/unit/state/apply/transfer/transferScenarioHelpers.js +1167 -0
  204. package/tests/unit/state/apply/transfer/transferSelfTransferAmountScenario.js +38 -0
  205. package/tests/unit/state/apply/transfer/transferSelfTransferZeroAmountScenario.js +38 -0
  206. package/tests/unit/state/apply/transfer/transferValidatorRecipientAmountScenario.js +38 -0
  207. package/tests/unit/state/apply/transfer/transferValidatorRecipientZeroAmountScenario.js +38 -0
  208. package/tests/unit/state/apply/txOperation/state.apply.txOperation.test.js +318 -0
  209. package/tests/unit/state/apply/txOperation/txOperationBootstrapNotRegisteredScenario.js +70 -0
  210. package/tests/unit/state/apply/txOperation/txOperationDifferentValidatorCreatorHappyPathScenario.js +23 -0
  211. package/tests/unit/state/apply/txOperation/txOperationInvalidDeploymentEntryScenario.js +48 -0
  212. package/tests/unit/state/apply/txOperation/txOperationInvalidFeeAmountScenario.js +39 -0
  213. package/tests/unit/state/apply/txOperation/txOperationInvalidSubnetCreatorAddressScenario.js +46 -0
  214. package/tests/unit/state/apply/txOperation/txOperationRequesterCreatorHappyPathScenario.js +21 -0
  215. package/tests/unit/state/apply/txOperation/txOperationScenarioHelpers.js +429 -0
  216. package/tests/unit/state/apply/txOperation/txOperationStandardHappyPathScenario.js +21 -0
  217. package/tests/unit/state/apply/txOperation/txOperationTransferFeeAddCreatorBalanceFailureScenario.js +26 -0
  218. package/tests/unit/state/apply/txOperation/txOperationTransferFeeAddValidatorBalanceFailureScenario.js +25 -0
  219. package/tests/unit/state/apply/txOperation/txOperationTransferFeeAddValidatorBonusFailureScenario.js +27 -0
  220. package/tests/unit/state/apply/txOperation/txOperationTransferFeeDecodeCreatorEntryScenario.js +18 -0
  221. package/tests/unit/state/apply/txOperation/txOperationTransferFeeDecodeRequesterEntryScenario.js +17 -0
  222. package/tests/unit/state/apply/txOperation/txOperationTransferFeeDecodeValidatorEntryScenario.js +31 -0
  223. package/tests/unit/state/apply/txOperation/txOperationTransferFeeGuardBypassScenario.js +49 -0
  224. package/tests/unit/state/apply/txOperation/txOperationTransferFeeGuardScenarioFactory.js +92 -0
  225. package/tests/unit/state/apply/txOperation/txOperationTransferFeeInsufficientRequesterBalanceScenario.js +28 -0
  226. package/tests/unit/state/apply/txOperation/txOperationTransferFeeInvalidCreatorBalanceScenario.js +29 -0
  227. package/tests/unit/state/apply/txOperation/txOperationTransferFeeInvalidRequesterBalanceScenario.js +28 -0
  228. package/tests/unit/state/apply/txOperation/txOperationTransferFeeInvalidRequesterEntryScenario.js +17 -0
  229. package/tests/unit/state/apply/txOperation/txOperationTransferFeeInvalidValidatorBalanceScenario.js +33 -0
  230. package/tests/unit/state/apply/txOperation/txOperationTransferFeeMissingCreatorEntryScenario.js +18 -0
  231. package/tests/unit/state/apply/txOperation/txOperationTransferFeeSubtractFailureScenario.js +25 -0
  232. package/tests/unit/state/apply/txOperation/txOperationTransferFeeUpdateCreatorBalanceFailureScenario.js +26 -0
  233. package/tests/unit/state/apply/txOperation/txOperationTransferFeeUpdateFailureScenario.js +25 -0
  234. package/tests/unit/state/apply/txOperation/txOperationTransferFeeUpdateValidatorBalanceFailureScenario.js +26 -0
  235. package/tests/unit/state/apply/txOperation/txOperationTransferFeeUpdateValidatorBonusFailureScenario.js +27 -0
  236. package/tests/unit/state/apply/txOperation/txOperationValidatorCreatorHappyPathScenario.js +21 -0
  237. package/tests/unit/state/stateModule.test.js +1 -0
  238. package/tests/unit/state/stateTestUtils.js +5 -1
  239. package/.env +0 -3
@@ -0,0 +1,307 @@
1
+ import removeWriterHappyPathScenario from './removeWriterHappyPathScenario.js';
2
+ import removeWriterAndAddWriterAgainScenario from './removeWriterAndAddWriterAgainScenario.js';
3
+ import removeWriterThroughWriterValidatorScenario from './removeWriterThroughWriterValidatorScenario.js';
4
+ import removeWriterInvalidValidatorSignatureScenario from './removeWriterInvalidValidatorSignatureScenario.js';
5
+ import removeWriterRequesterEntryMissingScenario from './removeWriterRequesterEntryMissingScenario.js';
6
+ import removeWriterRequesterEntryDecodeFailureScenario from './removeWriterRequesterEntryDecodeFailureScenario.js';
7
+ import removeWriterRequesterNotWriterScenario from './removeWriterRequesterNotWriterScenario.js';
8
+ import removeWriterRequesterIndexerScenario from './removeWriterRequesterIndexerScenario.js';
9
+ import removeWriterRequesterRoleUpdateFailureScenario from './removeWriterRequesterRoleUpdateFailureScenario.js';
10
+ import removeWriterWriterKeyRegistryMissingScenario from './removeWriterWriterKeyRegistryMissingScenario.js';
11
+ import removeWriterWriterKeyMismatchScenario from './removeWriterWriterKeyMismatchScenario.js';
12
+ import removeWriterWriterKeyOwnershipScenario from './removeWriterWriterKeyOwnershipScenario.js';
13
+ import removeWriterUnstakeFailureScenario from './removeWriterUnstakeFailureScenario.js';
14
+ import removeWriterRequesterBalanceInsufficientScenario from './removeWriterRequesterBalanceInsufficientScenario.js';
15
+ import RoleAccessOperationValidationScenario from '../common/access-control/roleAccessOperationValidationScenario.js';
16
+ import RequesterAddressValidationScenario from '../common/requesterAddressValidationScenario.js';
17
+ import createRequesterPublicKeyValidationScenario from '../common/requesterPublicKeyValidationScenario.js';
18
+ import PartialOperationValidationScenario, {
19
+ PartialOperationMutationStrategy
20
+ } from '../common/payload-structure/partialOperationValidationScenario.js';
21
+ import InvalidHashValidationScenario from '../common/payload-structure/invalidHashValidationScenario.js';
22
+ import InvalidSignatureValidationScenario, {
23
+ SignatureMutationStrategy
24
+ } from '../common/payload-structure/invalidSignatureValidationScenario.js';
25
+ import InvalidAddressValidationScenario from '../common/payload-structure/invalidAddressValidationScenario.js';
26
+ import createAddressWithInvalidPublicKeyScenario from '../common/payload-structure/addressWithInvalidPublicKeyScenario.js';
27
+ import TransactionValidityMismatchScenario from '../common/transactionValidityMismatchScenario.js';
28
+ import IndexerSequenceStateInvalidScenario from '../common/indexer/indexerSequenceStateInvalidScenario.js';
29
+ import OperationAlreadyAppliedScenario from '../common/operationAlreadyAppliedScenario.js';
30
+ import RequesterBalanceDecodeFailureScenario from '../common/balances/requesterBalanceDecodeFailureScenario.js';
31
+ import RequesterBalanceFeeApplicationFailureScenario from '../common/balances/requesterBalanceFeeApplicationFailureScenario.js';
32
+ import RequesterBalanceUpdateFailureScenario from '../common/balances/requesterBalanceUpdateFailureScenario.js';
33
+ import ValidatorEntryMissingScenario from '../common/validatorConsistency/validatorEntryMissingScenario.js';
34
+ import ValidatorEntryDecodeFailureScenario from '../common/validatorConsistency/validatorEntryDecodeFailureScenario.js';
35
+ import ValidatorInactiveScenario from '../common/validatorConsistency/validatorInactiveScenario.js';
36
+ import ValidatorWriterKeyMismatchScenario from '../common/validatorConsistency/validatorWriterKeyMismatchScenario.js';
37
+ import ValidatorEntryInvalidBalanceScenario from '../common/validatorEntryValidation/validatorEntryInvalidBalanceScenario.js';
38
+ import ValidatorEntryRewardFailureScenario from '../common/balances/validatorEntryRewardFailureScenario.js';
39
+ import ValidatorEntryUpdateFailureScenario from '../common/balances/validatorEntryUpdateFailureScenario.js';
40
+ import {
41
+ setupRemoveWriterScenario,
42
+ buildRemoveWriterPayload,
43
+ buildRemoveWriterPayloadWithTxValidity,
44
+ assertRemoveWriterFailureState,
45
+ snapshotDowngradedWriterEntry,
46
+ assertDowngradedWriterSnapshot,
47
+ selectWriterPeer
48
+ } from './removeWriterScenarioHelpers.js';
49
+ import {
50
+ applyWithMissingComponentBypass,
51
+ selectValidatorPeerWithoutEntry
52
+ } from '../addWriter/addWriterScenarioHelpers.js';
53
+
54
+ removeWriterHappyPathScenario();
55
+ removeWriterAndAddWriterAgainScenario();
56
+ removeWriterThroughWriterValidatorScenario();
57
+
58
+ new RoleAccessOperationValidationScenario({
59
+ title: 'State.apply removeWriter rejects payloads when contract schema validation fails',
60
+ setupScenario: setupRemoveWriterScenario,
61
+ buildValidPayload: context => buildRemoveWriterPayload(context),
62
+ assertStateUnchanged: assertRemoveWriterFailureState,
63
+ expectedLogs: ['Contract schema validation failed.']
64
+ }).performScenario();
65
+
66
+ new PartialOperationValidationScenario({
67
+ title: 'State.apply removeWriter rejects incomplete validator co-signatures',
68
+ setupScenario: setupRemoveWriterScenario,
69
+ buildValidPayload: context => buildRemoveWriterPayload(context),
70
+ assertStateUnchanged: assertRemoveWriterFailureState,
71
+ strategy: PartialOperationMutationStrategy.MISSING_COMPONENT,
72
+ parentKey: 'rao',
73
+ applyInvalidPayload: applyWithMissingComponentBypass,
74
+ expectedLogs: ['Operation is not complete.']
75
+ }).performScenario();
76
+
77
+ new PartialOperationValidationScenario({
78
+ title: 'State.apply removeWriter rejects payloads when nonces match',
79
+ setupScenario: setupRemoveWriterScenario,
80
+ buildValidPayload: context => buildRemoveWriterPayload(context),
81
+ assertStateUnchanged: assertRemoveWriterFailureState,
82
+ strategy: PartialOperationMutationStrategy.NONCE_MATCH,
83
+ parentKey: 'rao',
84
+ expectedLogs: ['Nonces should not be the same.']
85
+ }).performScenario();
86
+
87
+ new PartialOperationValidationScenario({
88
+ title: 'State.apply removeWriter rejects payloads when validator shares requester address',
89
+ setupScenario: setupRemoveWriterScenario,
90
+ buildValidPayload: context => buildRemoveWriterPayload(context),
91
+ assertStateUnchanged: assertRemoveWriterFailureState,
92
+ strategy: PartialOperationMutationStrategy.ADDRESS_MATCH,
93
+ parentKey: 'rao',
94
+ expectedLogs: ['Addresses should be different.']
95
+ }).performScenario();
96
+
97
+ new PartialOperationValidationScenario({
98
+ title: 'State.apply removeWriter rejects payloads when validator signature duplicates requester signature',
99
+ setupScenario: setupRemoveWriterScenario,
100
+ buildValidPayload: context => buildRemoveWriterPayload(context),
101
+ assertStateUnchanged: assertRemoveWriterFailureState,
102
+ strategy: PartialOperationMutationStrategy.SIGNATURE_MATCH,
103
+ parentKey: 'rao',
104
+ expectedLogs: ['Signatures should be different.']
105
+ }).performScenario();
106
+
107
+ new RequesterAddressValidationScenario({
108
+ title: 'State.apply removeWriter rejects payloads when requester address is invalid',
109
+ setupScenario: setupRemoveWriterScenario,
110
+ buildValidPayload: context => buildRemoveWriterPayload(context),
111
+ assertStateUnchanged: assertRemoveWriterFailureState,
112
+ expectedLogs: ['Requester address is invalid.']
113
+ }).performScenario();
114
+
115
+ createRequesterPublicKeyValidationScenario({
116
+ title: 'State.apply removeWriter rejects payloads when requester public key is invalid',
117
+ setupScenario: setupRemoveWriterScenario,
118
+ buildValidPayload: context => buildRemoveWriterPayload(context),
119
+ assertStateUnchanged: assertRemoveWriterFailureState,
120
+ expectedLogs: ['Error while decoding requester public key.']
121
+ }).performScenario();
122
+
123
+ new InvalidHashValidationScenario({
124
+ title: 'State.apply removeWriter rejects payloads when requester message hash mismatches',
125
+ setupScenario: setupRemoveWriterScenario,
126
+ buildValidPayload: context => buildRemoveWriterPayload(context),
127
+ assertStateUnchanged: assertRemoveWriterFailureState,
128
+ expectedLogs: ['Message hash does not match the tx_hash.']
129
+ }).performScenario();
130
+
131
+ new InvalidSignatureValidationScenario({
132
+ title: 'State.apply removeWriter rejects payloads when requester signature is invalid (foreign signature)',
133
+ setupScenario: setupRemoveWriterScenario,
134
+ buildValidPayload: context => buildRemoveWriterPayload(context),
135
+ assertStateUnchanged: assertRemoveWriterFailureState,
136
+ expectedLogs: ['Failed to verify message signature.']
137
+ }).performScenario();
138
+
139
+ new InvalidSignatureValidationScenario({
140
+ title: 'State.apply removeWriter rejects payloads when requester signature is invalid (zero fill)',
141
+ setupScenario: setupRemoveWriterScenario,
142
+ buildValidPayload: context => buildRemoveWriterPayload(context),
143
+ assertStateUnchanged: assertRemoveWriterFailureState,
144
+ strategy: SignatureMutationStrategy.ZERO_FILL,
145
+ expectedLogs: ['Failed to verify message signature.']
146
+ }).performScenario();
147
+
148
+ new InvalidSignatureValidationScenario({
149
+ title: 'State.apply removeWriter rejects payloads when requester signature is invalid (type mismatch)',
150
+ setupScenario: setupRemoveWriterScenario,
151
+ buildValidPayload: context => buildRemoveWriterPayload(context),
152
+ assertStateUnchanged: assertRemoveWriterFailureState,
153
+ strategy: SignatureMutationStrategy.TYPE_MISMATCH,
154
+ expectedLogs: ['Failed to verify message signature.']
155
+ }).performScenario();
156
+
157
+ new InvalidAddressValidationScenario({
158
+ title: 'State.apply removeWriter rejects payloads when validator address is invalid',
159
+ setupScenario: setupRemoveWriterScenario,
160
+ buildValidPayload: context => buildRemoveWriterPayload(context),
161
+ assertStateUnchanged: assertRemoveWriterFailureState,
162
+ addressPath: ['rao', 'va'],
163
+ expectedLogs: ['Failed to verify validator address.']
164
+ }).performScenario();
165
+
166
+ createAddressWithInvalidPublicKeyScenario({
167
+ title: 'State.apply removeWriter rejects payloads when validator public key is invalid',
168
+ setupScenario: setupRemoveWriterScenario,
169
+ buildValidPayload: context => buildRemoveWriterPayload(context),
170
+ assertStateUnchanged: assertRemoveWriterFailureState,
171
+ addressPath: ['rao', 'va'],
172
+ expectedLogs: ['Failed to decode validator public key.']
173
+ }).performScenario();
174
+
175
+ removeWriterInvalidValidatorSignatureScenario();
176
+
177
+ new IndexerSequenceStateInvalidScenario({
178
+ title: 'State.apply removeWriter rejects payloads when indexer sequence state is invalid',
179
+ setupScenario: setupRemoveWriterScenario,
180
+ buildValidPayload: context => buildRemoveWriterPayload(context),
181
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
182
+ expectedLogs: ['Indexer sequence state is invalid.']
183
+ }).performScenario();
184
+
185
+ new TransactionValidityMismatchScenario({
186
+ title: 'State.apply removeWriter rejects payloads when tx validity mismatches indexer state',
187
+ setupScenario: setupRemoveWriterScenario,
188
+ buildValidPayload: context => buildRemoveWriterPayload(context),
189
+ assertStateUnchanged: assertRemoveWriterFailureState,
190
+ txValidityPath: ['rao', 'txv'],
191
+ rebuildPayloadWithTxValidity: ({ context, mutatedTxValidity }) =>
192
+ buildRemoveWriterPayloadWithTxValidity(context, mutatedTxValidity),
193
+ expectedLogs: ['Transaction was not executed.']
194
+ }).performScenario();
195
+
196
+ new ValidatorEntryMissingScenario({
197
+ title: 'State.apply removeWriter rejects payloads when validator entry is missing',
198
+ setupScenario: t => setupRemoveWriterScenario(t, { nodes: 3 }),
199
+ buildValidPayload: context => {
200
+ const validatorPeer = selectValidatorPeerWithoutEntry(context);
201
+ if (!validatorPeer) {
202
+ throw new Error('Validator entry missing scenario requires an extra peer.');
203
+ }
204
+ return buildRemoveWriterPayload(context, { validatorPeer });
205
+ },
206
+ assertStateUnchanged: assertRemoveWriterFailureState,
207
+ expectedLogs: ['Incoming validator entry is null.']
208
+ }).performScenario();
209
+
210
+ new ValidatorEntryDecodeFailureScenario({
211
+ title: 'State.apply removeWriter rejects payloads when validator entry cannot be decoded',
212
+ setupScenario: setupRemoveWriterScenario,
213
+ buildValidPayload: context => buildRemoveWriterPayload(context),
214
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
215
+ expectedLogs: ['Failed to decode validator entry.']
216
+ }).performScenario();
217
+
218
+ new ValidatorInactiveScenario({
219
+ title: 'State.apply removeWriter rejects payloads when validator is not an active writer',
220
+ setupScenario: setupRemoveWriterScenario,
221
+ buildValidPayload: context => buildRemoveWriterPayload(context),
222
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
223
+ expectedLogs: ['Operation validator is not active']
224
+ }).performScenario();
225
+
226
+ new ValidatorWriterKeyMismatchScenario({
227
+ title: 'State.apply removeWriter rejects payloads when validator writer key mismatches requester',
228
+ setupScenario: setupRemoveWriterScenario,
229
+ buildValidPayload: context => buildRemoveWriterPayload(context),
230
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
231
+ expectedLogs: ['Validator cannot be the same as requester.']
232
+ }).performScenario();
233
+
234
+ new OperationAlreadyAppliedScenario({
235
+ title: 'State.apply removeWriter rejects duplicate operations',
236
+ setupScenario: setupRemoveWriterScenario,
237
+ buildValidPayload: context => buildRemoveWriterPayload(context),
238
+ beforeInvalidApply: async ({ context }) => {
239
+ await snapshotDowngradedWriterEntry(context);
240
+ },
241
+ assertStateUnchanged: (t, context) => assertDowngradedWriterSnapshot(t, context),
242
+ expectedLogs: ['Operation has already been applied.']
243
+ }).performScenario();
244
+
245
+ removeWriterRequesterEntryMissingScenario();
246
+ removeWriterRequesterEntryDecodeFailureScenario();
247
+
248
+ removeWriterRequesterNotWriterScenario();
249
+ removeWriterRequesterIndexerScenario();
250
+ removeWriterWriterKeyRegistryMissingScenario();
251
+ removeWriterWriterKeyMismatchScenario();
252
+ removeWriterWriterKeyOwnershipScenario();
253
+ removeWriterUnstakeFailureScenario();
254
+
255
+ new RequesterBalanceDecodeFailureScenario({
256
+ title: 'State.apply removeWriter rejects payloads when requester balance cannot be verified',
257
+ setupScenario: setupRemoveWriterScenario,
258
+ buildValidPayload: context => buildRemoveWriterPayload(context),
259
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
260
+ selectPeer: selectWriterPeer,
261
+ expectedLogs: ['Invalid requester balance.']
262
+ }).performScenario();
263
+
264
+ removeWriterRequesterBalanceInsufficientScenario();
265
+
266
+ new RequesterBalanceFeeApplicationFailureScenario({
267
+ title: 'State.apply removeWriter rejects payloads when fee cannot be applied to requester balance',
268
+ setupScenario: setupRemoveWriterScenario,
269
+ buildValidPayload: context => buildRemoveWriterPayload(context),
270
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
271
+ selectPeer: selectWriterPeer,
272
+ expectedLogs: ['Failed to apply fee to requester balance.']
273
+ }).performScenario();
274
+
275
+ removeWriterRequesterRoleUpdateFailureScenario();
276
+
277
+ new RequesterBalanceUpdateFailureScenario({
278
+ title: 'State.apply removeWriter rejects payloads when requester balance cannot be updated',
279
+ setupScenario: setupRemoveWriterScenario,
280
+ buildValidPayload: context => buildRemoveWriterPayload(context),
281
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
282
+ selectPeer: selectWriterPeer,
283
+ expectedLogs: ['Failed to update node balance.']
284
+ }).performScenario();
285
+
286
+ new ValidatorEntryInvalidBalanceScenario({
287
+ title: 'State.apply removeWriter rejects payloads when validator balance is invalid',
288
+ setupScenario: setupRemoveWriterScenario,
289
+ buildValidPayload: context => buildRemoveWriterPayload(context),
290
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true })
291
+ }).performScenario();
292
+
293
+ new ValidatorEntryRewardFailureScenario({
294
+ title: 'State.apply removeWriter rejects payloads when validator fee transfer fails',
295
+ setupScenario: setupRemoveWriterScenario,
296
+ buildValidPayload: context => buildRemoveWriterPayload(context),
297
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
298
+ expectedLogs: ['Failed to transfer fee to validator balance.']
299
+ }).performScenario();
300
+
301
+ new ValidatorEntryUpdateFailureScenario({
302
+ title: 'State.apply removeWriter rejects payloads when validator balance update fails',
303
+ setupScenario: setupRemoveWriterScenario,
304
+ buildValidPayload: context => buildRemoveWriterPayload(context),
305
+ assertStateUnchanged: (t, context) => assertRemoveWriterFailureState(t, context, { skipSync: true }),
306
+ expectedLogs: ['Failed to update validator balance.']
307
+ }).performScenario();
@@ -0,0 +1,24 @@
1
+ import { default as test } from 'brittle';
2
+ /**
3
+ * Note: This is not possible to cover tests with when indexer Sequence returns null. Hyperbee is shoting with errors,
4
+ * if someone will try to do it then, this person will hack itself.
5
+ */
6
+ async function runStateTests() {
7
+ test.pause();
8
+ await import('./addAdmin/state.apply.addAdmin.test.js');
9
+ await import('./balanceInitialization/state.apply.balanceInitialization.test.js');
10
+ await import('./disableInitialization/state.apply.disableInitialization.test.js');
11
+ await import('./appendWhitelist/state.apply.appendWhitelist.test.js');
12
+ await import('./addWriter/state.apply.addWriter.test.js');
13
+ await import('./removeWriter/state.apply.removeWriter.test.js');
14
+ await import('./addIndexer/state.apply.addIndexer.test.js');
15
+ await import('./removeIndexer/state.apply.removeIndexer.test.js');
16
+ await import('./banValidator/state.apply.banValidator.test.js');
17
+ await import('./bootstrapDeployment/state.apply.bootstrapDeployment.test.js')
18
+ await import('./txOperation/state.apply.txOperation.test.js');
19
+ await import('./transfer/state.apply.transfer.test.js');
20
+ await import('./adminRecovery/state.apply.adminRecovery.test.js');
21
+ test.resume();
22
+ }
23
+
24
+ runStateTests();