Skip to content

refactor(wallet-lib)!: convert to ESM, consume ESM dapi-client#3677

Closed
PastaPastaPasta wants to merge 4 commits into
dashpay:v3.1-devfrom
PastaPastaPasta:claude/esm-4-wallet-lib
Closed

refactor(wallet-lib)!: convert to ESM, consume ESM dapi-client#3677
PastaPastaPasta wants to merge 4 commits into
dashpay:v3.1-devfrom
PastaPastaPasta:claude/esm-4-wallet-lib

Conversation

@PastaPastaPasta
Copy link
Copy Markdown
Member

Summary

Converts @dashevo/wallet-lib to pure ESM so it can import the ESM dapi-client from PR 3. Drops webpack/karma and the browser-polyfill devDeps.

This is PR 4 of 5 in the stacked series. Depends on #3674, #3675, and #3676.

What changes

wallet-lib

  • package.json: "type": "module", engines.node >= 18.18. Drops scripts build:web, test:browsers*, prepublishOnly. Removes devDeps: all karma-*, webpack, browser polyfills (buffer, crypto-browserify, https-browserify, os-browserify, path-browserify, process, stream-browserify, stream-http, string_decoder, url, util, assert, browserify-zlib, events, setimmediate). Removes deps winston (replaced with console-backed logger), node-inspect-extracted.
  • All 350+ files in src/, fixtures/, and tests/ converted from CJS to ESM with .js extensions on relative imports.
  • src/logger/index.js rewritten as a console-backed logger (matching the dapi-client pattern from PR 1).
  • Deep imports of @dashevo/dapi-client updated to include .js extensions (e.g. '@dashevo/dapi-client/lib/transport/ReconnectableStream.js').
  • Deletes webpack.config.js, karma/, src/test/karma/.
  • .mocharc.yml uses require: for the ESM bootstrap (works for this package's bootstrap shape under Mocha 11 + Node 18+).

CJS-named-import conversions

Node ESM cannot statically enumerate named exports of CJS modules. So imports like import { sortBy } from 'lodash'; are replaced with import lodash from 'lodash'; const { sortBy } = lodash; across all uses of lodash, crypto-js, @dashevo/dashcore-lib, @dashevo/wasm-dpp, @dashevo/grpc-common.

Previously-silent CJS bugs that ESM strict mode catches

  • src/errors/index.js: added UnknownStrategy to the named-exports list (the class file existed but was never re-exported).
  • src/utils/coinSelections/strategies/index.js: added named exports for simpleAscendingAccumulator and simpleDescendingAccumulator (previously only available via the default STRATEGIES object, but Account.js was importing them by name).
  • src/types/DerivableKeyChain/DerivableKeyChain.spec.js: fixed type='HDPublicKey' syntax error (an implicit-global assignment that worked in CJS sloppy mode but fails in ESM strict mode).

Defensive wasm-dpp unwrap

src/plugins/Workers/IdentitySyncWorker.js uses (loadDpp.default ?? loadDpp)() because wasm-dpp is CJS and the NodeNext default import sometimes resolves to the namespace object instead of the callable.

Test plan

  • yarn workspace @dashevo/wallet-lib run test:unit377 passing, 2 pending, 0 failing
  • yarn workspace @dashevo/dapi-client run test:unit315 passing (no regression from PR 3)
  • yarn workspace dash run test:unit — TS compile still fails on dapi-client deep imports (PR 5 fixes)

Breaking changes

  • Package is ESM-only. Any require('@dashevo/wallet-lib') breaks.
  • Deep imports require .js extensions.
  • No prebuilt browser bundle. Consumers must use a modern bundler.
  • Removes bs58 from deps if unused (verified via grep).

Stack

…ton/fetch/promisify shims

Non-breaking cleanup pass; package stays CJS, no public API changes, no consumer changes required.

dapi-client: replace winston with a minimal console-backed logger that preserves the same API (.error/.warn/.info/.verbose/.debug/.silly/.getForId). Drop node-fetch and the lib/test/bootstrap setimmediate shim — Node 18+ has both globally. Drop the https.Agent self-signed-TLS branch from requestJsonRpc (was Node-only; consumers wanting this must configure NODE_TLS_REJECT_UNAUTHORIZED at the app layer). Inline lodash/sample in ListDAPIAddressProvider. Add engines.node >=18.18. Remove dependencies: winston, node-fetch, lodash, bs58 (unused), node-inspect-extracted (unused). Remove devDeps: setimmediate.

dapi-grpc: inline the promisify shim in core/v0/web/CorePromiseClient.js and platform/v0/web/PlatformPromiseClient.js so the browser bundle no longer requires Node's util module. Both files document the shim so a future codegen regen does not silently reintroduce require('util').
… API

Adds lib/utils/bytes.js helper (hexToBytes/bytesToHex/base64ToBytes/bytesToBase64/concatBytes/bytesEqual) and converts all Buffer.* call sites in dapi-client lib/ to Uint8Array, with corresponding test updates. Package stays CJS.

Production exceptions where Buffer is retained: BlockHeadersReader passes Buffer to dashcore-lib's BlockHeader (its BufferReader needs .readInt32LE), and GetIdentitiesContractKeysResponse passes Buffer to wasm-dpp's Identifier.from (it explicitly requires Node Buffer).

createGrpcTransportError now handles both raw bytes (grpc-js path) and base64 strings (grpc-web path) for drive-error-data-bin, stack-bin, and dash-serialized-consensus-error-bin metadata fields, restoring the dual-format behavior that Buffer.from(x, 'base64') used to provide implicitly.

Test updates: spec files that construct expected protobuf requests now wrap .toBuffer() with new Uint8Array(...) to match production's normalization (sinon calledOnceWithExactly distinguishes Buffer from plain Uint8Array).

Breaking change for direct consumers: response object byte fields are now Uint8Array. Callers that do response.field.toString('hex') will fail — use bytesToHex(response.field) from lib/utils/bytes instead. Buffer.isBuffer(response.field) now returns false; use response.field instanceof Uint8Array.

Test results: dapi-client 315/315, wallet-lib 377/377, js-dash-sdk 60/60 — downstream consumers continue passing without modification (they exercise dapi-client mostly via mocks).
Converts @dashevo/dapi-client to pure ESM: type: module, exports map with ./lib/* wildcard, all CJS require/module.exports replaced with import/export, .js extensions on relative imports. Engine bumped to >=18.18.

Drops webpack.config.js, karma.conf.js, and lib/test/karma/. Removes the @babel/core, babel-loader, browser-polyfill, karma, and webpack devDeps. Consumers must use a modern bundler (Vite/esbuild/webpack 5) which handles ESM natively.

Moves 'events' npm package from devDependencies to dependencies — used by DAPIClient, ReconnectableStream, and BlockHeadersProvider for EventEmitter, and resolves correctly in both Node and browser bundlers.

BREAKING: CJS consumers (require) no longer work. Downstream consumers wallet-lib (PR 4) and js-dash-sdk (PR 5) are temporarily broken between this PR merging and PRs 4/5 merging — they must land as a sequence. Dashmate is already ESM and continues to work.

Test results: dapi-client 315/315. wallet-lib + js-dash-sdk fail as expected (fixed by PRs 4 + 5).
Converts @dashevo/wallet-lib to pure ESM so it can consume the ESM dapi-client from PR 3. Adds 'type: module' to package.json. All src/, fixtures/, and tests/ files converted from CJS require/module.exports to ESM import/export with .js extensions on relative imports.

Deletes webpack.config.js, karma/, src/test/karma/. Removes browser-polyfill devDeps (buffer, crypto-browserify, stream-browserify, etc.) and webpack/karma. Tests run via Mocha in Node 18+; browser builds are out of scope. Engines: >=18.18.

CJS-named-import fixes: lodash, crypto-js, @dashevo/dashcore-lib, @dashevo/wasm-dpp, @dashevo/grpc-common all use default-import + destructure pattern because Node ESM cannot statically enumerate named exports of CJS modules.

Surfaces three previously-silent CJS bugs that ESM strict mode catches: missing UnknownStrategy export from errors/index.js, missing named exports for coinSelection strategies, and a 'type=' implicit-global in DerivableKeyChain.spec.js.

Defensive (loadDpp.default ?? loadDpp)() unwrap in IdentitySyncWorker.onStart for the same wasm-dpp NodeNext interop reason as PR 3's bootstrap.

Test results: wallet-lib 377/377 passing. dapi-client unchanged (315/315). js-dash-sdk still broken (PR 5 fixes).
@coderabbitai
Copy link
Copy Markdown
Contributor

coderabbitai Bot commented May 19, 2026

Important

Review skipped

Too many files!

This PR contains 288 files, which is 138 over the limit of 150.

To get a review, narrow the scope:
• coderabbit review --type committed # exclude uncommitted changes
• coderabbit review --dir # limit to a subdirectory
• coderabbit review --base # compare against a closer base

⚙️ Run configuration

Configuration used: defaults

Review profile: CHILL

Plan: Pro

Run ID: cf5352db-f438-453d-821c-4401e169af82

📥 Commits

Reviewing files that changed from the base of the PR and between 6a3b904 and f6bb12e.

⛔ Files ignored due to path filters (12)
  • .yarn/cache/babel-loader-npm-9.1.3-cbf4da21df-7086e67827.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/common-path-prefix-npm-3.0.0-68b78785c1-09c180e8d8.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/core-js-npm-3.33.2-08a6fba407-d62554d51c.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/find-cache-dir-npm-4.0.0-ad2504e37e-52a456a80d.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/find-up-npm-6.3.0-e5056fc655-4f3bdc30d4.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/locate-path-npm-7.2.0-0e1169e19b-1c6d269d4e.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/p-limit-npm-4.0.0-5dccf29b67-01d9d70695.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/p-locate-npm-6.0.0-b6cfb720dc-2bfe5234ef.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/path-exists-npm-5.0.0-0bf403c56c-8ca842868c.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/pkg-dir-npm-7.0.0-02ff099b31-94298b20a4.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/schema-utils-npm-4.2.0-e822c5b02e-808784735e.zip is excluded by !**/.yarn/**, !**/*.zip
  • .yarn/cache/yocto-queue-npm-1.0.0-7b502f1987-2cac84540f.zip is excluded by !**/.yarn/**, !**/*.zip
📒 Files selected for processing (288)
  • .pnp.cjs
  • packages/dapi-grpc/clients/core/v0/web/CorePromiseClient.js
  • packages/dapi-grpc/clients/platform/v0/web/PlatformPromiseClient.js
  • packages/js-dapi-client/.mocharc.yml
  • packages/js-dapi-client/karma.conf.js
  • packages/js-dapi-client/lib/BlockHeadersProvider/BlockHeadersProvider.js
  • packages/js-dapi-client/lib/BlockHeadersProvider/BlockHeadersReader.js
  • packages/js-dapi-client/lib/BlockHeadersProvider/createBlockHeadersProviderFromOptions.js
  • packages/js-dapi-client/lib/DAPIClient.js
  • packages/js-dapi-client/lib/SimplifiedMasternodeListProvider/SimplifiedMasternodeListProvider.js
  • packages/js-dapi-client/lib/SimplifiedMasternodeListProvider/createMasternodeListStreamFactory.js
  • packages/js-dapi-client/lib/dapiAddressProvider/DAPIAddress.js
  • packages/js-dapi-client/lib/dapiAddressProvider/ListDAPIAddressProvider.js
  • packages/js-dapi-client/lib/dapiAddressProvider/SimplifiedMasternodeListDAPIAddressProvider.js
  • packages/js-dapi-client/lib/dapiAddressProvider/createDAPIAddressProviderFromOptions.js
  • packages/js-dapi-client/lib/dapiAddressProvider/errors/DAPIAddressHostMissingError.js
  • packages/js-dapi-client/lib/errors/DAPIClientError.js
  • packages/js-dapi-client/lib/index.js
  • packages/js-dapi-client/lib/logger/index.js
  • packages/js-dapi-client/lib/methods/core/CoreMethodsFacade.js
  • packages/js-dapi-client/lib/methods/core/broadcastTransactionFactory.js
  • packages/js-dapi-client/lib/methods/core/getBestBlockHashFactory.js
  • packages/js-dapi-client/lib/methods/core/getBestBlockHeightFactory.js
  • packages/js-dapi-client/lib/methods/core/getBlockByHashFactory.js
  • packages/js-dapi-client/lib/methods/core/getBlockByHeightFactory.js
  • packages/js-dapi-client/lib/methods/core/getBlockHashFactory.js
  • packages/js-dapi-client/lib/methods/core/getBlockchainStatusFactory.js
  • packages/js-dapi-client/lib/methods/core/getMasternodeStatusFactory.js
  • packages/js-dapi-client/lib/methods/core/getTransaction/GetTransactionResponse.js
  • packages/js-dapi-client/lib/methods/core/getTransaction/getTransactionFactory.js
  • packages/js-dapi-client/lib/methods/core/subscribeToBlockHeadersWithChainLocksFactory.js
  • packages/js-dapi-client/lib/methods/core/subscribeToMasternodeListFactory.js
  • packages/js-dapi-client/lib/methods/core/subscribeToTransactionsWithProofsFactory.js
  • packages/js-dapi-client/lib/methods/platform/PlatformMethodsFacade.js
  • packages/js-dapi-client/lib/methods/platform/broadcastStateTransition/BroadcastStateTransitionResponse.js
  • packages/js-dapi-client/lib/methods/platform/broadcastStateTransition/broadcastStateTransitionFactory.js
  • packages/js-dapi-client/lib/methods/platform/getConsensusParams/ConsensusParamsBlock.js
  • packages/js-dapi-client/lib/methods/platform/getConsensusParams/ConsensusParamsEvidence.js
  • packages/js-dapi-client/lib/methods/platform/getConsensusParams/getConsensusParamsFactory.js
  • packages/js-dapi-client/lib/methods/platform/getConsensusParams/getConsensusParamsResponse.js
  • packages/js-dapi-client/lib/methods/platform/getDataContract/GetDataContractResponse.js
  • packages/js-dapi-client/lib/methods/platform/getDataContract/getDataContractFactory.js
  • packages/js-dapi-client/lib/methods/platform/getDataContractHistory/DataContractHistoryEntry.js
  • packages/js-dapi-client/lib/methods/platform/getDataContractHistory/GetDataContractHistoryResponse.js
  • packages/js-dapi-client/lib/methods/platform/getDataContractHistory/getDataContractHistoryFactory.js
  • packages/js-dapi-client/lib/methods/platform/getDocuments/GetDocumentsResponse.js
  • packages/js-dapi-client/lib/methods/platform/getDocuments/getDocumentsFactory.js
  • packages/js-dapi-client/lib/methods/platform/getEpochsInfo/EpochInfo.js
  • packages/js-dapi-client/lib/methods/platform/getEpochsInfo/GetEpochsInfoResponse.js
  • packages/js-dapi-client/lib/methods/platform/getEpochsInfo/getEpochsInfoFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentitiesContractKeys/GetIdentitiesContractKeysResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentitiesContractKeys/getIdentitiesContractKeysFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentity/GetIdentityResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentity/getIdentityFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityBalance/GetIdentityBalanceResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityBalance/getIdentityBalanceFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityByPublicKeyHash/GetIdentityByPublicKeyHashResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityByPublicKeyHash/getIdentityByPublicKeyHashFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityContractNonce/GetIdentityContractNonceResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityContractNonce/getIdentityContractNonceFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityKeys/GetIdentityKeysResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityKeys/getIdentityKeysFactory.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityNonce/GetIdentityNonceResponse.js
  • packages/js-dapi-client/lib/methods/platform/getIdentityNonce/getIdentityNonceFactory.js
  • packages/js-dapi-client/lib/methods/platform/getProtocolVersionUpgradeState/GetProtocolVersionUpgradeStateResponse.js
  • packages/js-dapi-client/lib/methods/platform/getProtocolVersionUpgradeState/VersionEntry.js
  • packages/js-dapi-client/lib/methods/platform/getProtocolVersionUpgradeState/getProtocolVersionUpgradeStateFactory.js
  • packages/js-dapi-client/lib/methods/platform/getProtocolVersionUpgradeVoteStatus/GetProtocolVersionUpgradeVoteStatusResponse.js
  • packages/js-dapi-client/lib/methods/platform/getProtocolVersionUpgradeVoteStatus/VersionSignal.js
  • packages/js-dapi-client/lib/methods/platform/getProtocolVersionUpgradeVoteStatus/getProtocolVersionUpgradeVoteStatusFactory.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/ChainStatus.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/GetStatusResponse.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/NetworkStatus.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/NodeStatus.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/StateSyncStatus.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/TimeStatus.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/VersionStatus.js
  • packages/js-dapi-client/lib/methods/platform/getStatus/getStatusFactory.js
  • packages/js-dapi-client/lib/methods/platform/getTotalCreditsInPlatform/GetTotalCreditsInPlatformResponse.js
  • packages/js-dapi-client/lib/methods/platform/getTotalCreditsInPlatform/getTotalCreditsInPlatformFactory.js
  • packages/js-dapi-client/lib/methods/platform/response/AbstractResponse.js
  • packages/js-dapi-client/lib/methods/platform/response/Metadata.js
  • packages/js-dapi-client/lib/methods/platform/response/Proof.js
  • packages/js-dapi-client/lib/methods/platform/response/StoreTreeProofs.js
  • packages/js-dapi-client/lib/methods/platform/response/errors/InvalidResponseError.js
  • packages/js-dapi-client/lib/methods/platform/waitForStateTransitionResult/ErrorResult.js
  • packages/js-dapi-client/lib/methods/platform/waitForStateTransitionResult/WaitForStateTransitionResultResponse.js
  • packages/js-dapi-client/lib/methods/platform/waitForStateTransitionResult/waitForStateTransitionResultFactory.js
  • packages/js-dapi-client/lib/networkConfigs.js
  • packages/js-dapi-client/lib/test/bootstrap.js
  • packages/js-dapi-client/lib/test/fixtures/getHeadersFixture.js
  • packages/js-dapi-client/lib/test/fixtures/getMNListDiffsFixture.js
  • packages/js-dapi-client/lib/test/fixtures/getMetadataFixture.js
  • packages/js-dapi-client/lib/test/fixtures/getProofFixture.js
  • packages/js-dapi-client/lib/test/fixtures/getStatusFixture.js
  • packages/js-dapi-client/lib/test/karma/bootstrap.js
  • packages/js-dapi-client/lib/test/karma/loader.js
  • packages/js-dapi-client/lib/test/mocks/BlockHeadersWithChainLocksStreamMock.js
  • packages/js-dapi-client/lib/test/mocks/mockHeadersChain.js
  • packages/js-dapi-client/lib/transport/GrpcTransport/GrpcTransport.js
  • packages/js-dapi-client/lib/transport/GrpcTransport/createGrpcTransportError.js
  • packages/js-dapi-client/lib/transport/GrpcTransport/errors/InternalServerError.js
  • packages/js-dapi-client/lib/transport/GrpcTransport/errors/NotFoundError.js
  • packages/js-dapi-client/lib/transport/GrpcTransport/errors/TimeoutError.js
  • packages/js-dapi-client/lib/transport/JsonRpcTransport/JsonRpcTransport.js
  • packages/js-dapi-client/lib/transport/JsonRpcTransport/createJsonTransportError.js
  • packages/js-dapi-client/lib/transport/JsonRpcTransport/errors/JsonRpcError.js
  • packages/js-dapi-client/lib/transport/JsonRpcTransport/errors/WrongHttpCodeError.js
  • packages/js-dapi-client/lib/transport/JsonRpcTransport/requestJsonRpc.js
  • packages/js-dapi-client/lib/transport/ReconnectableStream.js
  • packages/js-dapi-client/lib/transport/errors/NoAvailableAddressesError.js
  • packages/js-dapi-client/lib/transport/errors/response/InvalidRequestDPPError.js
  • packages/js-dapi-client/lib/transport/errors/response/InvalidRequestError.js
  • packages/js-dapi-client/lib/transport/errors/response/MaxRetriesReachedError.js
  • packages/js-dapi-client/lib/transport/errors/response/NoAvailableAddressesForRetryError.js
  • packages/js-dapi-client/lib/transport/errors/response/ResponseError.js
  • packages/js-dapi-client/lib/transport/errors/response/RetriableResponseError.js
  • packages/js-dapi-client/lib/transport/errors/response/ServerError.js
  • packages/js-dapi-client/lib/utils/bytes.js
  • packages/js-dapi-client/lib/utils/wait.js
  • packages/js-dapi-client/package.json
  • packages/js-dapi-client/polyfills/fetch-polyfill.js
  • packages/js-dapi-client/test/integration/BlockHeadersProvider/BlockHeadersProvider.spec.js
  • packages/js-dapi-client/test/integration/DAPIClient.spec.js
  • packages/js-dapi-client/test/integration/SMLProvider/SimplifiedMasternodeListProvider.spec.js
  • packages/js-dapi-client/test/integration/methods/core/CoreMethodsFacade.spec.js
  • packages/js-dapi-client/test/integration/methods/platform/PlatformMethodsFacade.spec.js
  • packages/js-dapi-client/test/unit/BlockHeadersProvider/BlockHeadersProvider.spec.js
  • packages/js-dapi-client/test/unit/BlockHeadersProvider/BlockHeadersReader.spec.js
  • packages/js-dapi-client/test/unit/BlockHeadersProvider/createBlockHeadersProviderFromOptions.spec.js
  • packages/js-dapi-client/test/unit/DAPIClient.spec.js
  • packages/js-dapi-client/test/unit/dapiAddressProvider/DAPIAddress.spec.js
  • packages/js-dapi-client/test/unit/dapiAddressProvider/ListDAPIAddressProvider.spec.js
  • packages/js-dapi-client/test/unit/dapiAddressProvider/SimplifiedMasternodeListDAPIAddressProvider.spec.js
  • packages/js-dapi-client/test/unit/dapiAddressProvider/createDAPIAddressProviderFromOptions.spec.js
  • packages/js-dapi-client/test/unit/methods/core/broadcastTransactionFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getBestBlockHashFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getBlockByHashFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getBlockByHeightFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getBlockHashFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getBlockchainStatusFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getMasternodeStatusFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getTransaction/GetTransactionResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/core/getTransaction/getTransactionFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/subscribeToBlockHeadersWithChainLocksFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/core/subscribeToTransactionsWithProofsFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/broadcaseStateTransition/broadcastStateTransitionFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getConsensusParams/ConsensusParamsBlock.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getConsensusParams/ConsensusParamsEvidence.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getConsensusParams/getConsensusParamsFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getConsensusParams/getConsensusParamsResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getDataContract/GetDataContractResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getDataContract/getDataContractFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getDataContractHistory/GetDataContractHistoryResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getDataContractHistory/getDataContractHistoryFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getDocuments/GetDocumentsResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getDocuments/getDocumentsFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getEpochsInfo/GetEpochsInfoResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getEpochsInfo/getEpochsInfoFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentitiesContractKeys/GetIdentitiesContractKeysResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentitiesContractKeys/getIdentitiesContractKeysFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentity/GetIdentityResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentity/getIdentityFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityBalance/GetIdentityBalanceResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityBalance/getIdentityBalanceFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityByPublicKeyHash/GetIdentityByPublicKeyHashResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityByPublicKeyHash/getIdentityByPublicKeyHashFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityContractNonce/GetIdentityContractNonce.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityContractNonce/getIdentityContractNonceFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityKeys/GetIdentityKeys.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityKeys/getIdentityKeysFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityNonce/GetIdentityNonce.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getIdentityNonce/getIdentityNonceFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getProtocolVersionUpgradeState/GetProtocolVersionUpgradeStateResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getProtocolVersionUpgradeState/getProtocolVersionUpgradeStateFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getProtocolVersionUpgradeVoteStatus/GetProtocolVersionUpgradeVoteStatusResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getProtocolVersionUpgradeVoteStatus/getProtocolVersionUpgradeVoteStatusFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getStatus/GetStatusResponse.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/getStatus/getStatusFactory.spec.js
  • packages/js-dapi-client/test/unit/methods/platform/waitForStateTransitionResult/waitForStateTransitionResultFactory.spec.js
  • packages/js-dapi-client/test/unit/transport/GrpcTransport/GrpcTransport.spec.js
  • packages/js-dapi-client/test/unit/transport/GrpcTransport/createGrpcTransportError.spec.js
  • packages/js-dapi-client/test/unit/transport/JsonRpcTransport/JsonRpcTransport.spec.js
  • packages/js-dapi-client/test/unit/transport/JsonRpcTransport/createJsonTransportError.spec.js
  • packages/js-dapi-client/test/unit/transport/JsonRpcTransport/requestJsonRpc.spec.js
  • packages/js-dapi-client/test/unit/transport/ReconnectableStream.spec.js
  • packages/js-dapi-client/webpack.config.js
  • packages/wallet-lib/fixtures/DummyWorker.js
  • packages/wallet-lib/fixtures/plugins/FaultyWorker.js
  • packages/wallet-lib/fixtures/plugins/WorkingWorker.js
  • packages/wallet-lib/fixtures/strategies/craftedGenerousMinerStrategy.js
  • packages/wallet-lib/fixtures/wallets/2a331817b9d6bf85100ef0/getFixtureAccountWithStorage.js
  • packages/wallet-lib/fixtures/wallets/apart-trip-dignity/categorizeTransactions.expectedResults.js
  • packages/wallet-lib/fixtures/wallets/apart-trip-dignity/getFixtureAccountWithStorage.js
  • packages/wallet-lib/karma/karma.conf.js
  • packages/wallet-lib/karma/karma.functional.conf.js
  • packages/wallet-lib/karma/options.js
  • packages/wallet-lib/package.json
  • packages/wallet-lib/src/CONSTANTS.js
  • packages/wallet-lib/src/EVENTS.js
  • packages/wallet-lib/src/adapters/InMem.js
  • packages/wallet-lib/src/adapters/inMem.spec.js
  • packages/wallet-lib/src/errors/BlockHeaderNotInStore.js
  • packages/wallet-lib/src/errors/CoinSelectionUnsufficientUTXOS.js
  • packages/wallet-lib/src/errors/CreateTransactionError.js
  • packages/wallet-lib/src/errors/IndentityIdReplaceError.js
  • packages/wallet-lib/src/errors/InjectionErrorCannotInject.js
  • packages/wallet-lib/src/errors/InjectionErrorCannotInjectUnknownDependency.js
  • packages/wallet-lib/src/errors/InjectionToPluginUnallowed.js
  • packages/wallet-lib/src/errors/InstantLockTimeoutError.js
  • packages/wallet-lib/src/errors/InvalidAddress.js
  • packages/wallet-lib/src/errors/InvalidAddressObject.js
  • packages/wallet-lib/src/errors/InvalidDashcoreTransaction.js
  • packages/wallet-lib/src/errors/InvalidOutput.js
  • packages/wallet-lib/src/errors/InvalidRawTransaction.js
  • packages/wallet-lib/src/errors/InvalidStorageAdapter.js
  • packages/wallet-lib/src/errors/InvalidStrategy.js
  • packages/wallet-lib/src/errors/InvalidTransactionObject.js
  • packages/wallet-lib/src/errors/InvalidUTXO.js
  • packages/wallet-lib/src/errors/MempoolPropagationTimeoutError.js
  • packages/wallet-lib/src/errors/PluginFailedOnStart.js
  • packages/wallet-lib/src/errors/PluginInjectionError.js
  • packages/wallet-lib/src/errors/StorageUnableToAddTransaction.js
  • packages/wallet-lib/src/errors/TransactionMetadataNotInStore.js
  • packages/wallet-lib/src/errors/TransactionNotInStore.js
  • packages/wallet-lib/src/errors/TransporterGenericError.js
  • packages/wallet-lib/src/errors/TxMetadataTimeoutError.js
  • packages/wallet-lib/src/errors/UnknownPlugin.js
  • packages/wallet-lib/src/errors/UnknownStrategy.js
  • packages/wallet-lib/src/errors/UnknownWorker.js
  • packages/wallet-lib/src/errors/ValidTransportLayerRequired.js
  • packages/wallet-lib/src/errors/WalletLibError.js
  • packages/wallet-lib/src/errors/WorkerFailedOnExecute.js
  • packages/wallet-lib/src/errors/WorkerFailedOnStart.js
  • packages/wallet-lib/src/errors/index.js
  • packages/wallet-lib/src/index.js
  • packages/wallet-lib/src/logger/index.js
  • packages/wallet-lib/src/plugins/Plugins/ChainPlugin.js
  • packages/wallet-lib/src/plugins/StandardPlugin.js
  • packages/wallet-lib/src/plugins/StandardPlugin.spec.js
  • packages/wallet-lib/src/plugins/Worker.js
  • packages/wallet-lib/src/plugins/Worker.spec.js
  • packages/wallet-lib/src/plugins/Workers/BlockHeadersSyncWorker/BlockHeadersSyncWorker.js
  • packages/wallet-lib/src/plugins/Workers/BlockHeadersSyncWorker/BlockHeadersSyncWorker.spec.js
  • packages/wallet-lib/src/plugins/Workers/IdentitySyncWorker.js
  • packages/wallet-lib/src/plugins/Workers/TransactionsSyncWorker/TransactionsReader.js
  • packages/wallet-lib/src/plugins/Workers/TransactionsSyncWorker/TransactionsReader.spec.js
  • packages/wallet-lib/src/plugins/Workers/TransactionsSyncWorker/TransactionsSyncWorker.js
  • packages/wallet-lib/src/plugins/Workers/TransactionsSyncWorker/TransactionsSyncWorker.spec.js
  • packages/wallet-lib/src/plugins/Workers/TransactionsSyncWorker/utils.js
  • packages/wallet-lib/src/plugins/Workers/TransactionsSyncWorker/utils.spec.js
  • packages/wallet-lib/src/plugins/index.js
  • packages/wallet-lib/src/test/bootstrap.js
  • packages/wallet-lib/src/test/karma/bootstrap.js
  • packages/wallet-lib/src/test/karma/loader.js
  • packages/wallet-lib/src/test/mocks/BlockHeadersStreamMock.js
  • packages/wallet-lib/src/test/mocks/LocalForageAdapterMock.js
  • packages/wallet-lib/src/test/mocks/TransportMock.js
  • packages/wallet-lib/src/test/mocks/TxStreamDataResponseMock.js
  • packages/wallet-lib/src/test/mocks/TxStreamMock.js
  • packages/wallet-lib/src/test/mocks/createAndAttachTransportMocksToWallet.js
  • packages/wallet-lib/src/test/mocks/createTransactionInAccount.js
  • packages/wallet-lib/src/test/mocks/dashcore/block.js
  • packages/wallet-lib/src/test/mocks/dashcore/instantlock.js
  • packages/wallet-lib/src/test/mocks/dashcore/transaction.js
  • packages/wallet-lib/src/test/mocks/mockBlockHeadersProvider.js
  • packages/wallet-lib/src/test/mocks/mockStorage.js
  • packages/wallet-lib/src/test/utils.js
  • packages/wallet-lib/src/transport/AbstractTransport.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/DAPIClientTransport.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/disconnect.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlock.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlock.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlockHash.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlockHash.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlockHeader.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlockHeader.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlockHeight.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBestBlockHeight.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockByHash.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockByHash.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockByHeight.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockByHeight.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockHeaderByHash.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockHeaderByHash.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockHeaderByHeight.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockHeaderByHeight.spec.js
  • packages/wallet-lib/src/transport/DAPIClientTransport/methods/getBlockchainStatus.js

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

Use the checkbox below for a quick retry:

  • 🔍 Trigger review
✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests

Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out.

❤️ Share

Comment @coderabbitai help to get the list of available commands and usage tips.

@PastaPastaPasta
Copy link
Copy Markdown
Member Author

Closing — reopening as upstream→upstream so CI runs against secrets/runners. New PR link will be added shortly.

@PastaPastaPasta
Copy link
Copy Markdown
Member Author

Reopened as #3682 (upstream→upstream so CI runs against repo secrets/runners).

Copy link
Copy Markdown
Collaborator

@thepastaclaw thepastaclaw left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This PR leaves @dashevo/wallet-lib in an incompatible intermediate state. The wasm-dpp worker report does not hold up against the package's actual CommonJS interop pattern, but the new ESM wallet-lib packaging does break current workspace consumers through unresolved extensionless deep imports and CommonJS callers that now receive ESM namespace objects instead of callable defaults.

Reviewed commit: f6bb12e8 (f6bb12e88900be8a1fddcc67e08de540b9b9c3db)

🔴 1 blocking

GitHub refused the PR diff API for this large PR (>300 files), so I’m posting the verified finding in the top-level review body instead of inline comments.

Findings

1. [blocking] packages/wallet-lib/package.json:5

Switching wallet-lib to ESM breaks existing deep-import consumers in this repo

Declaring @dashevo/wallet-lib as "type": "module" while exposing raw ./src/* entrypoints leaves existing workspace consumers on the old import shape. packages/platform-test-suite/lib/test/createClientWithFundedWallet.js:3 and packages/bench-suite/lib/client/createClientWithFundedWallet.js:5 both still do const fundWallet = require('@dashevo/wallet-lib/src/utils/fundWallet');. With the new package exports map, that extensionless subpath maps to ./src/utils/fundWallet exactly rather than ./src/utils/fundWallet.js; once corrected to .js, it is still an ESM file and require() cannot load it as the old callable CommonJS export. packages/js-dash-sdk/src/SDK/Client/Client.ts:3 has the same unresolved extensionless deep import for @dashevo/wallet-lib/src/transport/DAPIClientTransport/DAPIClientTransport. So this PR cannot be merged by itself without breaking monorepo consumers; migrate the workspace consumers in this PR, or keep the compatibility surface until the follow-up PR lands.

Inline posting could not be used because GitHub’s PR diff endpoint rejected the oversized diff; this review intentionally covers the assigned SHA.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants