@originals/sdk 1.2.0 → 1.4.3
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/package.json +4 -1
- package/.eslintrc.json +0 -33
- package/.turbo/turbo-build.log +0 -1
- package/dist/adapters/FeeOracleMock.d.ts +0 -6
- package/dist/adapters/FeeOracleMock.js +0 -8
- package/dist/adapters/index.d.ts +0 -4
- package/dist/adapters/index.js +0 -4
- package/dist/adapters/providers/OrdHttpProvider.d.ts +0 -56
- package/dist/adapters/providers/OrdHttpProvider.js +0 -110
- package/dist/adapters/providers/OrdMockProvider.d.ts +0 -70
- package/dist/adapters/providers/OrdMockProvider.js +0 -75
- package/dist/adapters/types.d.ts +0 -71
- package/dist/adapters/types.js +0 -1
- package/dist/bitcoin/BitcoinManager.d.ts +0 -15
- package/dist/bitcoin/BitcoinManager.js +0 -262
- package/dist/bitcoin/BroadcastClient.d.ts +0 -30
- package/dist/bitcoin/BroadcastClient.js +0 -35
- package/dist/bitcoin/OrdinalsClient.d.ts +0 -21
- package/dist/bitcoin/OrdinalsClient.js +0 -105
- package/dist/bitcoin/PSBTBuilder.d.ts +0 -24
- package/dist/bitcoin/PSBTBuilder.js +0 -80
- package/dist/bitcoin/fee-calculation.d.ts +0 -14
- package/dist/bitcoin/fee-calculation.js +0 -31
- package/dist/bitcoin/providers/OrdNodeProvider.d.ts +0 -38
- package/dist/bitcoin/providers/OrdNodeProvider.js +0 -67
- package/dist/bitcoin/providers/OrdinalsProvider.d.ts +0 -33
- package/dist/bitcoin/providers/OrdinalsProvider.js +0 -50
- package/dist/bitcoin/providers/types.d.ts +0 -63
- package/dist/bitcoin/providers/types.js +0 -1
- package/dist/bitcoin/transactions/commit.d.ts +0 -89
- package/dist/bitcoin/transactions/commit.js +0 -311
- package/dist/bitcoin/transactions/index.d.ts +0 -7
- package/dist/bitcoin/transactions/index.js +0 -8
- package/dist/bitcoin/transfer.d.ts +0 -9
- package/dist/bitcoin/transfer.js +0 -26
- package/dist/bitcoin/utxo-selection.d.ts +0 -78
- package/dist/bitcoin/utxo-selection.js +0 -237
- package/dist/bitcoin/utxo.d.ts +0 -26
- package/dist/bitcoin/utxo.js +0 -78
- package/dist/contexts/credentials-v1.json +0 -195
- package/dist/contexts/credentials-v2-examples.json +0 -5
- package/dist/contexts/credentials-v2.json +0 -301
- package/dist/contexts/credentials.json +0 -195
- package/dist/contexts/data-integrity-v2.json +0 -81
- package/dist/contexts/dids.json +0 -57
- package/dist/contexts/ed255192020.json +0 -93
- package/dist/contexts/ordinals-plus.json +0 -23
- package/dist/contexts/originals.json +0 -22
- package/dist/core/OriginalsSDK.d.ts +0 -158
- package/dist/core/OriginalsSDK.js +0 -274
- package/dist/crypto/Multikey.d.ts +0 -30
- package/dist/crypto/Multikey.js +0 -149
- package/dist/crypto/Signer.d.ts +0 -21
- package/dist/crypto/Signer.js +0 -196
- package/dist/crypto/noble-init.d.ts +0 -18
- package/dist/crypto/noble-init.js +0 -106
- package/dist/did/BtcoDidResolver.d.ts +0 -57
- package/dist/did/BtcoDidResolver.js +0 -166
- package/dist/did/DIDManager.d.ts +0 -101
- package/dist/did/DIDManager.js +0 -493
- package/dist/did/Ed25519Verifier.d.ts +0 -30
- package/dist/did/Ed25519Verifier.js +0 -59
- package/dist/did/KeyManager.d.ts +0 -17
- package/dist/did/KeyManager.js +0 -207
- package/dist/did/WebVHManager.d.ts +0 -100
- package/dist/did/WebVHManager.js +0 -304
- package/dist/did/createBtcoDidDocument.d.ts +0 -10
- package/dist/did/createBtcoDidDocument.js +0 -42
- package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +0 -23
- package/dist/did/providers/OrdinalsClientProviderAdapter.js +0 -51
- package/dist/events/EventEmitter.d.ts +0 -115
- package/dist/events/EventEmitter.js +0 -198
- package/dist/events/index.d.ts +0 -7
- package/dist/events/index.js +0 -6
- package/dist/events/types.d.ts +0 -286
- package/dist/events/types.js +0 -9
- package/dist/examples/basic-usage.d.ts +0 -3
- package/dist/examples/basic-usage.js +0 -62
- package/dist/examples/run.d.ts +0 -1
- package/dist/examples/run.js +0 -4
- package/dist/index.d.ts +0 -39
- package/dist/index.js +0 -47
- package/dist/lifecycle/BatchOperations.d.ts +0 -147
- package/dist/lifecycle/BatchOperations.js +0 -251
- package/dist/lifecycle/LifecycleManager.d.ts +0 -116
- package/dist/lifecycle/LifecycleManager.js +0 -971
- package/dist/lifecycle/OriginalsAsset.d.ts +0 -164
- package/dist/lifecycle/OriginalsAsset.js +0 -380
- package/dist/lifecycle/ProvenanceQuery.d.ts +0 -126
- package/dist/lifecycle/ProvenanceQuery.js +0 -220
- package/dist/lifecycle/ResourceVersioning.d.ts +0 -73
- package/dist/lifecycle/ResourceVersioning.js +0 -127
- package/dist/migration/MigrationManager.d.ts +0 -86
- package/dist/migration/MigrationManager.js +0 -412
- package/dist/migration/audit/AuditLogger.d.ts +0 -51
- package/dist/migration/audit/AuditLogger.js +0 -156
- package/dist/migration/checkpoint/CheckpointManager.d.ts +0 -31
- package/dist/migration/checkpoint/CheckpointManager.js +0 -96
- package/dist/migration/checkpoint/CheckpointStorage.d.ts +0 -26
- package/dist/migration/checkpoint/CheckpointStorage.js +0 -89
- package/dist/migration/index.d.ts +0 -22
- package/dist/migration/index.js +0 -27
- package/dist/migration/operations/BaseMigration.d.ts +0 -48
- package/dist/migration/operations/BaseMigration.js +0 -83
- package/dist/migration/operations/PeerToBtcoMigration.d.ts +0 -25
- package/dist/migration/operations/PeerToBtcoMigration.js +0 -67
- package/dist/migration/operations/PeerToWebvhMigration.d.ts +0 -19
- package/dist/migration/operations/PeerToWebvhMigration.js +0 -46
- package/dist/migration/operations/WebvhToBtcoMigration.d.ts +0 -25
- package/dist/migration/operations/WebvhToBtcoMigration.js +0 -67
- package/dist/migration/rollback/RollbackManager.d.ts +0 -29
- package/dist/migration/rollback/RollbackManager.js +0 -146
- package/dist/migration/state/StateMachine.d.ts +0 -25
- package/dist/migration/state/StateMachine.js +0 -76
- package/dist/migration/state/StateTracker.d.ts +0 -36
- package/dist/migration/state/StateTracker.js +0 -123
- package/dist/migration/types.d.ts +0 -306
- package/dist/migration/types.js +0 -33
- package/dist/migration/validation/BitcoinValidator.d.ts +0 -13
- package/dist/migration/validation/BitcoinValidator.js +0 -83
- package/dist/migration/validation/CredentialValidator.d.ts +0 -13
- package/dist/migration/validation/CredentialValidator.js +0 -46
- package/dist/migration/validation/DIDCompatibilityValidator.d.ts +0 -16
- package/dist/migration/validation/DIDCompatibilityValidator.js +0 -127
- package/dist/migration/validation/LifecycleValidator.d.ts +0 -10
- package/dist/migration/validation/LifecycleValidator.js +0 -52
- package/dist/migration/validation/StorageValidator.d.ts +0 -10
- package/dist/migration/validation/StorageValidator.js +0 -65
- package/dist/migration/validation/ValidationPipeline.d.ts +0 -29
- package/dist/migration/validation/ValidationPipeline.js +0 -180
- package/dist/storage/LocalStorageAdapter.d.ts +0 -11
- package/dist/storage/LocalStorageAdapter.js +0 -53
- package/dist/storage/MemoryStorageAdapter.d.ts +0 -6
- package/dist/storage/MemoryStorageAdapter.js +0 -21
- package/dist/storage/StorageAdapter.d.ts +0 -16
- package/dist/storage/StorageAdapter.js +0 -1
- package/dist/storage/index.d.ts +0 -2
- package/dist/storage/index.js +0 -2
- package/dist/types/bitcoin.d.ts +0 -84
- package/dist/types/bitcoin.js +0 -1
- package/dist/types/common.d.ts +0 -82
- package/dist/types/common.js +0 -1
- package/dist/types/credentials.d.ts +0 -75
- package/dist/types/credentials.js +0 -1
- package/dist/types/did.d.ts +0 -26
- package/dist/types/did.js +0 -1
- package/dist/types/index.d.ts +0 -5
- package/dist/types/index.js +0 -5
- package/dist/types/network.d.ts +0 -78
- package/dist/types/network.js +0 -145
- package/dist/utils/EventLogger.d.ts +0 -71
- package/dist/utils/EventLogger.js +0 -232
- package/dist/utils/Logger.d.ts +0 -106
- package/dist/utils/Logger.js +0 -257
- package/dist/utils/MetricsCollector.d.ts +0 -110
- package/dist/utils/MetricsCollector.js +0 -264
- package/dist/utils/bitcoin-address.d.ts +0 -38
- package/dist/utils/bitcoin-address.js +0 -113
- package/dist/utils/cbor.d.ts +0 -2
- package/dist/utils/cbor.js +0 -9
- package/dist/utils/encoding.d.ts +0 -37
- package/dist/utils/encoding.js +0 -120
- package/dist/utils/hash.d.ts +0 -1
- package/dist/utils/hash.js +0 -5
- package/dist/utils/retry.d.ts +0 -10
- package/dist/utils/retry.js +0 -35
- package/dist/utils/satoshi-validation.d.ts +0 -60
- package/dist/utils/satoshi-validation.js +0 -156
- package/dist/utils/serialization.d.ts +0 -14
- package/dist/utils/serialization.js +0 -76
- package/dist/utils/telemetry.d.ts +0 -17
- package/dist/utils/telemetry.js +0 -24
- package/dist/utils/validation.d.ts +0 -5
- package/dist/utils/validation.js +0 -98
- package/dist/vc/CredentialManager.d.ts +0 -22
- package/dist/vc/CredentialManager.js +0 -227
- package/dist/vc/Issuer.d.ts +0 -27
- package/dist/vc/Issuer.js +0 -70
- package/dist/vc/Verifier.d.ts +0 -16
- package/dist/vc/Verifier.js +0 -50
- package/dist/vc/cryptosuites/bbs.d.ts +0 -44
- package/dist/vc/cryptosuites/bbs.js +0 -213
- package/dist/vc/cryptosuites/bbsSimple.d.ts +0 -9
- package/dist/vc/cryptosuites/bbsSimple.js +0 -12
- package/dist/vc/cryptosuites/eddsa.d.ts +0 -30
- package/dist/vc/cryptosuites/eddsa.js +0 -81
- package/dist/vc/documentLoader.d.ts +0 -16
- package/dist/vc/documentLoader.js +0 -59
- package/dist/vc/proofs/data-integrity.d.ts +0 -21
- package/dist/vc/proofs/data-integrity.js +0 -15
- package/dist/vc/utils/jsonld.d.ts +0 -2
- package/dist/vc/utils/jsonld.js +0 -15
- package/src/adapters/FeeOracleMock.ts +0 -9
- package/src/adapters/index.ts +0 -5
- package/src/adapters/providers/OrdHttpProvider.ts +0 -126
- package/src/adapters/providers/OrdMockProvider.ts +0 -101
- package/src/adapters/types.ts +0 -66
- package/src/bitcoin/BitcoinManager.ts +0 -330
- package/src/bitcoin/BroadcastClient.ts +0 -54
- package/src/bitcoin/OrdinalsClient.ts +0 -119
- package/src/bitcoin/PSBTBuilder.ts +0 -106
- package/src/bitcoin/fee-calculation.ts +0 -38
- package/src/bitcoin/providers/OrdNodeProvider.ts +0 -92
- package/src/bitcoin/providers/OrdinalsProvider.ts +0 -56
- package/src/bitcoin/providers/types.ts +0 -59
- package/src/bitcoin/transactions/commit.ts +0 -465
- package/src/bitcoin/transactions/index.ts +0 -13
- package/src/bitcoin/transfer.ts +0 -43
- package/src/bitcoin/utxo-selection.ts +0 -322
- package/src/bitcoin/utxo.ts +0 -113
- package/src/contexts/credentials-v1.json +0 -237
- package/src/contexts/credentials-v2-examples.json +0 -5
- package/src/contexts/credentials-v2.json +0 -340
- package/src/contexts/credentials.json +0 -237
- package/src/contexts/data-integrity-v2.json +0 -81
- package/src/contexts/dids.json +0 -58
- package/src/contexts/ed255192020.json +0 -93
- package/src/contexts/ordinals-plus.json +0 -23
- package/src/contexts/originals.json +0 -22
- package/src/core/OriginalsSDK.ts +0 -416
- package/src/crypto/Multikey.ts +0 -194
- package/src/crypto/Signer.ts +0 -254
- package/src/crypto/noble-init.ts +0 -121
- package/src/did/BtcoDidResolver.ts +0 -227
- package/src/did/DIDManager.ts +0 -694
- package/src/did/Ed25519Verifier.ts +0 -68
- package/src/did/KeyManager.ts +0 -236
- package/src/did/WebVHManager.ts +0 -489
- package/src/did/createBtcoDidDocument.ts +0 -59
- package/src/did/providers/OrdinalsClientProviderAdapter.ts +0 -68
- package/src/events/EventEmitter.ts +0 -222
- package/src/events/index.ts +0 -19
- package/src/events/types.ts +0 -331
- package/src/examples/basic-usage.ts +0 -78
- package/src/examples/run.ts +0 -5
- package/src/index.ts +0 -84
- package/src/lifecycle/BatchOperations.ts +0 -373
- package/src/lifecycle/LifecycleManager.ts +0 -1218
- package/src/lifecycle/OriginalsAsset.ts +0 -524
- package/src/lifecycle/ProvenanceQuery.ts +0 -280
- package/src/lifecycle/ResourceVersioning.ts +0 -163
- package/src/migration/MigrationManager.ts +0 -527
- package/src/migration/audit/AuditLogger.ts +0 -176
- package/src/migration/checkpoint/CheckpointManager.ts +0 -112
- package/src/migration/checkpoint/CheckpointStorage.ts +0 -101
- package/src/migration/index.ts +0 -33
- package/src/migration/operations/BaseMigration.ts +0 -126
- package/src/migration/operations/PeerToBtcoMigration.ts +0 -105
- package/src/migration/operations/PeerToWebvhMigration.ts +0 -62
- package/src/migration/operations/WebvhToBtcoMigration.ts +0 -105
- package/src/migration/rollback/RollbackManager.ts +0 -170
- package/src/migration/state/StateMachine.ts +0 -92
- package/src/migration/state/StateTracker.ts +0 -156
- package/src/migration/types.ts +0 -344
- package/src/migration/validation/BitcoinValidator.ts +0 -107
- package/src/migration/validation/CredentialValidator.ts +0 -62
- package/src/migration/validation/DIDCompatibilityValidator.ts +0 -151
- package/src/migration/validation/LifecycleValidator.ts +0 -64
- package/src/migration/validation/StorageValidator.ts +0 -79
- package/src/migration/validation/ValidationPipeline.ts +0 -213
- package/src/storage/LocalStorageAdapter.ts +0 -61
- package/src/storage/MemoryStorageAdapter.ts +0 -29
- package/src/storage/StorageAdapter.ts +0 -25
- package/src/storage/index.ts +0 -3
- package/src/types/bitcoin.ts +0 -98
- package/src/types/common.ts +0 -92
- package/src/types/credentials.ts +0 -88
- package/src/types/did.ts +0 -31
- package/src/types/external-shims.d.ts +0 -53
- package/src/types/index.ts +0 -7
- package/src/types/network.ts +0 -175
- package/src/utils/EventLogger.ts +0 -298
- package/src/utils/Logger.ts +0 -322
- package/src/utils/MetricsCollector.ts +0 -358
- package/src/utils/bitcoin-address.ts +0 -130
- package/src/utils/cbor.ts +0 -12
- package/src/utils/encoding.ts +0 -127
- package/src/utils/hash.ts +0 -6
- package/src/utils/retry.ts +0 -46
- package/src/utils/satoshi-validation.ts +0 -196
- package/src/utils/serialization.ts +0 -96
- package/src/utils/telemetry.ts +0 -40
- package/src/utils/validation.ts +0 -119
- package/src/vc/CredentialManager.ts +0 -273
- package/src/vc/Issuer.ts +0 -100
- package/src/vc/Verifier.ts +0 -47
- package/src/vc/cryptosuites/bbs.ts +0 -253
- package/src/vc/cryptosuites/bbsSimple.ts +0 -21
- package/src/vc/cryptosuites/eddsa.ts +0 -99
- package/src/vc/documentLoader.ts +0 -67
- package/src/vc/proofs/data-integrity.ts +0 -33
- package/src/vc/utils/jsonld.ts +0 -18
- package/test/logs/did_webvh_QmNTn9Kkp8dQ75WrF9xqJ2kuDp9QhKc3aPiERRMj8XoTBN_example_com.jsonl +0 -1
- package/test/logs/did_webvh_QmNu4MNr8Lr5txx5gYNhuhZDchXsZEu3hJXKYuphpWTPDp_example_com_users_etc_passwd.jsonl +0 -1
- package/test/logs/did_webvh_QmR9MrGZACzjKETA8SBRNCKG11HxU85c4bVR2qN5eDCfsD_example_com.jsonl +0 -1
- package/test/logs/did_webvh_QmUc5suaqRM2P4nrXxZwqYMfqzhdMqjuL7oJaJbEpCQVCd_example_com_users_etc_passwd.jsonl +0 -1
- package/test/logs/did_webvh_QmUkiB2RCV2VZ1RTXsCebWN25Eiy9TLvpzDWAJNjhgvB4X_example_com_etc_passwd.jsonl +0 -1
- package/test/logs/did_webvh_QmUoRTe8UMwpAQXZSAW7pjAgZK1tq2X3C6Kfxq3UXGcaGy_example_com_secret.jsonl +0 -1
- package/test/logs/did_webvh_QmWWot3chx1t6KwTmcE5i2FeDZ5JMkQw3qXycsKDVmJ9Be_example_com_users_alice.jsonl +0 -1
- package/test/logs/did_webvh_QmWvVgALL5kjZdpgR7KZay7J8UiiUr834kkRmWeFAxjAuC_example_com_users_etc_passwd.jsonl +0 -1
- package/test/logs/did_webvh_QmWwaRQHUZAFcKihFC6xR6tRTTrQhHPTku6azf1egWbpy1_example_com_users_alice.jsonl +0 -1
- package/test/logs/did_webvh_QmXJLtkz23r7AozbtXsZMKWnVU6rd38CkVtjdWuATU3Yp6_example_com_users_alice123_profile.jsonl +0 -1
- package/test/logs/did_webvh_QmYsce448po14oDE1wXbyaP6wY9HQgHSKLwdezn1k577SF_example_com_my_org_user_name_test_123.jsonl +0 -1
- package/test/logs/did_webvh_QmZBeNzzqajxdfwcDUPZ4P8C5YSXyRztrAwmPiKuKUxmAK_example_com.jsonl +0 -1
- package/test/logs/did_webvh_QmZhJsqxizwVbRtqCUkmE6XQunSxtxMt3gbTYadVBNAaEq_example_com.jsonl +0 -1
- package/test/logs/did_webvh_QmZk7NHU2D57RzzbMq4tWW9gBa9AqtVTWfiRM6RFdwGVj2_example_com.jsonl +0 -1
- package/test/logs/did_webvh_QmZshSXp9w8ovH62zGGBS1b5pGGPsuYiu1VQ935sga2hWF_example_com_level1_level2.jsonl +0 -1
- package/test/logs/did_webvh_QmbWAmw7HQL7vKJyCsctZihXf1rmT4sGvggKCPKWcUWjw1_example_com.jsonl +0 -1
- package/test/logs/did_webvh_QmbdLUMbYs3juR39TLB6hhrFWLcNg45ybUzeBJCS1MhCh1_example_com_C_Windows_System32.jsonl +0 -1
- package/test/logs/did_webvh_QmcaQ1Ma4gkSbae85aCm8Mv4rvdT2Sb2RR3JzYwrm5XBq8_example_com_etc_passwd.jsonl +0 -1
- package/test/logs/did_webvh_QmcbA7WQhsBqZSoDpKJHjV8Q5o53h8vmgJhQfo6rqTY5ho_example_com.jsonl +0 -1
- package/test/logs/did_webvh_Qmdy8uWr2gkUJrXsThynAug3DASTWwb3onEj89LKmMGZYB_example_com.jsonl +0 -1
- package/tests/__mocks__/bbs-signatures.js +0 -17
- package/tests/__mocks__/mf-base58.js +0 -24
- package/tests/e2e/README.md +0 -97
- package/tests/e2e/example.spec.ts +0 -78
- package/tests/fixtures/did-documents.ts +0 -247
- package/tests/index.test.ts +0 -21
- package/tests/integration/BatchOperations.test.ts +0 -531
- package/tests/integration/CompleteLifecycle.e2e.test.ts +0 -735
- package/tests/integration/CredentialManager.test.ts +0 -42
- package/tests/integration/DIDManager.test.ts +0 -41
- package/tests/integration/DidPeerToWebVhFlow.test.ts +0 -351
- package/tests/integration/Events.test.ts +0 -435
- package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +0 -25
- package/tests/integration/LifecycleManager.test.ts +0 -21
- package/tests/integration/MultikeyFlow.test.ts +0 -52
- package/tests/integration/TelemetryIntegration.test.ts +0 -395
- package/tests/integration/WebVhPublish.test.ts +0 -48
- package/tests/integration/migration/peer-to-webvh.test.ts +0 -172
- package/tests/manual/test-commit-creation.ts +0 -323
- package/tests/mocks/MockKeyStore.ts +0 -38
- package/tests/mocks/adapters/MemoryStorageAdapter.ts +0 -24
- package/tests/mocks/adapters/MockFeeOracle.ts +0 -11
- package/tests/mocks/adapters/MockOrdinalsProvider.ts +0 -76
- package/tests/mocks/adapters/OrdMockProvider.test.ts +0 -176
- package/tests/mocks/adapters/index.ts +0 -6
- package/tests/performance/BatchOperations.perf.test.ts +0 -403
- package/tests/performance/logging.perf.test.ts +0 -336
- package/tests/sdk.test.ts +0 -43
- package/tests/security/bitcoin-penetration-tests.test.ts +0 -622
- package/tests/setup.bun.ts +0 -69
- package/tests/setup.jest.ts +0 -23
- package/tests/stress/batch-operations-stress.test.ts +0 -571
- package/tests/unit/adapters/FeeOracleMock.test.ts +0 -40
- package/tests/unit/bitcoin/BitcoinManager.test.ts +0 -293
- package/tests/unit/bitcoin/BroadcastClient.test.ts +0 -52
- package/tests/unit/bitcoin/OrdNodeProvider.test.ts +0 -53
- package/tests/unit/bitcoin/OrdinalsClient.test.ts +0 -381
- package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +0 -102
- package/tests/unit/bitcoin/PSBTBuilder.test.ts +0 -84
- package/tests/unit/bitcoin/fee-calculation.test.ts +0 -261
- package/tests/unit/bitcoin/transactions/commit.test.ts +0 -649
- package/tests/unit/bitcoin/transfer.test.ts +0 -31
- package/tests/unit/bitcoin/utxo-selection-new.test.ts +0 -502
- package/tests/unit/bitcoin/utxo.more.test.ts +0 -39
- package/tests/unit/bitcoin/utxo.selection.test.ts +0 -38
- package/tests/unit/core/OriginalsSDK.test.ts +0 -152
- package/tests/unit/crypto/Multikey.test.ts +0 -206
- package/tests/unit/crypto/Signer.test.ts +0 -408
- package/tests/unit/did/BtcoDidResolver.test.ts +0 -611
- package/tests/unit/did/DIDManager.more.test.ts +0 -43
- package/tests/unit/did/DIDManager.test.ts +0 -185
- package/tests/unit/did/Ed25519Verifier.test.ts +0 -160
- package/tests/unit/did/KeyManager.test.ts +0 -452
- package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +0 -45
- package/tests/unit/did/WebVHManager.test.ts +0 -435
- package/tests/unit/did/createBtcoDidDocument.test.ts +0 -67
- package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +0 -159
- package/tests/unit/events/EventEmitter.test.ts +0 -407
- package/tests/unit/lifecycle/BatchOperations.test.ts +0 -527
- package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +0 -312
- package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +0 -18
- package/tests/unit/lifecycle/LifecycleManager.test.ts +0 -213
- package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +0 -30
- package/tests/unit/lifecycle/OriginalsAsset.test.ts +0 -176
- package/tests/unit/lifecycle/ProvenanceQuery.test.ts +0 -577
- package/tests/unit/lifecycle/ResourceVersioning.test.ts +0 -651
- package/tests/unit/storage/MemoryStorageAdapter.test.ts +0 -93
- package/tests/unit/types/network.test.ts +0 -255
- package/tests/unit/utils/EventIntegration.test.ts +0 -384
- package/tests/unit/utils/Logger.test.ts +0 -473
- package/tests/unit/utils/MetricsCollector.test.ts +0 -358
- package/tests/unit/utils/bitcoin-address.test.ts +0 -250
- package/tests/unit/utils/cbor.test.ts +0 -35
- package/tests/unit/utils/encoding.test.ts +0 -318
- package/tests/unit/utils/hash.test.ts +0 -12
- package/tests/unit/utils/retry.test.ts +0 -100
- package/tests/unit/utils/satoshi-validation.test.ts +0 -354
- package/tests/unit/utils/serialization.test.ts +0 -124
- package/tests/unit/utils/telemetry.test.ts +0 -52
- package/tests/unit/utils/validation.test.ts +0 -141
- package/tests/unit/vc/CredentialManager.test.ts +0 -487
- package/tests/unit/vc/Issuer.test.ts +0 -107
- package/tests/unit/vc/Verifier.test.ts +0 -525
- package/tests/unit/vc/bbs.test.ts +0 -282
- package/tests/unit/vc/cryptosuites/eddsa.test.ts +0 -398
- package/tests/unit/vc/documentLoader.test.ts +0 -121
- package/tests/unit/vc/proofs/data-integrity.test.ts +0 -24
- package/tsconfig.json +0 -31
- package/tsconfig.test.json +0 -15
|
@@ -1,527 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Unit tests for Batch Operations
|
|
3
|
-
*
|
|
4
|
-
* Tests the core batch execution logic, validation, and error handling
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { describe, test, expect, beforeEach } from 'bun:test';
|
|
8
|
-
import {
|
|
9
|
-
BatchOperationExecutor,
|
|
10
|
-
BatchValidator,
|
|
11
|
-
BatchError,
|
|
12
|
-
type BatchResult,
|
|
13
|
-
type BatchOperationOptions,
|
|
14
|
-
type ValidationResult
|
|
15
|
-
} from '../../../src/lifecycle/BatchOperations';
|
|
16
|
-
|
|
17
|
-
describe('BatchOperations', () => {
|
|
18
|
-
describe('BatchOperationExecutor', () => {
|
|
19
|
-
let executor: BatchOperationExecutor;
|
|
20
|
-
|
|
21
|
-
beforeEach(() => {
|
|
22
|
-
executor = new BatchOperationExecutor();
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
test('should execute all operations successfully in sequential mode', async () => {
|
|
26
|
-
const items = [1, 2, 3, 4, 5];
|
|
27
|
-
const operation = async (item: number) => item * 2;
|
|
28
|
-
|
|
29
|
-
const result = await executor.execute(items, operation, {
|
|
30
|
-
maxConcurrent: 1,
|
|
31
|
-
continueOnError: false
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
expect(result.successful).toHaveLength(5);
|
|
35
|
-
expect(result.failed).toHaveLength(0);
|
|
36
|
-
expect(result.totalProcessed).toBe(5);
|
|
37
|
-
expect(result.batchId).toMatch(/^batch_\d+_[0-9a-f]+$/);
|
|
38
|
-
expect(result.successful.map(s => s.result)).toEqual([2, 4, 6, 8, 10]);
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
test('should execute operations concurrently when maxConcurrent > 1', async () => {
|
|
42
|
-
const items = [1, 2, 3, 4, 5, 6];
|
|
43
|
-
const executionOrder: number[] = [];
|
|
44
|
-
|
|
45
|
-
const operation = async (item: number) => {
|
|
46
|
-
executionOrder.push(item);
|
|
47
|
-
await new Promise(resolve => setTimeout(resolve, 10));
|
|
48
|
-
return item * 2;
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
const result = await executor.execute(items, operation, {
|
|
52
|
-
maxConcurrent: 3,
|
|
53
|
-
continueOnError: false
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
expect(result.successful).toHaveLength(6);
|
|
57
|
-
expect(result.failed).toHaveLength(0);
|
|
58
|
-
// With maxConcurrent=3, items should be processed in chunks
|
|
59
|
-
// Items 1,2,3 should start before 4,5,6
|
|
60
|
-
expect(executionOrder.slice(0, 3).sort()).toEqual([1, 2, 3]);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
test('should handle partial failures with continueOnError: true', async () => {
|
|
64
|
-
const items = [1, 2, 3, 4, 5];
|
|
65
|
-
const operation = async (item: number) => {
|
|
66
|
-
if (item === 3 || item === 5) {
|
|
67
|
-
throw new Error(`Failed on item ${item}`);
|
|
68
|
-
}
|
|
69
|
-
return item * 2;
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
const result = await executor.execute(items, operation, {
|
|
73
|
-
continueOnError: true,
|
|
74
|
-
maxConcurrent: 1
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
expect(result.successful).toHaveLength(3);
|
|
78
|
-
expect(result.failed).toHaveLength(2);
|
|
79
|
-
expect(result.totalProcessed).toBe(5);
|
|
80
|
-
expect(result.successful.map(s => s.result)).toEqual([2, 4, 8]);
|
|
81
|
-
expect(result.failed.map(f => f.index)).toEqual([2, 4]); // indices 2 and 4 (items 3 and 5)
|
|
82
|
-
expect(result.failed[0].error.message).toBe('Failed on item 3');
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
test('should fail fast when continueOnError: false', async () => {
|
|
86
|
-
const items = [1, 2, 3, 4, 5];
|
|
87
|
-
const operation = async (item: number) => {
|
|
88
|
-
if (item === 3) {
|
|
89
|
-
throw new Error('Failed on item 3');
|
|
90
|
-
}
|
|
91
|
-
return item * 2;
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
await expect(
|
|
95
|
-
executor.execute(items, operation, {
|
|
96
|
-
continueOnError: false,
|
|
97
|
-
maxConcurrent: 1
|
|
98
|
-
})
|
|
99
|
-
).rejects.toThrow('Failed on item 3');
|
|
100
|
-
});
|
|
101
|
-
|
|
102
|
-
test('should retry failed operations with exponential backoff', async () => {
|
|
103
|
-
let attempts = 0;
|
|
104
|
-
const items = [1];
|
|
105
|
-
|
|
106
|
-
const operation = async (item: number) => {
|
|
107
|
-
attempts++;
|
|
108
|
-
if (attempts < 3) {
|
|
109
|
-
throw new Error('Temporary failure');
|
|
110
|
-
}
|
|
111
|
-
return item * 2;
|
|
112
|
-
};
|
|
113
|
-
|
|
114
|
-
const result = await executor.execute(items, operation, {
|
|
115
|
-
retryCount: 2,
|
|
116
|
-
retryDelay: 10,
|
|
117
|
-
continueOnError: false
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
expect(attempts).toBe(3);
|
|
121
|
-
expect(result.successful).toHaveLength(1);
|
|
122
|
-
expect(result.successful[0].result).toBe(2);
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
test('should fail after exhausting retries', async () => {
|
|
126
|
-
let attempts = 0;
|
|
127
|
-
const items = [1];
|
|
128
|
-
|
|
129
|
-
const operation = async (item: number) => {
|
|
130
|
-
attempts++;
|
|
131
|
-
throw new Error('Permanent failure');
|
|
132
|
-
};
|
|
133
|
-
|
|
134
|
-
const result = await executor.execute(items, operation, {
|
|
135
|
-
retryCount: 2,
|
|
136
|
-
retryDelay: 10,
|
|
137
|
-
continueOnError: true
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
expect(attempts).toBe(3); // Initial attempt + 2 retries
|
|
141
|
-
expect(result.successful).toHaveLength(0);
|
|
142
|
-
expect(result.failed).toHaveLength(1);
|
|
143
|
-
expect(result.failed[0].retryAttempts).toBe(2);
|
|
144
|
-
});
|
|
145
|
-
|
|
146
|
-
test('should respect timeout for operations', async () => {
|
|
147
|
-
const items = [1];
|
|
148
|
-
const operation = async (item: number) => {
|
|
149
|
-
await new Promise(resolve => setTimeout(resolve, 200));
|
|
150
|
-
return item * 2;
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
const result = await executor.execute(items, operation, {
|
|
154
|
-
timeoutMs: 50,
|
|
155
|
-
continueOnError: true
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
expect(result.failed).toHaveLength(1);
|
|
159
|
-
expect(result.failed[0].error.message).toContain('timeout');
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
test('should generate unique batch IDs', () => {
|
|
163
|
-
const ids = new Set<string>();
|
|
164
|
-
for (let i = 0; i < 100; i++) {
|
|
165
|
-
ids.add(executor.generateBatchId());
|
|
166
|
-
}
|
|
167
|
-
expect(ids.size).toBe(100);
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
test('should calculate timing accurately', async () => {
|
|
171
|
-
const items = [1, 2, 3];
|
|
172
|
-
const operation = async (item: number) => {
|
|
173
|
-
await new Promise(resolve => setTimeout(resolve, 20));
|
|
174
|
-
return item * 2;
|
|
175
|
-
};
|
|
176
|
-
|
|
177
|
-
const result = await executor.execute(items, operation, {
|
|
178
|
-
maxConcurrent: 1
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
expect(result.totalDuration).toBeGreaterThanOrEqual(60); // At least 60ms (3 * 20ms)
|
|
182
|
-
expect(result.startedAt).toBeDefined();
|
|
183
|
-
expect(result.completedAt).toBeDefined();
|
|
184
|
-
|
|
185
|
-
const startTime = new Date(result.startedAt).getTime();
|
|
186
|
-
const endTime = new Date(result.completedAt).getTime();
|
|
187
|
-
expect(endTime - startTime).toBeGreaterThanOrEqual(60);
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
test('should track individual operation durations', async () => {
|
|
191
|
-
const items = [1, 2, 3];
|
|
192
|
-
const operation = async (item: number) => {
|
|
193
|
-
await new Promise(resolve => setTimeout(resolve, item * 10));
|
|
194
|
-
return item * 2;
|
|
195
|
-
};
|
|
196
|
-
|
|
197
|
-
const result = await executor.execute(items, operation, {
|
|
198
|
-
maxConcurrent: 1
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
// Allow for timing imprecision - setTimeout can fire slightly early
|
|
202
|
-
// Use 80% of expected time as minimum to account for timer precision issues
|
|
203
|
-
expect(result.successful[0].duration).toBeGreaterThanOrEqual(8);
|
|
204
|
-
expect(result.successful[1].duration).toBeGreaterThanOrEqual(18);
|
|
205
|
-
expect(result.successful[2].duration).toBeGreaterThanOrEqual(28);
|
|
206
|
-
|
|
207
|
-
// Also verify durations are reasonable (not too high)
|
|
208
|
-
expect(result.successful[0].duration).toBeLessThan(50);
|
|
209
|
-
expect(result.successful[1].duration).toBeLessThan(60);
|
|
210
|
-
expect(result.successful[2].duration).toBeLessThan(70);
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
test('should handle empty array', async () => {
|
|
214
|
-
const items: number[] = [];
|
|
215
|
-
const operation = async (item: number) => item * 2;
|
|
216
|
-
|
|
217
|
-
const result = await executor.execute(items, operation);
|
|
218
|
-
|
|
219
|
-
expect(result.successful).toHaveLength(0);
|
|
220
|
-
expect(result.failed).toHaveLength(0);
|
|
221
|
-
expect(result.totalProcessed).toBe(0);
|
|
222
|
-
});
|
|
223
|
-
|
|
224
|
-
test('should preserve item indices in results', async () => {
|
|
225
|
-
const items = [10, 20, 30, 40, 50];
|
|
226
|
-
const operation = async (item: number, index: number) => {
|
|
227
|
-
if (item === 30) throw new Error('Failed');
|
|
228
|
-
return { item, index };
|
|
229
|
-
};
|
|
230
|
-
|
|
231
|
-
const result = await executor.execute(items, operation, {
|
|
232
|
-
continueOnError: true
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
expect(result.successful[0].index).toBe(0);
|
|
236
|
-
expect(result.successful[0].result.index).toBe(0);
|
|
237
|
-
expect(result.successful[1].index).toBe(1);
|
|
238
|
-
expect(result.failed[0].index).toBe(2); // Item 30 at index 2
|
|
239
|
-
});
|
|
240
|
-
});
|
|
241
|
-
|
|
242
|
-
describe('BatchValidator', () => {
|
|
243
|
-
let validator: BatchValidator;
|
|
244
|
-
|
|
245
|
-
beforeEach(() => {
|
|
246
|
-
validator = new BatchValidator();
|
|
247
|
-
});
|
|
248
|
-
|
|
249
|
-
describe('validateBatchCreate', () => {
|
|
250
|
-
test('should validate correct resource lists', () => {
|
|
251
|
-
const resourcesList = [
|
|
252
|
-
[
|
|
253
|
-
{
|
|
254
|
-
id: 'res1',
|
|
255
|
-
type: 'image',
|
|
256
|
-
contentType: 'image/png',
|
|
257
|
-
hash: 'abc123'
|
|
258
|
-
}
|
|
259
|
-
],
|
|
260
|
-
[
|
|
261
|
-
{
|
|
262
|
-
id: 'res2',
|
|
263
|
-
type: 'text',
|
|
264
|
-
contentType: 'text/plain',
|
|
265
|
-
hash: 'def456'
|
|
266
|
-
}
|
|
267
|
-
]
|
|
268
|
-
];
|
|
269
|
-
|
|
270
|
-
const results = validator.validateBatchCreate(resourcesList);
|
|
271
|
-
|
|
272
|
-
expect(results).toHaveLength(2);
|
|
273
|
-
expect(results[0].isValid).toBe(true);
|
|
274
|
-
expect(results[1].isValid).toBe(true);
|
|
275
|
-
expect(results[0].errors).toHaveLength(0);
|
|
276
|
-
});
|
|
277
|
-
|
|
278
|
-
test('should detect empty resource arrays', () => {
|
|
279
|
-
const resourcesList = [[]];
|
|
280
|
-
|
|
281
|
-
const results = validator.validateBatchCreate(resourcesList);
|
|
282
|
-
|
|
283
|
-
expect(results[0].isValid).toBe(false);
|
|
284
|
-
expect(results[0].errors[0]).toContain('At least one resource is required');
|
|
285
|
-
});
|
|
286
|
-
|
|
287
|
-
test('should detect invalid resource objects', () => {
|
|
288
|
-
const resourcesList = [
|
|
289
|
-
[
|
|
290
|
-
{
|
|
291
|
-
id: 'res1'
|
|
292
|
-
// missing type, contentType, hash
|
|
293
|
-
}
|
|
294
|
-
]
|
|
295
|
-
];
|
|
296
|
-
|
|
297
|
-
const results = validator.validateBatchCreate(resourcesList as any);
|
|
298
|
-
|
|
299
|
-
expect(results[0].isValid).toBe(false);
|
|
300
|
-
expect(results[0].errors.length).toBeGreaterThan(0);
|
|
301
|
-
});
|
|
302
|
-
|
|
303
|
-
test('should detect invalid hash format', () => {
|
|
304
|
-
const resourcesList = [
|
|
305
|
-
[
|
|
306
|
-
{
|
|
307
|
-
id: 'res1',
|
|
308
|
-
type: 'image',
|
|
309
|
-
contentType: 'image/png',
|
|
310
|
-
hash: 'not-hex-!@#'
|
|
311
|
-
}
|
|
312
|
-
]
|
|
313
|
-
];
|
|
314
|
-
|
|
315
|
-
const results = validator.validateBatchCreate(resourcesList);
|
|
316
|
-
|
|
317
|
-
expect(results[0].isValid).toBe(false);
|
|
318
|
-
expect(results[0].errors[0]).toContain('invalid hash');
|
|
319
|
-
});
|
|
320
|
-
|
|
321
|
-
test('should handle non-array input', () => {
|
|
322
|
-
const resourcesList = ['not-an-array'];
|
|
323
|
-
|
|
324
|
-
const results = validator.validateBatchCreate(resourcesList as any);
|
|
325
|
-
|
|
326
|
-
expect(results[0].isValid).toBe(false);
|
|
327
|
-
expect(results[0].errors[0]).toContain('must be an array');
|
|
328
|
-
});
|
|
329
|
-
});
|
|
330
|
-
|
|
331
|
-
describe('validateBatchInscription', () => {
|
|
332
|
-
test('should validate correct assets', () => {
|
|
333
|
-
const assets = [
|
|
334
|
-
{
|
|
335
|
-
id: 'did:peer:123',
|
|
336
|
-
currentLayer: 'did:peer',
|
|
337
|
-
resources: [{ id: 'res1' }]
|
|
338
|
-
},
|
|
339
|
-
{
|
|
340
|
-
id: 'did:webvh:example.com:456',
|
|
341
|
-
currentLayer: 'did:webvh',
|
|
342
|
-
resources: [{ id: 'res2' }]
|
|
343
|
-
}
|
|
344
|
-
];
|
|
345
|
-
|
|
346
|
-
const results = validator.validateBatchInscription(assets);
|
|
347
|
-
|
|
348
|
-
expect(results).toHaveLength(2);
|
|
349
|
-
expect(results[0].isValid).toBe(true);
|
|
350
|
-
expect(results[1].isValid).toBe(true);
|
|
351
|
-
});
|
|
352
|
-
|
|
353
|
-
test('should detect already inscribed assets', () => {
|
|
354
|
-
const assets = [
|
|
355
|
-
{
|
|
356
|
-
id: 'did:btco:123',
|
|
357
|
-
currentLayer: 'did:btco',
|
|
358
|
-
resources: [{ id: 'res1' }]
|
|
359
|
-
}
|
|
360
|
-
];
|
|
361
|
-
|
|
362
|
-
const results = validator.validateBatchInscription(assets);
|
|
363
|
-
|
|
364
|
-
expect(results[0].isValid).toBe(false);
|
|
365
|
-
expect(results[0].errors[0]).toContain('already inscribed');
|
|
366
|
-
});
|
|
367
|
-
|
|
368
|
-
test('should detect missing resources', () => {
|
|
369
|
-
const assets = [
|
|
370
|
-
{
|
|
371
|
-
id: 'did:peer:123',
|
|
372
|
-
currentLayer: 'did:peer',
|
|
373
|
-
resources: []
|
|
374
|
-
}
|
|
375
|
-
];
|
|
376
|
-
|
|
377
|
-
const results = validator.validateBatchInscription(assets);
|
|
378
|
-
|
|
379
|
-
expect(results[0].isValid).toBe(false);
|
|
380
|
-
expect(results[0].errors[0]).toContain('at least one resource');
|
|
381
|
-
});
|
|
382
|
-
|
|
383
|
-
test('should detect invalid asset objects', () => {
|
|
384
|
-
const assets = [null, undefined, 'not-an-object'];
|
|
385
|
-
|
|
386
|
-
const results = validator.validateBatchInscription(assets as any);
|
|
387
|
-
|
|
388
|
-
expect(results).toHaveLength(3);
|
|
389
|
-
expect(results.every(r => !r.isValid)).toBe(true);
|
|
390
|
-
});
|
|
391
|
-
});
|
|
392
|
-
|
|
393
|
-
describe('validateBatchTransfer', () => {
|
|
394
|
-
test('should validate correct transfers', () => {
|
|
395
|
-
const transfers = [
|
|
396
|
-
{
|
|
397
|
-
asset: {
|
|
398
|
-
id: 'did:btco:123',
|
|
399
|
-
currentLayer: 'did:btco'
|
|
400
|
-
},
|
|
401
|
-
to: 'bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4'
|
|
402
|
-
}
|
|
403
|
-
];
|
|
404
|
-
|
|
405
|
-
const results = validator.validateBatchTransfer(transfers);
|
|
406
|
-
|
|
407
|
-
expect(results[0].isValid).toBe(true);
|
|
408
|
-
});
|
|
409
|
-
|
|
410
|
-
test('should detect non-btco assets', () => {
|
|
411
|
-
const transfers = [
|
|
412
|
-
{
|
|
413
|
-
asset: {
|
|
414
|
-
id: 'did:peer:123',
|
|
415
|
-
currentLayer: 'did:peer'
|
|
416
|
-
},
|
|
417
|
-
to: 'bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4'
|
|
418
|
-
}
|
|
419
|
-
];
|
|
420
|
-
|
|
421
|
-
const results = validator.validateBatchTransfer(transfers);
|
|
422
|
-
|
|
423
|
-
expect(results[0].isValid).toBe(false);
|
|
424
|
-
expect(results[0].errors[0]).toContain('must be inscribed on Bitcoin');
|
|
425
|
-
});
|
|
426
|
-
|
|
427
|
-
test('should detect missing destination address', () => {
|
|
428
|
-
const transfers = [
|
|
429
|
-
{
|
|
430
|
-
asset: {
|
|
431
|
-
id: 'did:btco:123',
|
|
432
|
-
currentLayer: 'did:btco'
|
|
433
|
-
},
|
|
434
|
-
to: ''
|
|
435
|
-
}
|
|
436
|
-
];
|
|
437
|
-
|
|
438
|
-
const results = validator.validateBatchTransfer(transfers);
|
|
439
|
-
|
|
440
|
-
expect(results[0].isValid).toBe(false);
|
|
441
|
-
expect(results[0].errors[0]).toContain('Invalid destination address');
|
|
442
|
-
});
|
|
443
|
-
|
|
444
|
-
test('should detect invalid transfer objects', () => {
|
|
445
|
-
const transfers = [null, { asset: null, to: 'address' }];
|
|
446
|
-
|
|
447
|
-
const results = validator.validateBatchTransfer(transfers as any);
|
|
448
|
-
|
|
449
|
-
expect(results).toHaveLength(2);
|
|
450
|
-
expect(results.every(r => !r.isValid)).toBe(true);
|
|
451
|
-
});
|
|
452
|
-
});
|
|
453
|
-
});
|
|
454
|
-
|
|
455
|
-
describe('BatchError', () => {
|
|
456
|
-
test('should create error with batch metadata', () => {
|
|
457
|
-
const error = new BatchError(
|
|
458
|
-
'batch_123',
|
|
459
|
-
'create',
|
|
460
|
-
{ successful: 3, failed: 2 },
|
|
461
|
-
'Operation failed'
|
|
462
|
-
);
|
|
463
|
-
|
|
464
|
-
expect(error.name).toBe('BatchError');
|
|
465
|
-
expect(error.message).toBe('Operation failed');
|
|
466
|
-
expect(error.batchId).toBe('batch_123');
|
|
467
|
-
expect(error.operation).toBe('create');
|
|
468
|
-
expect(error.partialResults.successful).toBe(3);
|
|
469
|
-
expect(error.partialResults.failed).toBe(2);
|
|
470
|
-
expect(error instanceof Error).toBe(true);
|
|
471
|
-
});
|
|
472
|
-
});
|
|
473
|
-
|
|
474
|
-
describe('Integration scenarios', () => {
|
|
475
|
-
test('should handle mixed success and failure with retries', async () => {
|
|
476
|
-
const executor = new BatchOperationExecutor();
|
|
477
|
-
const attemptCounts = new Map<number, number>();
|
|
478
|
-
|
|
479
|
-
const items = [1, 2, 3, 4, 5];
|
|
480
|
-
const operation = async (item: number) => {
|
|
481
|
-
const count = attemptCounts.get(item) || 0;
|
|
482
|
-
attemptCounts.set(item, count + 1);
|
|
483
|
-
|
|
484
|
-
// Item 3 fails on first two attempts, succeeds on third
|
|
485
|
-
if (item === 3 && count < 2) {
|
|
486
|
-
throw new Error('Temporary failure');
|
|
487
|
-
}
|
|
488
|
-
|
|
489
|
-
// Item 5 always fails
|
|
490
|
-
if (item === 5) {
|
|
491
|
-
throw new Error('Permanent failure');
|
|
492
|
-
}
|
|
493
|
-
|
|
494
|
-
return item * 2;
|
|
495
|
-
};
|
|
496
|
-
|
|
497
|
-
const result = await executor.execute(items, operation, {
|
|
498
|
-
retryCount: 2,
|
|
499
|
-
retryDelay: 5,
|
|
500
|
-
continueOnError: true,
|
|
501
|
-
maxConcurrent: 1
|
|
502
|
-
});
|
|
503
|
-
|
|
504
|
-
expect(result.successful).toHaveLength(4); // Items 1, 2, 3, 4
|
|
505
|
-
expect(result.failed).toHaveLength(1); // Item 5
|
|
506
|
-
expect(attemptCounts.get(3)).toBe(3); // 2 failures + 1 success
|
|
507
|
-
expect(attemptCounts.get(5)).toBe(3); // 3 failures
|
|
508
|
-
});
|
|
509
|
-
|
|
510
|
-
test('should handle large batches efficiently', async () => {
|
|
511
|
-
const executor = new BatchOperationExecutor();
|
|
512
|
-
const items = Array.from({ length: 100 }, (_, i) => i);
|
|
513
|
-
|
|
514
|
-
const startTime = Date.now();
|
|
515
|
-
const result = await executor.execute(items, async (item) => item * 2, {
|
|
516
|
-
maxConcurrent: 10
|
|
517
|
-
});
|
|
518
|
-
const duration = Date.now() - startTime;
|
|
519
|
-
|
|
520
|
-
expect(result.successful).toHaveLength(100);
|
|
521
|
-
expect(result.failed).toHaveLength(0);
|
|
522
|
-
// With concurrency=10, should be much faster than sequential
|
|
523
|
-
// This is a rough check - actual timing depends on system load
|
|
524
|
-
expect(duration).toBeLessThan(5000);
|
|
525
|
-
});
|
|
526
|
-
});
|
|
527
|
-
});
|