@originals/sdk 1.1.0
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/.eslintrc.json +33 -0
- package/.turbo/turbo-build.log +1 -0
- package/.turbo/turbo-test.log +68353 -0
- package/dist/adapters/FeeOracleMock.d.ts +6 -0
- package/dist/adapters/FeeOracleMock.js +8 -0
- package/dist/adapters/index.d.ts +4 -0
- package/dist/adapters/index.js +4 -0
- package/dist/adapters/providers/OrdHttpProvider.d.ts +56 -0
- package/dist/adapters/providers/OrdHttpProvider.js +110 -0
- package/dist/adapters/providers/OrdMockProvider.d.ts +70 -0
- package/dist/adapters/providers/OrdMockProvider.js +75 -0
- package/dist/adapters/types.d.ts +71 -0
- package/dist/adapters/types.js +1 -0
- package/dist/bitcoin/BitcoinManager.d.ts +15 -0
- package/dist/bitcoin/BitcoinManager.js +262 -0
- package/dist/bitcoin/BroadcastClient.d.ts +30 -0
- package/dist/bitcoin/BroadcastClient.js +35 -0
- package/dist/bitcoin/OrdinalsClient.d.ts +21 -0
- package/dist/bitcoin/OrdinalsClient.js +105 -0
- package/dist/bitcoin/PSBTBuilder.d.ts +24 -0
- package/dist/bitcoin/PSBTBuilder.js +80 -0
- package/dist/bitcoin/fee-calculation.d.ts +14 -0
- package/dist/bitcoin/fee-calculation.js +31 -0
- package/dist/bitcoin/providers/OrdNodeProvider.d.ts +38 -0
- package/dist/bitcoin/providers/OrdNodeProvider.js +67 -0
- package/dist/bitcoin/providers/OrdinalsProvider.d.ts +33 -0
- package/dist/bitcoin/providers/OrdinalsProvider.js +50 -0
- package/dist/bitcoin/providers/types.d.ts +63 -0
- package/dist/bitcoin/providers/types.js +1 -0
- package/dist/bitcoin/transactions/commit.d.ts +89 -0
- package/dist/bitcoin/transactions/commit.js +311 -0
- package/dist/bitcoin/transactions/index.d.ts +7 -0
- package/dist/bitcoin/transactions/index.js +8 -0
- package/dist/bitcoin/transfer.d.ts +9 -0
- package/dist/bitcoin/transfer.js +26 -0
- package/dist/bitcoin/utxo-selection.d.ts +78 -0
- package/dist/bitcoin/utxo-selection.js +237 -0
- package/dist/bitcoin/utxo.d.ts +26 -0
- package/dist/bitcoin/utxo.js +78 -0
- package/dist/contexts/credentials-v1.json +195 -0
- package/dist/contexts/credentials-v2-examples.json +5 -0
- package/dist/contexts/credentials-v2.json +301 -0
- package/dist/contexts/credentials.json +195 -0
- package/dist/contexts/data-integrity-v2.json +81 -0
- package/dist/contexts/dids.json +57 -0
- package/dist/contexts/ed255192020.json +93 -0
- package/dist/contexts/ordinals-plus.json +23 -0
- package/dist/contexts/originals.json +22 -0
- package/dist/core/OriginalsSDK.d.ts +158 -0
- package/dist/core/OriginalsSDK.js +274 -0
- package/dist/crypto/Multikey.d.ts +30 -0
- package/dist/crypto/Multikey.js +149 -0
- package/dist/crypto/Signer.d.ts +21 -0
- package/dist/crypto/Signer.js +196 -0
- package/dist/crypto/noble-init.d.ts +18 -0
- package/dist/crypto/noble-init.js +106 -0
- package/dist/did/BtcoDidResolver.d.ts +57 -0
- package/dist/did/BtcoDidResolver.js +166 -0
- package/dist/did/DIDManager.d.ts +101 -0
- package/dist/did/DIDManager.js +493 -0
- package/dist/did/Ed25519Verifier.d.ts +30 -0
- package/dist/did/Ed25519Verifier.js +59 -0
- package/dist/did/KeyManager.d.ts +17 -0
- package/dist/did/KeyManager.js +207 -0
- package/dist/did/WebVHManager.d.ts +100 -0
- package/dist/did/WebVHManager.js +304 -0
- package/dist/did/createBtcoDidDocument.d.ts +10 -0
- package/dist/did/createBtcoDidDocument.js +42 -0
- package/dist/did/providers/OrdinalsClientProviderAdapter.d.ts +23 -0
- package/dist/did/providers/OrdinalsClientProviderAdapter.js +51 -0
- package/dist/events/EventEmitter.d.ts +115 -0
- package/dist/events/EventEmitter.js +198 -0
- package/dist/events/index.d.ts +7 -0
- package/dist/events/index.js +6 -0
- package/dist/events/types.d.ts +286 -0
- package/dist/events/types.js +9 -0
- package/dist/examples/basic-usage.d.ts +3 -0
- package/dist/examples/basic-usage.js +62 -0
- package/dist/examples/run.d.ts +1 -0
- package/dist/examples/run.js +4 -0
- package/dist/index.d.ts +39 -0
- package/dist/index.js +47 -0
- package/dist/lifecycle/BatchOperations.d.ts +147 -0
- package/dist/lifecycle/BatchOperations.js +251 -0
- package/dist/lifecycle/LifecycleManager.d.ts +116 -0
- package/dist/lifecycle/LifecycleManager.js +971 -0
- package/dist/lifecycle/OriginalsAsset.d.ts +164 -0
- package/dist/lifecycle/OriginalsAsset.js +380 -0
- package/dist/lifecycle/ProvenanceQuery.d.ts +126 -0
- package/dist/lifecycle/ProvenanceQuery.js +220 -0
- package/dist/lifecycle/ResourceVersioning.d.ts +73 -0
- package/dist/lifecycle/ResourceVersioning.js +127 -0
- package/dist/migration/MigrationManager.d.ts +86 -0
- package/dist/migration/MigrationManager.js +412 -0
- package/dist/migration/audit/AuditLogger.d.ts +51 -0
- package/dist/migration/audit/AuditLogger.js +156 -0
- package/dist/migration/checkpoint/CheckpointManager.d.ts +31 -0
- package/dist/migration/checkpoint/CheckpointManager.js +96 -0
- package/dist/migration/checkpoint/CheckpointStorage.d.ts +26 -0
- package/dist/migration/checkpoint/CheckpointStorage.js +89 -0
- package/dist/migration/index.d.ts +22 -0
- package/dist/migration/index.js +27 -0
- package/dist/migration/operations/BaseMigration.d.ts +48 -0
- package/dist/migration/operations/BaseMigration.js +83 -0
- package/dist/migration/operations/PeerToBtcoMigration.d.ts +25 -0
- package/dist/migration/operations/PeerToBtcoMigration.js +67 -0
- package/dist/migration/operations/PeerToWebvhMigration.d.ts +19 -0
- package/dist/migration/operations/PeerToWebvhMigration.js +46 -0
- package/dist/migration/operations/WebvhToBtcoMigration.d.ts +25 -0
- package/dist/migration/operations/WebvhToBtcoMigration.js +67 -0
- package/dist/migration/rollback/RollbackManager.d.ts +29 -0
- package/dist/migration/rollback/RollbackManager.js +146 -0
- package/dist/migration/state/StateMachine.d.ts +25 -0
- package/dist/migration/state/StateMachine.js +76 -0
- package/dist/migration/state/StateTracker.d.ts +36 -0
- package/dist/migration/state/StateTracker.js +123 -0
- package/dist/migration/types.d.ts +306 -0
- package/dist/migration/types.js +33 -0
- package/dist/migration/validation/BitcoinValidator.d.ts +13 -0
- package/dist/migration/validation/BitcoinValidator.js +83 -0
- package/dist/migration/validation/CredentialValidator.d.ts +13 -0
- package/dist/migration/validation/CredentialValidator.js +46 -0
- package/dist/migration/validation/DIDCompatibilityValidator.d.ts +16 -0
- package/dist/migration/validation/DIDCompatibilityValidator.js +127 -0
- package/dist/migration/validation/LifecycleValidator.d.ts +10 -0
- package/dist/migration/validation/LifecycleValidator.js +52 -0
- package/dist/migration/validation/StorageValidator.d.ts +10 -0
- package/dist/migration/validation/StorageValidator.js +65 -0
- package/dist/migration/validation/ValidationPipeline.d.ts +29 -0
- package/dist/migration/validation/ValidationPipeline.js +180 -0
- package/dist/storage/LocalStorageAdapter.d.ts +11 -0
- package/dist/storage/LocalStorageAdapter.js +53 -0
- package/dist/storage/MemoryStorageAdapter.d.ts +6 -0
- package/dist/storage/MemoryStorageAdapter.js +21 -0
- package/dist/storage/StorageAdapter.d.ts +16 -0
- package/dist/storage/StorageAdapter.js +1 -0
- package/dist/storage/index.d.ts +2 -0
- package/dist/storage/index.js +2 -0
- package/dist/types/bitcoin.d.ts +84 -0
- package/dist/types/bitcoin.js +1 -0
- package/dist/types/common.d.ts +82 -0
- package/dist/types/common.js +1 -0
- package/dist/types/credentials.d.ts +75 -0
- package/dist/types/credentials.js +1 -0
- package/dist/types/did.d.ts +26 -0
- package/dist/types/did.js +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.js +5 -0
- package/dist/types/network.d.ts +78 -0
- package/dist/types/network.js +145 -0
- package/dist/utils/EventLogger.d.ts +71 -0
- package/dist/utils/EventLogger.js +232 -0
- package/dist/utils/Logger.d.ts +106 -0
- package/dist/utils/Logger.js +257 -0
- package/dist/utils/MetricsCollector.d.ts +110 -0
- package/dist/utils/MetricsCollector.js +264 -0
- package/dist/utils/bitcoin-address.d.ts +38 -0
- package/dist/utils/bitcoin-address.js +113 -0
- package/dist/utils/cbor.d.ts +2 -0
- package/dist/utils/cbor.js +9 -0
- package/dist/utils/encoding.d.ts +37 -0
- package/dist/utils/encoding.js +120 -0
- package/dist/utils/hash.d.ts +1 -0
- package/dist/utils/hash.js +5 -0
- package/dist/utils/retry.d.ts +10 -0
- package/dist/utils/retry.js +35 -0
- package/dist/utils/satoshi-validation.d.ts +60 -0
- package/dist/utils/satoshi-validation.js +156 -0
- package/dist/utils/serialization.d.ts +14 -0
- package/dist/utils/serialization.js +76 -0
- package/dist/utils/telemetry.d.ts +17 -0
- package/dist/utils/telemetry.js +24 -0
- package/dist/utils/validation.d.ts +5 -0
- package/dist/utils/validation.js +98 -0
- package/dist/vc/CredentialManager.d.ts +22 -0
- package/dist/vc/CredentialManager.js +227 -0
- package/dist/vc/Issuer.d.ts +27 -0
- package/dist/vc/Issuer.js +70 -0
- package/dist/vc/Verifier.d.ts +16 -0
- package/dist/vc/Verifier.js +50 -0
- package/dist/vc/cryptosuites/bbs.d.ts +44 -0
- package/dist/vc/cryptosuites/bbs.js +213 -0
- package/dist/vc/cryptosuites/bbsSimple.d.ts +9 -0
- package/dist/vc/cryptosuites/bbsSimple.js +12 -0
- package/dist/vc/cryptosuites/eddsa.d.ts +30 -0
- package/dist/vc/cryptosuites/eddsa.js +81 -0
- package/dist/vc/documentLoader.d.ts +16 -0
- package/dist/vc/documentLoader.js +59 -0
- package/dist/vc/proofs/data-integrity.d.ts +21 -0
- package/dist/vc/proofs/data-integrity.js +15 -0
- package/dist/vc/utils/jsonld.d.ts +2 -0
- package/dist/vc/utils/jsonld.js +15 -0
- package/package.json +79 -0
- package/src/adapters/FeeOracleMock.ts +9 -0
- package/src/adapters/index.ts +5 -0
- package/src/adapters/providers/OrdHttpProvider.ts +126 -0
- package/src/adapters/providers/OrdMockProvider.ts +101 -0
- package/src/adapters/types.ts +66 -0
- package/src/bitcoin/BitcoinManager.ts +330 -0
- package/src/bitcoin/BroadcastClient.ts +54 -0
- package/src/bitcoin/OrdinalsClient.ts +119 -0
- package/src/bitcoin/PSBTBuilder.ts +106 -0
- package/src/bitcoin/fee-calculation.ts +38 -0
- package/src/bitcoin/providers/OrdNodeProvider.ts +92 -0
- package/src/bitcoin/providers/OrdinalsProvider.ts +56 -0
- package/src/bitcoin/providers/types.ts +59 -0
- package/src/bitcoin/transactions/commit.ts +465 -0
- package/src/bitcoin/transactions/index.ts +13 -0
- package/src/bitcoin/transfer.ts +43 -0
- package/src/bitcoin/utxo-selection.ts +322 -0
- package/src/bitcoin/utxo.ts +113 -0
- package/src/contexts/credentials-v1.json +237 -0
- package/src/contexts/credentials-v2-examples.json +5 -0
- package/src/contexts/credentials-v2.json +340 -0
- package/src/contexts/credentials.json +237 -0
- package/src/contexts/data-integrity-v2.json +81 -0
- package/src/contexts/dids.json +58 -0
- package/src/contexts/ed255192020.json +93 -0
- package/src/contexts/ordinals-plus.json +23 -0
- package/src/contexts/originals.json +22 -0
- package/src/core/OriginalsSDK.ts +416 -0
- package/src/crypto/Multikey.ts +194 -0
- package/src/crypto/Signer.ts +254 -0
- package/src/crypto/noble-init.ts +121 -0
- package/src/did/BtcoDidResolver.ts +227 -0
- package/src/did/DIDManager.ts +694 -0
- package/src/did/Ed25519Verifier.ts +68 -0
- package/src/did/KeyManager.ts +236 -0
- package/src/did/WebVHManager.ts +489 -0
- package/src/did/createBtcoDidDocument.ts +59 -0
- package/src/did/providers/OrdinalsClientProviderAdapter.ts +68 -0
- package/src/events/EventEmitter.ts +222 -0
- package/src/events/index.ts +19 -0
- package/src/events/types.ts +331 -0
- package/src/examples/basic-usage.ts +78 -0
- package/src/examples/run.ts +5 -0
- package/src/index.ts +84 -0
- package/src/lifecycle/BatchOperations.ts +373 -0
- package/src/lifecycle/LifecycleManager.ts +1218 -0
- package/src/lifecycle/OriginalsAsset.ts +524 -0
- package/src/lifecycle/ProvenanceQuery.ts +280 -0
- package/src/lifecycle/ResourceVersioning.ts +163 -0
- package/src/migration/MigrationManager.ts +527 -0
- package/src/migration/audit/AuditLogger.ts +176 -0
- package/src/migration/checkpoint/CheckpointManager.ts +112 -0
- package/src/migration/checkpoint/CheckpointStorage.ts +101 -0
- package/src/migration/index.ts +33 -0
- package/src/migration/operations/BaseMigration.ts +126 -0
- package/src/migration/operations/PeerToBtcoMigration.ts +105 -0
- package/src/migration/operations/PeerToWebvhMigration.ts +62 -0
- package/src/migration/operations/WebvhToBtcoMigration.ts +105 -0
- package/src/migration/rollback/RollbackManager.ts +170 -0
- package/src/migration/state/StateMachine.ts +92 -0
- package/src/migration/state/StateTracker.ts +156 -0
- package/src/migration/types.ts +344 -0
- package/src/migration/validation/BitcoinValidator.ts +107 -0
- package/src/migration/validation/CredentialValidator.ts +62 -0
- package/src/migration/validation/DIDCompatibilityValidator.ts +151 -0
- package/src/migration/validation/LifecycleValidator.ts +64 -0
- package/src/migration/validation/StorageValidator.ts +79 -0
- package/src/migration/validation/ValidationPipeline.ts +213 -0
- package/src/storage/LocalStorageAdapter.ts +61 -0
- package/src/storage/MemoryStorageAdapter.ts +29 -0
- package/src/storage/StorageAdapter.ts +25 -0
- package/src/storage/index.ts +3 -0
- package/src/types/bitcoin.ts +98 -0
- package/src/types/common.ts +92 -0
- package/src/types/credentials.ts +88 -0
- package/src/types/did.ts +31 -0
- package/src/types/external-shims.d.ts +53 -0
- package/src/types/index.ts +7 -0
- package/src/types/network.ts +175 -0
- package/src/utils/EventLogger.ts +298 -0
- package/src/utils/Logger.ts +322 -0
- package/src/utils/MetricsCollector.ts +358 -0
- package/src/utils/bitcoin-address.ts +130 -0
- package/src/utils/cbor.ts +12 -0
- package/src/utils/encoding.ts +127 -0
- package/src/utils/hash.ts +6 -0
- package/src/utils/retry.ts +46 -0
- package/src/utils/satoshi-validation.ts +196 -0
- package/src/utils/serialization.ts +96 -0
- package/src/utils/telemetry.ts +40 -0
- package/src/utils/validation.ts +119 -0
- package/src/vc/CredentialManager.ts +273 -0
- package/src/vc/Issuer.ts +100 -0
- package/src/vc/Verifier.ts +47 -0
- package/src/vc/cryptosuites/bbs.ts +253 -0
- package/src/vc/cryptosuites/bbsSimple.ts +21 -0
- package/src/vc/cryptosuites/eddsa.ts +99 -0
- package/src/vc/documentLoader.ts +67 -0
- package/src/vc/proofs/data-integrity.ts +33 -0
- package/src/vc/utils/jsonld.ts +18 -0
- package/test/logs/did_webvh_QmQsRNhXxPSCSeLjpbKYcNMZj8b1kBQAoC6cZmkFAgmpHt_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmSQkpD58qxcqMWHYcEmDUn3wk7hHvJwzYTrZmhh6zjPQ8_example_com_users_alice123_profile.jsonl +1 -0
- package/test/logs/did_webvh_QmTMda6VW3cUPdKk5Yc3onnv1vdgEumvWWdP2noAYFSjeG_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmTkb8KnCYcsnKKDCY4eUQuKQdKJLrCinvhw13v3zETxpE_example_com_users_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmTn9FdCfpXFDrxHH52pwB4iNrDFVvNDjJ5FQTcDbmM3Fg_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUCQUi1xjtJjnSQ1XJZgKqcWgErx1v7E2dz4DAPraAyJP_example_com_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmUENQJCDKBJVRS5BkL6zjaUvcRjkb9xHmy7foCgRjmv3W_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUPdGyjYBEnQ3aQUkmqyyBKTyjvCP5RZQGiaEDeTtf6dc_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUoHTuHMWzQM29ZFrE9VLtMxkZ5u869yqee8LwcCLN39M_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmUrnms8G65ggVKsr9oQeWrLUBuGChwQPPb2LCFvaoNxaw_example_com_users_alice.jsonl +1 -0
- package/test/logs/did_webvh_QmUwiw3eSXdHG1hPvoAGu3cuK5jF4aXRYDLBAjPXfv1qzb_example_com_level1_level2.jsonl +1 -0
- package/test/logs/did_webvh_QmW7bzKh6yFEKNAtmVsrPGvvsMHTUQdzJSNsTZkbuGFpbj_example_com_secret.jsonl +1 -0
- package/test/logs/did_webvh_QmXbFTFBBJ8zpjdz9WE1DNN44A2wprFmdvAubjSffeyoAG_example_com.jsonl +1 -0
- package/test/logs/did_webvh_QmXyVXFPCTffGb2mTUFDeMCsScjnpLWkyUkVkB6q6QoeBf_example_com_C_Windows_System32.jsonl +1 -0
- package/test/logs/did_webvh_QmZK9B81gxZtvo5fYHYKDtKt8zZfZZPhmCMhbujBJuRRzE_example_com_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmbNLCVSdXSVLrwFBvCBQPAabjtRb1SGHjkGVyw3QUbfBL_example_com_users_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmbeaicmGW3Q7Yzbqmftc8a9jLBngokveb5A2KVKfVGZRb_example_com_my_org_user_name_test_123.jsonl +1 -0
- package/test/logs/did_webvh_Qmdv7c7AjUreUfoKyvkN2UpAWTozxKsv99srQetPJMJEnp_example_com_users_etc_passwd.jsonl +1 -0
- package/test/logs/did_webvh_QmeioWY3uypYLkYpCXe9eCYnn4xBVruP9C1d79azMrTEHG_example_com.jsonl +1 -0
- package/test/logs/did_webvh_Qmf4QH5dsA6Ecr5HJ6KaJL9uJRyY8RxrQdqoRCM25DzvPi_example_com_users_alice.jsonl +1 -0
- package/tests/__mocks__/bbs-signatures.js +17 -0
- package/tests/__mocks__/mf-base58.js +24 -0
- package/tests/e2e/README.md +97 -0
- package/tests/e2e/example.spec.ts +78 -0
- package/tests/fixtures/did-documents.ts +247 -0
- package/tests/index.test.ts +21 -0
- package/tests/integration/BatchOperations.test.ts +531 -0
- package/tests/integration/CompleteLifecycle.e2e.test.ts +735 -0
- package/tests/integration/CredentialManager.test.ts +42 -0
- package/tests/integration/DIDManager.test.ts +41 -0
- package/tests/integration/DidPeerToWebVhFlow.test.ts +351 -0
- package/tests/integration/Events.test.ts +435 -0
- package/tests/integration/Lifecycle.transfer.btco.integration.test.ts +25 -0
- package/tests/integration/LifecycleManager.test.ts +21 -0
- package/tests/integration/MultikeyFlow.test.ts +52 -0
- package/tests/integration/TelemetryIntegration.test.ts +395 -0
- package/tests/integration/WebVhPublish.test.ts +48 -0
- package/tests/integration/migration/peer-to-webvh.test.ts +172 -0
- package/tests/manual/test-commit-creation.ts +323 -0
- package/tests/mocks/MockKeyStore.ts +38 -0
- package/tests/mocks/adapters/MemoryStorageAdapter.ts +24 -0
- package/tests/mocks/adapters/MockFeeOracle.ts +11 -0
- package/tests/mocks/adapters/MockOrdinalsProvider.ts +76 -0
- package/tests/mocks/adapters/OrdMockProvider.test.ts +176 -0
- package/tests/mocks/adapters/index.ts +6 -0
- package/tests/performance/BatchOperations.perf.test.ts +403 -0
- package/tests/performance/logging.perf.test.ts +336 -0
- package/tests/sdk.test.ts +43 -0
- package/tests/security/bitcoin-penetration-tests.test.ts +622 -0
- package/tests/setup.bun.ts +69 -0
- package/tests/setup.jest.ts +23 -0
- package/tests/stress/batch-operations-stress.test.ts +571 -0
- package/tests/unit/adapters/FeeOracleMock.test.ts +40 -0
- package/tests/unit/bitcoin/BitcoinManager.test.ts +293 -0
- package/tests/unit/bitcoin/BroadcastClient.test.ts +52 -0
- package/tests/unit/bitcoin/OrdNodeProvider.test.ts +53 -0
- package/tests/unit/bitcoin/OrdinalsClient.test.ts +381 -0
- package/tests/unit/bitcoin/OrdinalsClientProvider.test.ts +102 -0
- package/tests/unit/bitcoin/PSBTBuilder.test.ts +84 -0
- package/tests/unit/bitcoin/fee-calculation.test.ts +261 -0
- package/tests/unit/bitcoin/transactions/commit.test.ts +649 -0
- package/tests/unit/bitcoin/transfer.test.ts +31 -0
- package/tests/unit/bitcoin/utxo-selection-new.test.ts +502 -0
- package/tests/unit/bitcoin/utxo.more.test.ts +39 -0
- package/tests/unit/bitcoin/utxo.selection.test.ts +38 -0
- package/tests/unit/core/OriginalsSDK.test.ts +152 -0
- package/tests/unit/crypto/Multikey.test.ts +206 -0
- package/tests/unit/crypto/Signer.test.ts +408 -0
- package/tests/unit/did/BtcoDidResolver.test.ts +611 -0
- package/tests/unit/did/DIDManager.more.test.ts +43 -0
- package/tests/unit/did/DIDManager.test.ts +185 -0
- package/tests/unit/did/Ed25519Verifier.test.ts +160 -0
- package/tests/unit/did/KeyManager.test.ts +452 -0
- package/tests/unit/did/OrdinalsClientProviderAdapter.test.ts +45 -0
- package/tests/unit/did/WebVHManager.test.ts +435 -0
- package/tests/unit/did/createBtcoDidDocument.test.ts +67 -0
- package/tests/unit/did/providers/OrdinalsClientProviderAdapter.test.ts +159 -0
- package/tests/unit/events/EventEmitter.test.ts +407 -0
- package/tests/unit/lifecycle/BatchOperations.test.ts +527 -0
- package/tests/unit/lifecycle/LifecycleManager.keymanagement.test.ts +312 -0
- package/tests/unit/lifecycle/LifecycleManager.prov.test.ts +18 -0
- package/tests/unit/lifecycle/LifecycleManager.test.ts +213 -0
- package/tests/unit/lifecycle/LifecycleManager.transfer.unit.test.ts +30 -0
- package/tests/unit/lifecycle/OriginalsAsset.test.ts +176 -0
- package/tests/unit/lifecycle/ProvenanceQuery.test.ts +577 -0
- package/tests/unit/lifecycle/ResourceVersioning.test.ts +651 -0
- package/tests/unit/storage/MemoryStorageAdapter.test.ts +93 -0
- package/tests/unit/types/network.test.ts +255 -0
- package/tests/unit/utils/EventIntegration.test.ts +384 -0
- package/tests/unit/utils/Logger.test.ts +473 -0
- package/tests/unit/utils/MetricsCollector.test.ts +358 -0
- package/tests/unit/utils/bitcoin-address.test.ts +250 -0
- package/tests/unit/utils/cbor.test.ts +35 -0
- package/tests/unit/utils/encoding.test.ts +318 -0
- package/tests/unit/utils/hash.test.ts +12 -0
- package/tests/unit/utils/retry.test.ts +100 -0
- package/tests/unit/utils/satoshi-validation.test.ts +354 -0
- package/tests/unit/utils/serialization.test.ts +124 -0
- package/tests/unit/utils/telemetry.test.ts +52 -0
- package/tests/unit/utils/validation.test.ts +141 -0
- package/tests/unit/vc/CredentialManager.test.ts +487 -0
- package/tests/unit/vc/Issuer.test.ts +107 -0
- package/tests/unit/vc/Verifier.test.ts +525 -0
- package/tests/unit/vc/bbs.test.ts +282 -0
- package/tests/unit/vc/cryptosuites/eddsa.test.ts +398 -0
- package/tests/unit/vc/documentLoader.test.ts +121 -0
- package/tests/unit/vc/proofs/data-integrity.test.ts +24 -0
- package/tsconfig.json +32 -0
- package/tsconfig.test.json +15 -0
- package/tsconfig.tsbuildinfo +1 -0
|
@@ -0,0 +1,531 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration tests for Batch Operations
|
|
3
|
+
*
|
|
4
|
+
* Tests the complete integration of batch operations with LifecycleManager,
|
|
5
|
+
* including event emission, cost savings, and end-to-end workflows
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { describe, test, expect, beforeEach } from 'bun:test';
|
|
9
|
+
import { OriginalsSDK } from '../../src/core/OriginalsSDK';
|
|
10
|
+
import { OriginalsAsset } from '../../src/lifecycle/OriginalsAsset';
|
|
11
|
+
import { AssetResource, OriginalsConfig } from '../../src/types';
|
|
12
|
+
import { MemoryStorageAdapter } from '../../src/storage/MemoryStorageAdapter';
|
|
13
|
+
import { FeeOracleMock } from '../../src/adapters/FeeOracleMock';
|
|
14
|
+
import { OrdMockProvider } from '../../src/adapters/providers/OrdMockProvider';
|
|
15
|
+
import { StorageAdapter as ConfigStorageAdapter } from '../../src/adapters/types';
|
|
16
|
+
import { MockKeyStore } from '../mocks/MockKeyStore';
|
|
17
|
+
import type { BatchResult } from '../../src/lifecycle/BatchOperations';
|
|
18
|
+
import { KeyManager } from '../../src/did/KeyManager';
|
|
19
|
+
|
|
20
|
+
function makeHash(prefix: string): string {
|
|
21
|
+
const hexOnly = prefix.split('').map(c => {
|
|
22
|
+
if (/[0-9a-f]/i.test(c)) return c;
|
|
23
|
+
return c.charCodeAt(0).toString(16).slice(-1);
|
|
24
|
+
}).join('');
|
|
25
|
+
return hexOnly.padEnd(64, '0');
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
class StorageAdapterBridge implements ConfigStorageAdapter {
|
|
29
|
+
constructor(private memoryAdapter: MemoryStorageAdapter) {}
|
|
30
|
+
|
|
31
|
+
async put(objectKey: string, data: Buffer | string, options?: { contentType?: string }): Promise<string> {
|
|
32
|
+
const firstSlash = objectKey.indexOf('/');
|
|
33
|
+
const domain = firstSlash >= 0 ? objectKey.substring(0, firstSlash) : objectKey;
|
|
34
|
+
const path = firstSlash >= 0 ? objectKey.substring(firstSlash + 1) : '';
|
|
35
|
+
const content = typeof data === 'string' ? Buffer.from(data) : data;
|
|
36
|
+
return await this.memoryAdapter.putObject(domain, path, new Uint8Array(content));
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
async get(objectKey: string): Promise<{ content: Buffer; contentType: string } | null> {
|
|
40
|
+
const firstSlash = objectKey.indexOf('/');
|
|
41
|
+
const domain = firstSlash >= 0 ? objectKey.substring(0, firstSlash) : objectKey;
|
|
42
|
+
const path = firstSlash >= 0 ? objectKey.substring(firstSlash + 1) : '';
|
|
43
|
+
const result = await this.memoryAdapter.getObject(domain, path);
|
|
44
|
+
if (!result) return null;
|
|
45
|
+
return {
|
|
46
|
+
content: Buffer.from(result.content),
|
|
47
|
+
contentType: result.contentType || 'application/octet-stream'
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
async delete(objectKey: string): Promise<boolean> {
|
|
52
|
+
return false;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
describe('Batch Operations Integration', () => {
|
|
57
|
+
let sdk: OriginalsSDK;
|
|
58
|
+
let memoryStorage: MemoryStorageAdapter;
|
|
59
|
+
let feeOracle: FeeOracleMock;
|
|
60
|
+
let ordinalsProvider: OrdMockProvider;
|
|
61
|
+
let keyStore: MockKeyStore;
|
|
62
|
+
|
|
63
|
+
beforeEach(async () => {
|
|
64
|
+
memoryStorage = new MemoryStorageAdapter();
|
|
65
|
+
const storageAdapter = new StorageAdapterBridge(memoryStorage);
|
|
66
|
+
feeOracle = new FeeOracleMock(7);
|
|
67
|
+
ordinalsProvider = new OrdMockProvider();
|
|
68
|
+
keyStore = new MockKeyStore();
|
|
69
|
+
|
|
70
|
+
const config: OriginalsConfig = {
|
|
71
|
+
network: 'regtest',
|
|
72
|
+
defaultKeyType: 'Ed25519', // Use Ed25519 for did:webvh compatibility
|
|
73
|
+
enableLogging: false,
|
|
74
|
+
storageAdapter,
|
|
75
|
+
feeOracle,
|
|
76
|
+
ordinalsProvider
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
sdk = new OriginalsSDK(config, keyStore);
|
|
80
|
+
|
|
81
|
+
// Set up publisher DID keys for batch operation tests
|
|
82
|
+
const keyManager = new KeyManager();
|
|
83
|
+
const domains = ['example.com', 'test.com', 'batch.test'];
|
|
84
|
+
for (const domain of domains) {
|
|
85
|
+
const publisherKey = await keyManager.generateKeyPair('Ed25519');
|
|
86
|
+
await keyStore.setPrivateKey(`did:webvh:${domain}:user#key-0`, publisherKey.privateKey);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
describe('batchCreateAssets', () => {
|
|
91
|
+
test('should create multiple assets successfully', async () => {
|
|
92
|
+
const resourcesList = [
|
|
93
|
+
[
|
|
94
|
+
{ id: 'res1', type: 'image', contentType: 'image/png', hash: makeHash('img1'), content: 'image1' }
|
|
95
|
+
],
|
|
96
|
+
[
|
|
97
|
+
{ id: 'res2', type: 'text', contentType: 'text/plain', hash: makeHash('txt1'), content: 'text1' }
|
|
98
|
+
],
|
|
99
|
+
[
|
|
100
|
+
{ id: 'res3', type: 'data', contentType: 'application/json', hash: makeHash('json1'), content: '{"key":"value"}' }
|
|
101
|
+
]
|
|
102
|
+
];
|
|
103
|
+
|
|
104
|
+
const result = await sdk.lifecycle.batchCreateAssets(resourcesList);
|
|
105
|
+
|
|
106
|
+
expect(result.successful).toHaveLength(3);
|
|
107
|
+
expect(result.failed).toHaveLength(0);
|
|
108
|
+
expect(result.totalProcessed).toBe(3);
|
|
109
|
+
expect(result.batchId).toBeDefined();
|
|
110
|
+
expect(result.totalDuration).toBeGreaterThanOrEqual(0);
|
|
111
|
+
|
|
112
|
+
// Verify each asset
|
|
113
|
+
for (const item of result.successful) {
|
|
114
|
+
expect(item.result).toBeInstanceOf(OriginalsAsset);
|
|
115
|
+
expect(item.result.currentLayer).toBe('did:peer');
|
|
116
|
+
expect(item.result.id).toMatch(/^did:peer:/);
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
test('should handle validation errors', async () => {
|
|
121
|
+
const invalidResourcesList = [
|
|
122
|
+
[], // Empty resources
|
|
123
|
+
[{ id: 'res1' }] // Missing required fields
|
|
124
|
+
];
|
|
125
|
+
|
|
126
|
+
await expect(
|
|
127
|
+
sdk.lifecycle.batchCreateAssets(invalidResourcesList as any)
|
|
128
|
+
).rejects.toThrow('Batch validation failed');
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
test('should continue on error when specified', async () => {
|
|
132
|
+
const resourcesList = [
|
|
133
|
+
[
|
|
134
|
+
{ id: 'res1', type: 'image', contentType: 'image/png', hash: makeHash('img1'), content: 'image1' }
|
|
135
|
+
],
|
|
136
|
+
[], // This will fail validation at runtime
|
|
137
|
+
[
|
|
138
|
+
{ id: 'res3', type: 'text', contentType: 'text/plain', hash: makeHash('txt1'), content: 'text1' }
|
|
139
|
+
]
|
|
140
|
+
];
|
|
141
|
+
|
|
142
|
+
// Disable pre-validation to test runtime errors
|
|
143
|
+
const result = await sdk.lifecycle.batchCreateAssets(resourcesList, {
|
|
144
|
+
validateFirst: false,
|
|
145
|
+
continueOnError: true
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
expect(result.successful.length).toBeGreaterThan(0);
|
|
149
|
+
expect(result.failed.length).toBeGreaterThan(0);
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
test('should emit batch events', async () => {
|
|
153
|
+
const events: any[] = [];
|
|
154
|
+
const unsubscribe = sdk.lifecycle.on('batch:started', (event) => {
|
|
155
|
+
events.push({ type: 'started', event });
|
|
156
|
+
});
|
|
157
|
+
sdk.lifecycle.on('batch:completed', (event) => {
|
|
158
|
+
events.push({ type: 'completed', event });
|
|
159
|
+
});
|
|
160
|
+
|
|
161
|
+
const resourcesList = [
|
|
162
|
+
[{ id: 'res1', type: 'image', contentType: 'image/png', hash: makeHash('img1'), content: 'image1' }]
|
|
163
|
+
];
|
|
164
|
+
|
|
165
|
+
await sdk.lifecycle.batchCreateAssets(resourcesList);
|
|
166
|
+
|
|
167
|
+
expect(events.length).toBeGreaterThanOrEqual(2);
|
|
168
|
+
expect(events.find(e => e.type === 'started')).toBeDefined();
|
|
169
|
+
expect(events.find(e => e.type === 'completed')).toBeDefined();
|
|
170
|
+
|
|
171
|
+
const startedEvent = events.find(e => e.type === 'started').event;
|
|
172
|
+
expect(startedEvent.operation).toBe('create');
|
|
173
|
+
expect(startedEvent.itemCount).toBe(1);
|
|
174
|
+
|
|
175
|
+
unsubscribe();
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
describe('batchPublishToWeb', () => {
|
|
180
|
+
test('should publish multiple assets successfully', async () => {
|
|
181
|
+
// Create assets first
|
|
182
|
+
const assets: OriginalsAsset[] = [];
|
|
183
|
+
for (let i = 0; i < 3; i++) {
|
|
184
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
185
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
186
|
+
]);
|
|
187
|
+
assets.push(asset);
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
const result = await sdk.lifecycle.batchPublishToWeb(assets, 'example.com');
|
|
191
|
+
|
|
192
|
+
expect(result.successful).toHaveLength(3);
|
|
193
|
+
expect(result.failed).toHaveLength(0);
|
|
194
|
+
|
|
195
|
+
// Verify all assets are published
|
|
196
|
+
for (const item of result.successful) {
|
|
197
|
+
expect(item.result.currentLayer).toBe('did:webvh');
|
|
198
|
+
expect(item.result.resources[0].url).toBeDefined();
|
|
199
|
+
expect(item.result.resources[0].url).toMatch(/^did:webvh:/);
|
|
200
|
+
}
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
test('should validate domain format', async () => {
|
|
204
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
205
|
+
{ id: 'res1', type: 'text', contentType: 'text/plain', hash: makeHash('txt1'), content: 'text1' }
|
|
206
|
+
]);
|
|
207
|
+
|
|
208
|
+
await expect(
|
|
209
|
+
sdk.lifecycle.batchPublishToWeb([asset], 'invalid domain!')
|
|
210
|
+
).rejects.toThrow('Invalid domain format');
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
test('should emit batch events for publishing', async () => {
|
|
214
|
+
const events: any[] = [];
|
|
215
|
+
sdk.lifecycle.on('batch:started', (event) => {
|
|
216
|
+
events.push({ type: 'started', event });
|
|
217
|
+
});
|
|
218
|
+
sdk.lifecycle.on('batch:completed', (event) => {
|
|
219
|
+
events.push({ type: 'completed', event });
|
|
220
|
+
});
|
|
221
|
+
|
|
222
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
223
|
+
{ id: 'res1', type: 'text', contentType: 'text/plain', hash: makeHash('txt1'), content: 'text1' }
|
|
224
|
+
]);
|
|
225
|
+
|
|
226
|
+
await sdk.lifecycle.batchPublishToWeb([asset], 'example.com');
|
|
227
|
+
|
|
228
|
+
const startedEvent = events.find(e => e.type === 'started')?.event;
|
|
229
|
+
expect(startedEvent.operation).toBe('publish');
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
describe('batchInscribeOnBitcoin - Individual Transactions', () => {
|
|
234
|
+
test('should inscribe multiple assets individually', async () => {
|
|
235
|
+
const assets: OriginalsAsset[] = [];
|
|
236
|
+
for (let i = 0; i < 3; i++) {
|
|
237
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
238
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
239
|
+
]);
|
|
240
|
+
assets.push(asset);
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
const result = await sdk.lifecycle.batchInscribeOnBitcoin(assets, {
|
|
244
|
+
singleTransaction: false,
|
|
245
|
+
feeRate: 5
|
|
246
|
+
});
|
|
247
|
+
|
|
248
|
+
expect(result.successful).toHaveLength(3);
|
|
249
|
+
expect(result.failed).toHaveLength(0);
|
|
250
|
+
|
|
251
|
+
// Verify all assets are inscribed
|
|
252
|
+
for (const item of result.successful) {
|
|
253
|
+
expect(item.result.currentLayer).toBe('did:btco');
|
|
254
|
+
const provenance = item.result.getProvenance();
|
|
255
|
+
const latestMigration = provenance.migrations[provenance.migrations.length - 1];
|
|
256
|
+
expect(latestMigration.transactionId).toBeDefined();
|
|
257
|
+
expect(latestMigration.inscriptionId).toBeDefined();
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
});
|
|
261
|
+
|
|
262
|
+
describe('batchInscribeOnBitcoin - Single Transaction (Cost Savings)', () => {
|
|
263
|
+
test('should inscribe multiple assets in single transaction', async () => {
|
|
264
|
+
const assets: OriginalsAsset[] = [];
|
|
265
|
+
for (let i = 0; i < 5; i++) {
|
|
266
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
267
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
268
|
+
]);
|
|
269
|
+
assets.push(asset);
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
const result = await sdk.lifecycle.batchInscribeOnBitcoin(assets, {
|
|
273
|
+
singleTransaction: true,
|
|
274
|
+
feeRate: 10
|
|
275
|
+
});
|
|
276
|
+
|
|
277
|
+
expect(result.successful).toHaveLength(5);
|
|
278
|
+
expect(result.failed).toHaveLength(0);
|
|
279
|
+
|
|
280
|
+
// Verify all assets share the same batch transaction
|
|
281
|
+
const batchIds = new Set<string>();
|
|
282
|
+
const transactionIds = new Set<string>();
|
|
283
|
+
|
|
284
|
+
for (const item of result.successful) {
|
|
285
|
+
expect(item.result.currentLayer).toBe('did:btco');
|
|
286
|
+
const provenance = item.result.getProvenance();
|
|
287
|
+
const latestMigration = provenance.migrations[provenance.migrations.length - 1];
|
|
288
|
+
|
|
289
|
+
expect((latestMigration as any).batchId).toBeDefined();
|
|
290
|
+
expect((latestMigration as any).batchInscription).toBe(true);
|
|
291
|
+
expect((latestMigration as any).feePaid).toBeDefined();
|
|
292
|
+
|
|
293
|
+
batchIds.add((latestMigration as any).batchId);
|
|
294
|
+
transactionIds.add(latestMigration.transactionId!);
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
// All assets should share the same batch ID and transaction ID
|
|
298
|
+
expect(batchIds.size).toBe(1);
|
|
299
|
+
expect(transactionIds.size).toBe(1);
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
test('should calculate cost savings correctly', async () => {
|
|
303
|
+
const assets: OriginalsAsset[] = [];
|
|
304
|
+
for (let i = 0; i < 10; i++) {
|
|
305
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
306
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
307
|
+
]);
|
|
308
|
+
assets.push(asset);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
// Track batch events to capture cost savings
|
|
312
|
+
let costSavings: any = null;
|
|
313
|
+
sdk.lifecycle.on('batch:completed', (event) => {
|
|
314
|
+
if (event.results.costSavings) {
|
|
315
|
+
costSavings = event.results.costSavings;
|
|
316
|
+
}
|
|
317
|
+
});
|
|
318
|
+
|
|
319
|
+
await sdk.lifecycle.batchInscribeOnBitcoin(assets, {
|
|
320
|
+
singleTransaction: true,
|
|
321
|
+
feeRate: 10
|
|
322
|
+
});
|
|
323
|
+
|
|
324
|
+
expect(costSavings).toBeDefined();
|
|
325
|
+
expect(costSavings.amount).toBeGreaterThan(0);
|
|
326
|
+
expect(costSavings.percentage).toBeGreaterThan(0);
|
|
327
|
+
// Should save at least 30% as per requirements
|
|
328
|
+
expect(costSavings.percentage).toBeGreaterThanOrEqual(30);
|
|
329
|
+
});
|
|
330
|
+
|
|
331
|
+
test('should split fees proportionally by data size', async () => {
|
|
332
|
+
// Create assets of different sizes
|
|
333
|
+
const assets: OriginalsAsset[] = [];
|
|
334
|
+
|
|
335
|
+
// Small asset
|
|
336
|
+
assets.push(await sdk.lifecycle.createAsset([
|
|
337
|
+
{ id: 'small', type: 'text', contentType: 'text/plain', hash: makeHash('small'), content: 'x' }
|
|
338
|
+
]));
|
|
339
|
+
|
|
340
|
+
// Large asset
|
|
341
|
+
assets.push(await sdk.lifecycle.createAsset([
|
|
342
|
+
{ id: 'large', type: 'text', contentType: 'text/plain', hash: makeHash('large'), content: 'x'.repeat(1000) }
|
|
343
|
+
]));
|
|
344
|
+
|
|
345
|
+
const result = await sdk.lifecycle.batchInscribeOnBitcoin(assets, {
|
|
346
|
+
singleTransaction: true,
|
|
347
|
+
feeRate: 10
|
|
348
|
+
});
|
|
349
|
+
|
|
350
|
+
const smallAssetFee = (result.successful[0].result.getProvenance().migrations[0] as any).feePaid;
|
|
351
|
+
const largeAssetFee = (result.successful[1].result.getProvenance().migrations[0] as any).feePaid;
|
|
352
|
+
|
|
353
|
+
// Large asset should pay more fees
|
|
354
|
+
expect(largeAssetFee).toBeGreaterThan(smallAssetFee);
|
|
355
|
+
});
|
|
356
|
+
|
|
357
|
+
test('should handle atomic failure in single transaction mode', async () => {
|
|
358
|
+
const assets: OriginalsAsset[] = [];
|
|
359
|
+
for (let i = 0; i < 3; i++) {
|
|
360
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
361
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
362
|
+
]);
|
|
363
|
+
assets.push(asset);
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
// Mock a failure scenario by using an invalid configuration
|
|
367
|
+
// In single transaction mode, if the transaction fails, ALL assets should fail
|
|
368
|
+
try {
|
|
369
|
+
const result = await sdk.lifecycle.batchInscribeOnBitcoin(assets, {
|
|
370
|
+
singleTransaction: true,
|
|
371
|
+
feeRate: 10
|
|
372
|
+
});
|
|
373
|
+
|
|
374
|
+
// If it succeeds, all should succeed
|
|
375
|
+
expect(result.failed).toHaveLength(0);
|
|
376
|
+
} catch (error) {
|
|
377
|
+
// If it fails, it should be a BatchError
|
|
378
|
+
expect(error).toBeDefined();
|
|
379
|
+
}
|
|
380
|
+
});
|
|
381
|
+
});
|
|
382
|
+
|
|
383
|
+
describe('batchTransferOwnership', () => {
|
|
384
|
+
test('should transfer multiple assets successfully', async () => {
|
|
385
|
+
// Create and inscribe assets
|
|
386
|
+
const assets: OriginalsAsset[] = [];
|
|
387
|
+
for (let i = 0; i < 3; i++) {
|
|
388
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
389
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
390
|
+
]);
|
|
391
|
+
const inscribed = await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
392
|
+
assets.push(inscribed);
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
const transfers = assets.map(asset => ({
|
|
396
|
+
asset,
|
|
397
|
+
to: 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx'
|
|
398
|
+
}));
|
|
399
|
+
|
|
400
|
+
const result = await sdk.lifecycle.batchTransferOwnership(transfers);
|
|
401
|
+
|
|
402
|
+
expect(result.successful).toHaveLength(3);
|
|
403
|
+
expect(result.failed).toHaveLength(0);
|
|
404
|
+
|
|
405
|
+
// Verify all transfers
|
|
406
|
+
for (let i = 0; i < assets.length; i++) {
|
|
407
|
+
const provenance = assets[i].getProvenance();
|
|
408
|
+
expect(provenance.transfers).toHaveLength(1);
|
|
409
|
+
expect(provenance.transfers[0].to).toBe('tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx');
|
|
410
|
+
}
|
|
411
|
+
});
|
|
412
|
+
|
|
413
|
+
test('should validate Bitcoin addresses', async () => {
|
|
414
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
415
|
+
{ id: 'res1', type: 'text', contentType: 'text/plain', hash: makeHash('txt1'), content: 'text1' }
|
|
416
|
+
]);
|
|
417
|
+
const inscribed = await sdk.lifecycle.inscribeOnBitcoin(asset, 5);
|
|
418
|
+
|
|
419
|
+
const transfers = [
|
|
420
|
+
{ asset: inscribed, to: 'invalid-address' }
|
|
421
|
+
];
|
|
422
|
+
|
|
423
|
+
await expect(
|
|
424
|
+
sdk.lifecycle.batchTransferOwnership(transfers)
|
|
425
|
+
).rejects.toThrow();
|
|
426
|
+
});
|
|
427
|
+
|
|
428
|
+
test('should validate assets are inscribed', async () => {
|
|
429
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
430
|
+
{ id: 'res1', type: 'text', contentType: 'text/plain', hash: makeHash('txt1'), content: 'text1' }
|
|
431
|
+
]);
|
|
432
|
+
|
|
433
|
+
const transfers = [
|
|
434
|
+
{ asset, to: 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx' }
|
|
435
|
+
];
|
|
436
|
+
|
|
437
|
+
await expect(
|
|
438
|
+
sdk.lifecycle.batchTransferOwnership(transfers)
|
|
439
|
+
).rejects.toThrow('Batch validation failed');
|
|
440
|
+
});
|
|
441
|
+
});
|
|
442
|
+
|
|
443
|
+
describe('Complete Batch Lifecycle', () => {
|
|
444
|
+
test('should execute full lifecycle with batch operations', async () => {
|
|
445
|
+
// Phase 1: Batch create
|
|
446
|
+
const resourcesList = Array.from({ length: 5 }, (_, i) => [
|
|
447
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
448
|
+
]);
|
|
449
|
+
|
|
450
|
+
const createResult = await sdk.lifecycle.batchCreateAssets(resourcesList);
|
|
451
|
+
expect(createResult.successful).toHaveLength(5);
|
|
452
|
+
|
|
453
|
+
const assets = createResult.successful.map(s => s.result);
|
|
454
|
+
|
|
455
|
+
// Phase 2: Batch publish
|
|
456
|
+
const publishResult = await sdk.lifecycle.batchPublishToWeb(assets, 'batch.test');
|
|
457
|
+
expect(publishResult.successful).toHaveLength(5);
|
|
458
|
+
|
|
459
|
+
const publishedAssets = publishResult.successful.map(s => s.result);
|
|
460
|
+
|
|
461
|
+
// Phase 3: Batch inscribe with cost savings
|
|
462
|
+
const inscribeResult = await sdk.lifecycle.batchInscribeOnBitcoin(publishedAssets, {
|
|
463
|
+
singleTransaction: true,
|
|
464
|
+
feeRate: 10
|
|
465
|
+
});
|
|
466
|
+
expect(inscribeResult.successful).toHaveLength(5);
|
|
467
|
+
|
|
468
|
+
const inscribedAssets = inscribeResult.successful.map(s => s.result);
|
|
469
|
+
|
|
470
|
+
// Phase 4: Batch transfer
|
|
471
|
+
const transfers = inscribedAssets.map(asset => ({
|
|
472
|
+
asset,
|
|
473
|
+
to: 'tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx'
|
|
474
|
+
}));
|
|
475
|
+
|
|
476
|
+
const transferResult = await sdk.lifecycle.batchTransferOwnership(transfers);
|
|
477
|
+
expect(transferResult.successful).toHaveLength(5);
|
|
478
|
+
|
|
479
|
+
// Verify complete provenance chain
|
|
480
|
+
for (const asset of inscribedAssets) {
|
|
481
|
+
const provenance = asset.getProvenance();
|
|
482
|
+
expect(provenance.migrations).toHaveLength(2); // peer -> webvh -> btco
|
|
483
|
+
expect(provenance.transfers).toHaveLength(1);
|
|
484
|
+
expect(provenance.migrations[0].from).toBe('did:peer');
|
|
485
|
+
expect(provenance.migrations[0].to).toBe('did:webvh');
|
|
486
|
+
expect(provenance.migrations[1].from).toBe('did:webvh');
|
|
487
|
+
expect(provenance.migrations[1].to).toBe('did:btco');
|
|
488
|
+
}
|
|
489
|
+
});
|
|
490
|
+
});
|
|
491
|
+
|
|
492
|
+
describe('Performance and Scalability', () => {
|
|
493
|
+
test('should handle large batches efficiently', async () => {
|
|
494
|
+
const resourcesList = Array.from({ length: 50 }, (_, i) => [
|
|
495
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
496
|
+
]);
|
|
497
|
+
|
|
498
|
+
const startTime = Date.now();
|
|
499
|
+
const result = await sdk.lifecycle.batchCreateAssets(resourcesList, {
|
|
500
|
+
maxConcurrent: 5
|
|
501
|
+
});
|
|
502
|
+
const duration = Date.now() - startTime;
|
|
503
|
+
|
|
504
|
+
expect(result.successful).toHaveLength(50);
|
|
505
|
+
expect(result.totalDuration).toBeGreaterThanOrEqual(0);
|
|
506
|
+
|
|
507
|
+
// With concurrency, should complete in reasonable time
|
|
508
|
+
expect(duration).toBeLessThan(30000); // 30 seconds
|
|
509
|
+
});
|
|
510
|
+
|
|
511
|
+
test('should handle batch inscription of many assets', async () => {
|
|
512
|
+
const assets: OriginalsAsset[] = [];
|
|
513
|
+
for (let i = 0; i < 20; i++) {
|
|
514
|
+
const asset = await sdk.lifecycle.createAsset([
|
|
515
|
+
{ id: `res${i}`, type: 'text', contentType: 'text/plain', hash: makeHash(`txt${i}`), content: `text${i}` }
|
|
516
|
+
]);
|
|
517
|
+
assets.push(asset);
|
|
518
|
+
}
|
|
519
|
+
|
|
520
|
+
const startTime = Date.now();
|
|
521
|
+
const result = await sdk.lifecycle.batchInscribeOnBitcoin(assets, {
|
|
522
|
+
singleTransaction: true,
|
|
523
|
+
feeRate: 10
|
|
524
|
+
});
|
|
525
|
+
const duration = Date.now() - startTime;
|
|
526
|
+
|
|
527
|
+
expect(result.successful).toHaveLength(20);
|
|
528
|
+
expect(duration).toBeLessThan(10000); // Should be fast with single transaction
|
|
529
|
+
});
|
|
530
|
+
});
|
|
531
|
+
});
|