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