diff --git a/.github/workflows/test-suite-native-e2e-android.yml b/.github/workflows/test-suite-native-e2e-android.yml index debaa53d2c5b..121e2ea0d4e6 100644 --- a/.github/workflows/test-suite-native-e2e-android.yml +++ b/.github/workflows/test-suite-native-e2e-android.yml @@ -18,73 +18,73 @@ env: NODE_ENV: "test" jobs: - build_android_test_app: - if: github.repository == 'trezor/trezor-suite' - runs-on: ubuntu-latest - steps: - - name: Checkout project - uses: actions/checkout@v4 - with: - submodules: "true" - - - name: Free Disk Space - uses: jlumbroso/free-disk-space@main - with: - # The free GH runner has limited disk space, so we need to uninstall some preinstalled tools. - dotnet: true - haskell: true - tool-cache: false - android: false - swap-storage: false - large-packages: false - - - name: Install node and yarn - uses: actions/setup-node@v4 - with: - node-version-file: ".nvmrc" - cache: yarn - - - name: Setup node_modules cache - uses: actions/cache@v4 - with: - path: node_modules - key: node_modules/${{ github.ref }}/${{github.run_id}} - - - name: Install Yarn dependencies - run: | - echo -e "\nenableScripts: false" >> .yarnrc.yml - echo -e "\nenableHardenedMode: false" >> .yarnrc.yml - yarn install - - - name: Setup Java - uses: actions/setup-java@v4 - with: - distribution: temurin - java-version: 17 - - - name: Sign message system config - working-directory: ./suite-common/message-system - run: yarn sign-config - - - name: Prebuild native expo project - working-directory: ./suite-native/app - run: yarn prebuild --platform android --clean - - - name: Build Detox test .apk - run: ../../node_modules/.bin/detox build -PreactNativeArchitectures=x86_64 --configuration android.emu.release - working-directory: ./suite-native/app - - - name: Save build to cache - uses: actions/cache/save@v4 - with: - path: | - suite-native/app/android/app/build/ - key: android_test_build/${{ github.ref }}/${{github.run_id}} + # build_android_test_app: + # if: github.repository == 'trezor/trezor-suite' + # runs-on: ubuntu-latest + # steps: + # - name: Checkout project + # uses: actions/checkout@v4 + # with: + # submodules: "true" + + # - name: Free Disk Space + # uses: jlumbroso/free-disk-space@main + # with: + # # The free GH runner has limited disk space, so we need to uninstall some preinstalled tools. + # dotnet: true + # haskell: true + # tool-cache: false + # android: false + # swap-storage: false + # large-packages: false + + # - name: Install node and yarn + # uses: actions/setup-node@v4 + # with: + # node-version-file: ".nvmrc" + # cache: yarn + + # - name: Setup node_modules cache + # uses: actions/cache@v4 + # with: + # path: node_modules + # key: node_modules/${{ github.ref }}/${{github.run_id}} + + # - name: Install Yarn dependencies + # run: | + # echo -e "\nenableScripts: false" >> .yarnrc.yml + # echo -e "\nenableHardenedMode: false" >> .yarnrc.yml + # yarn install + + # - name: Setup Java + # uses: actions/setup-java@v4 + # with: + # distribution: temurin + # java-version: 17 + + # - name: Sign message system config + # working-directory: ./suite-common/message-system + # run: yarn sign-config + + # - name: Prebuild native expo project + # working-directory: ./suite-native/app + # run: yarn prebuild --platform android --clean + + # - name: Build Detox test .apk + # run: ../../node_modules/.bin/detox build -PreactNativeArchitectures=x86_64 --configuration android.emu.release + # working-directory: ./suite-native/app + + # - name: Save build to cache + # uses: actions/cache/save@v4 + # with: + # path: | + # suite-native/app/android/app/build/ + # key: android_test_build/${{ github.ref }}/${{github.run_id}} run_android_e2e_tests: if: github.repository == 'trezor/trezor-suite' runs-on: ubuntu-latest - needs: build_android_test_app + # needs: build_android_test_app steps: - name: Checkout project uses: actions/checkout@v4 @@ -113,7 +113,7 @@ jobs: uses: actions/cache@v4 with: path: node_modules - key: node_modules/${{ github.ref }}/${{github.run_id}} + key: node_modules/refs/heads/currents-suite-lite/12231436913 - name: Install Yarn dependencies run: | @@ -159,6 +159,23 @@ jobs: avd-name: ${{ steps.device.outputs.AVD_NAME }} emulator-options: -no-window -gpu swiftshader_indirect -no-snapshot -noaudio -no-boot-anim -grpc 8554 script: yarn test:e2e android.emu.release --headless --take-screenshots failing --record-videos failing + + - name: Upload results to Currents.dev + if: ${{ ! cancelled() }} + env: + CURRENTS_PROJECT_ID: 4ytF0E + CURRENTS_RECORD_KEY: ${{ secrets.CURRENTS_RECORD_KEY }} + working-directory: ./suite-native/app + run: | + pwd + ls + npx currents convert \ + --input-format=junit \ + --input-file=./reports/junit-report.xml \ + --output-dir=./currents \ + --framework=postman \ + --framework-version=v11.2.0 + npx currents upload --project-id=${CURRENTS_PROJECT_ID} --key=${CURRENTS_RECORD_KEY} - name: "Store failed test screenshot artifacts" if: ${{failure()}} diff --git a/suite-native/app/e2e/jest.config.js b/suite-native/app/e2e/jest.config.js index e06b28d5f447..ff9a283870fd 100644 --- a/suite-native/app/e2e/jest.config.js +++ b/suite-native/app/e2e/jest.config.js @@ -7,7 +7,10 @@ module.exports = { testTimeout: 120000, globalSetup: 'detox/runners/jest/globalSetup', globalTeardown: 'detox/runners/jest/globalTeardown', - reporters: ['detox/runners/jest/reporter'], + reporters: [ + 'detox/runners/jest/reporter', + ["jest-junit", { outputDirectory: "./reports", outputName: "junit-report.xml" }] + ], testEnvironment: 'detox/runners/jest/testEnvironment', verbose: true, maxWorkers: 1, diff --git a/suite-native/app/e2e/tests/accountManagement.test.ts b/suite-native/app/e2e/tests/accountManagement.test.ts index f62a2f1d3e99..8d7c3c9089a8 100644 --- a/suite-native/app/e2e/tests/accountManagement.test.ts +++ b/suite-native/app/e2e/tests/accountManagement.test.ts @@ -10,7 +10,7 @@ import { onAccountDetailSettings } from '../pageObjects/accountDetailSettingsAct import { onMyAssets } from '../pageObjects/myAssetsActions'; import { onTabBar } from '../pageObjects/tabBarActions'; -describe('Account management', () => { +describe.skip('Account management', () => { beforeAll(async () => { await openApp({ newInstance: true }); await onOnboarding.finishOnboarding(); diff --git a/suite-native/app/e2e/tests/bitcoinAccountsImport.test.ts b/suite-native/app/e2e/tests/bitcoinAccountsImport.test.ts index 95b813af3b02..0e3604da2283 100644 --- a/suite-native/app/e2e/tests/bitcoinAccountsImport.test.ts +++ b/suite-native/app/e2e/tests/bitcoinAccountsImport.test.ts @@ -5,7 +5,7 @@ import { onMyAssets } from '../pageObjects/myAssetsActions'; import { onOnboarding } from '../pageObjects/onboardingActions'; import { onTabBar } from '../pageObjects/tabBarActions'; -describe('Import Bitcoin network accounts.', () => { +describe.skip('Import Bitcoin network accounts.', () => { beforeAll(async () => { await openApp({ newInstance: true }); await onOnboarding.finishOnboarding(); diff --git a/suite-native/app/e2e/tests/deeplinkPopup.test.ts b/suite-native/app/e2e/tests/deeplinkPopup.test.ts index 2d2da1e46b97..048db18a3a61 100644 --- a/suite-native/app/e2e/tests/deeplinkPopup.test.ts +++ b/suite-native/app/e2e/tests/deeplinkPopup.test.ts @@ -105,7 +105,7 @@ conditionalDescribe(device.getPlatform() !== 'android', 'Deeplink connect popup. await device.terminateApp(); }); - it('Handle deeplink', async () => { + it.skip('Handle deeplink', async () => { const promise = TrezorConnect.getAddress({ path: "m/49'/0'/0'/0/0", coin: 'btc', diff --git a/suite-native/app/e2e/tests/deviceSettings.test.ts b/suite-native/app/e2e/tests/deviceSettings.test.ts index 161c71aa8306..6af99aa0f25d 100644 --- a/suite-native/app/e2e/tests/deviceSettings.test.ts +++ b/suite-native/app/e2e/tests/deviceSettings.test.ts @@ -45,7 +45,7 @@ conditionalDescribe(device.getPlatform() !== 'android', 'Device settings', () => await device.terminateApp(); }); - test('Enable, change & disable PIN', async () => { + test.skip('Enable, change & disable PIN', async () => { await onDeviceSettings.tapEnablePinProtectionButton(); await TrezorUserEnvLink.pressNo(); @@ -78,7 +78,7 @@ conditionalDescribe(device.getPlatform() !== 'android', 'Device settings', () => await onDeviceSettings.waitForScreen(); }); - test('Check device authenticity', async () => { + test.skip('Check device authenticity', async () => { await onDeviceSettings.scrollUntilCheckAuthenticityButtonIsVisible(); await onDeviceSettings.tapCheckAuthenticityButton(); diff --git a/suite-native/app/e2e/tests/invalidAccountsImport.test.ts b/suite-native/app/e2e/tests/invalidAccountsImport.test.ts index 8f5bef2396d6..d55ce91eaba8 100644 --- a/suite-native/app/e2e/tests/invalidAccountsImport.test.ts +++ b/suite-native/app/e2e/tests/invalidAccountsImport.test.ts @@ -13,7 +13,7 @@ const goToBtcImportXpubScreen = async () => { await onAccountImport.selectCoin({ networkSymbol: 'btc' }); }; -describe('Import invalid accounts', () => { +describe.skip('Import invalid accounts', () => { beforeAll(async () => { await openApp({ newInstance: true }); await onOnboarding.finishOnboarding(); diff --git a/suite-native/app/e2e/tests/onboardAndConnect.test.ts b/suite-native/app/e2e/tests/onboardAndConnect.test.ts index 389adc0d1755..f638ae5e3521 100644 --- a/suite-native/app/e2e/tests/onboardAndConnect.test.ts +++ b/suite-native/app/e2e/tests/onboardAndConnect.test.ts @@ -8,7 +8,7 @@ import { onCoinEnablingInit } from '../pageObjects/coinEnablingActions'; const platform = device.getPlatform(); -describe('Go through onboarding and connect Trezor.', () => { +describe.skip('Go through onboarding and connect Trezor.', () => { beforeAll(async () => { await prepareTrezorEmulator(); diff --git a/suite-native/app/e2e/tests/othersAccountsImport.test.ts b/suite-native/app/e2e/tests/othersAccountsImport.test.ts index 407f48e562e5..5f77030aa9c4 100644 --- a/suite-native/app/e2e/tests/othersAccountsImport.test.ts +++ b/suite-native/app/e2e/tests/othersAccountsImport.test.ts @@ -5,7 +5,7 @@ import { onMyAssets } from '../pageObjects/myAssetsActions'; import { onOnboarding } from '../pageObjects/onboardingActions'; import { onTabBar } from '../pageObjects/tabBarActions'; -describe('Import accounts of other networks.', () => { +describe.skip('Import accounts of other networks.', () => { beforeAll(async () => { await openApp({ newInstance: true }); await onOnboarding.finishOnboarding(); diff --git a/suite-native/app/e2e/tests/send.test.ts b/suite-native/app/e2e/tests/send.test.ts index 91a42cb342b5..4eaf7a90d38b 100644 --- a/suite-native/app/e2e/tests/send.test.ts +++ b/suite-native/app/e2e/tests/send.test.ts @@ -104,13 +104,13 @@ conditionalDescribe(device.getPlatform() !== 'android', 'Send transaction flow.' disconnectTrezorUserEnv(); }); - it('Compose and dispatch a regtest transaction.', async () => { + it.skip('Compose and dispatch a regtest transaction.', async () => { await prepareTransactionForOnDeviceReview({ isFormEmpty: true }); await signTransactionAndSendIt(); }); - it('Compose and dispatch a regtest transaction with a custom fee.', async () => { + it.skip('Compose and dispatch a regtest transaction with a custom fee.', async () => { await prepareTransactionForOnDeviceReview({ feeValues: { feeType: 'custom', customFeePerUnit: '100' }, }); @@ -118,7 +118,7 @@ conditionalDescribe(device.getPlatform() !== 'android', 'Send transaction flow.' await signTransactionAndSendIt(); }); - it('Validate send form input errors.', async () => { + it.skip('Validate send form input errors.', async () => { await onSendOutputsForm.fillForm([{ address: 'wrong address', amount: '200' }]); await waitFor(element(by.text(SEND_FORM_ERROR_MESSAGES.invalidAddress))).toBeVisible(); @@ -138,7 +138,7 @@ conditionalDescribe(device.getPlatform() !== 'android', 'Send transaction flow.' await waitFor(element(by.text(SEND_FORM_ERROR_MESSAGES.tooManyDecimals))).toBeVisible(); }); - it('Review cancellation and error handling.', async () => { + it.skip('Review cancellation and error handling.', async () => { await prepareTransactionForOnDeviceReview({ isFormEmpty: true }); // Cancel button should go back if the on device review was not started yet. diff --git a/suite-native/app/package.json b/suite-native/app/package.json index 0be1091e9bd7..a4031fa6c3cb 100644 --- a/suite-native/app/package.json +++ b/suite-native/app/package.json @@ -126,6 +126,7 @@ "@babel/core": "^7.20.0", "@babel/plugin-transform-export-namespace-from": "^7.23.4", "@config-plugins/detox": "^8.0.0", + "@currents/cmd": "^1.6.0", "@react-native/babel-preset": "^0.75.2", "@suite-common/test-utils": "workspace:^", "@trezor/connect-mobile": "workspace:^", @@ -136,6 +137,7 @@ "detox": "^20.25.6", "expo-atlas": "0.3.27", "jest": "^29.7.0", + "jest-junit": "^16.0.0", "metro": "0.81.0", "ts-jest": "^29.1.2", "typescript": "^5.3.3" diff --git a/yarn.lock b/yarn.lock index 153b446c9262..3d6695910c62 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2037,6 +2037,15 @@ __metadata: languageName: node linkType: hard +"@commander-js/extra-typings@npm:^12.1.0": + version: 12.1.0 + resolution: "@commander-js/extra-typings@npm:12.1.0" + peerDependencies: + commander: ~12.1.0 + checksum: 10/489ef40dcf18508da5d8db288fa1536e294773b8d07e4c1edee6709972fe4310e3713819ef10bdc1d234615c5cf42df6acf9ddce0b31c6c8114be704fd626971 + languageName: node + linkType: hard + "@config-plugins/detox@npm:^8.0.0": version: 8.0.0 resolution: "@config-plugins/detox@npm:8.0.0" @@ -2265,6 +2274,46 @@ __metadata: languageName: node linkType: hard +"@currents/cmd@npm:^1.6.0": + version: 1.6.0 + resolution: "@currents/cmd@npm:1.6.0" + dependencies: + "@commander-js/extra-typings": "npm:^12.1.0" + "@currents/commit-info": "npm:1.0.1-beta.0" + archiver: "npm:^7.0.1" + async-retry: "npm:^1.3.3" + axios: "npm:^1.7.2" + axios-retry: "npm:^4.5.0" + chalk: "npm:^4.1.2" + commander: "npm:^11.1.0" + debug: "npm:^4.3.5" + dotenv: "npm:^16.4.5" + execa: "npm:^9.5.1" + fs-extra: "npm:^11.2.0" + getos: "npm:^3.2.1" + glob: "npm:^11.0.0" + https-proxy-agent: "npm:^7.0.4" + jest-cli: "npm:^29.7.0" + jest-config: "npm:^29.7.0" + lodash: "npm:^4.17.21" + nanoid: "npm:^3.3.4" + pretty-ms: "npm:^7.0.1" + proxy-from-env: "npm:^1.1.0" + semver: "npm:^7.6.0" + source-map-support: "npm:^0.5.21" + tmp: "npm:^0.2.3" + tmp-promise: "npm:^3.0.3" + ts-pattern: "npm:^5.5.0" + unzipper: "npm:^0.12.3" + uuid: "npm:^11.0.3" + xml2js: "npm:^0.6.2" + bin: + currents: dist/bin/index.js + currents-cli: dist/bin/index.js + checksum: 10/266428f7109379992c82be87bdbd9ee844c283fbd01d2c722861877294f3c54ca408890a62800b21afbb1e124b777ac9662036c69af7fa36f16bd1e7c664f858 + languageName: node + linkType: hard + "@currents/commit-info@npm:1.0.1-beta.0": version: 1.0.1-beta.0 resolution: "@currents/commit-info@npm:1.0.1-beta.0" @@ -7099,6 +7148,13 @@ __metadata: languageName: node linkType: hard +"@sec-ant/readable-stream@npm:^0.4.1": + version: 0.4.1 + resolution: "@sec-ant/readable-stream@npm:0.4.1" + checksum: 10/aac89581652ac85debe7c5303451c2ebf8bf25ca25db680e4b9b73168f6940616d9a4bbe3348981827b1159b14e2f2e6af4b7bd5735cac898c12d5c51909c102 + languageName: node + linkType: hard + "@segment/loosely-validate-event@npm:^2.0.0": version: 2.0.0 resolution: "@segment/loosely-validate-event@npm:2.0.0" @@ -7766,6 +7822,13 @@ __metadata: languageName: node linkType: hard +"@sindresorhus/merge-streams@npm:^4.0.0": + version: 4.0.0 + resolution: "@sindresorhus/merge-streams@npm:4.0.0" + checksum: 10/16551c787f5328c8ef05fd9831ade64369ccc992df78deb635ec6c44af217d2f1b43f8728c348cdc4e00585ff2fad6e00d8155199cbf6b154acc45fe65cbf0aa + languageName: node + linkType: hard + "@sinonjs/commons@npm:^2.0.0": version: 2.0.0 resolution: "@sinonjs/commons@npm:2.0.0" @@ -9641,6 +9704,7 @@ __metadata: "@babel/core": "npm:^7.20.0" "@babel/plugin-transform-export-namespace-from": "npm:^7.23.4" "@config-plugins/detox": "npm:^8.0.0" + "@currents/cmd": "npm:^1.6.0" "@gorhom/bottom-sheet": "npm:5.0.5" "@mobily/ts-belt": "npm:^3.13.1" "@react-native-community/netinfo": "npm:^11.4.1" @@ -9735,6 +9799,7 @@ __metadata: expo-updates: "npm:0.26.6" expo-video: "npm:^2.0.1" jest: "npm:^29.7.0" + jest-junit: "npm:^16.0.0" lottie-react-native: "npm:^7.1.0" metro: "npm:0.81.0" node-libs-browser: "npm:^2.2.1" @@ -14929,6 +14994,13 @@ __metadata: languageName: node linkType: hard +"agent-base@npm:^7.1.2": + version: 7.1.3 + resolution: "agent-base@npm:7.1.3" + checksum: 10/3db6d8d4651f2aa1a9e4af35b96ab11a7607af57a24f3bc721a387eaa3b5f674e901f0a648b0caefd48f3fd117c7761b79a3b55854e2aebaa96c3f32cf76af84 + languageName: node + linkType: hard + "agentkeepalive@npm:^4.5.0": version: 4.5.0 resolution: "agentkeepalive@npm:4.5.0" @@ -15258,6 +15330,36 @@ __metadata: languageName: node linkType: hard +"archiver-utils@npm:^5.0.0, archiver-utils@npm:^5.0.2": + version: 5.0.2 + resolution: "archiver-utils@npm:5.0.2" + dependencies: + glob: "npm:^10.0.0" + graceful-fs: "npm:^4.2.0" + is-stream: "npm:^2.0.1" + lazystream: "npm:^1.0.0" + lodash: "npm:^4.17.15" + normalize-path: "npm:^3.0.0" + readable-stream: "npm:^4.0.0" + checksum: 10/9dde4aa3f0cb1bdfe0b3d4c969f82e6cca9ae76338b7fee6f0071a14a2a38c0cdd1c41ecd3e362466585aa6cc5d07e9e435abea8c94fd9c7ace35f184abef9e4 + languageName: node + linkType: hard + +"archiver@npm:^7.0.1": + version: 7.0.1 + resolution: "archiver@npm:7.0.1" + dependencies: + archiver-utils: "npm:^5.0.2" + async: "npm:^3.2.4" + buffer-crc32: "npm:^1.0.0" + readable-stream: "npm:^4.0.0" + readdir-glob: "npm:^1.1.2" + tar-stream: "npm:^3.0.0" + zip-stream: "npm:^6.0.1" + checksum: 10/81c6102db99d7ffd5cb2aed02a678f551c6603991a059ca66ef59249942b835a651a3d3b5240af4f8bec4e61e13790357c9d1ad4a99982bd2cc4149575c31d67 + languageName: node + linkType: hard + "arg@npm:1.0.0": version: 1.0.0 resolution: "arg@npm:1.0.0" @@ -15632,6 +15734,13 @@ __metadata: languageName: node linkType: hard +"async@npm:^3.2.4": + version: 3.2.6 + resolution: "async@npm:3.2.6" + checksum: 10/cb6e0561a3c01c4b56a799cc8bab6ea5fef45f069ab32500b6e19508db270ef2dffa55e5aed5865c5526e9907b1f8be61b27530823b411ffafb5e1538c86c368 + languageName: node + linkType: hard + "asynckit@npm:^0.4.0": version: 0.4.0 resolution: "asynckit@npm:0.4.0" @@ -15718,6 +15827,17 @@ __metadata: languageName: node linkType: hard +"axios-retry@npm:^4.5.0": + version: 4.5.0 + resolution: "axios-retry@npm:4.5.0" + dependencies: + is-retry-allowed: "npm:^2.2.0" + peerDependencies: + axios: 0.x || 1.x + checksum: 10/39ed05248757387a44dde94255df8ad54088aece50574c6ce9a1cd02b9e40252f7390285cea54ded04e33a3a549e462d5bdacc8d3178221b7cd40e8aff09ba46 + languageName: node + linkType: hard + "axios@npm:1.6.2": version: 1.6.2 resolution: "axios@npm:1.6.2" @@ -15749,6 +15869,17 @@ __metadata: languageName: node linkType: hard +"axios@npm:^1.7.2": + version: 1.7.9 + resolution: "axios@npm:1.7.9" + dependencies: + follow-redirects: "npm:^1.15.6" + form-data: "npm:^4.0.0" + proxy-from-env: "npm:^1.1.0" + checksum: 10/b7a5f660ea53ba9c2a745bf5ad77ad8bf4f1338e13ccc3f9f09f810267d6c638c03dac88b55dae8dc98b79c57d2d6835be651d58d2af97c174f43d289a9fd007 + languageName: node + linkType: hard + "axobject-query@npm:^4.1.0": version: 4.1.0 resolution: "axobject-query@npm:4.1.0" @@ -16365,7 +16496,7 @@ __metadata: languageName: node linkType: hard -"bluebird@npm:^3.5.4, bluebird@npm:^3.5.5, bluebird@npm:^3.7.2": +"bluebird@npm:^3.5.4, bluebird@npm:^3.5.5, bluebird@npm:^3.7.2, bluebird@npm:~3.7.2": version: 3.7.2 resolution: "bluebird@npm:3.7.2" checksum: 10/007c7bad22c5d799c8dd49c85b47d012a1fe3045be57447721e6afbd1d5be43237af1db62e26cb9b0d9ba812d2e4ca3bac82f6d7e016b6b88de06ee25ceb96e7 @@ -16781,6 +16912,13 @@ __metadata: languageName: node linkType: hard +"buffer-crc32@npm:^1.0.0": + version: 1.0.0 + resolution: "buffer-crc32@npm:1.0.0" + checksum: 10/ef3b7c07622435085c04300c9a51e850ec34a27b2445f758eef69b859c7827848c2282f3840ca6c1eef3829145a1580ce540cab03ccf4433827a2b95d3b09ca7 + languageName: node + linkType: hard + "buffer-crc32@npm:~0.2.3": version: 0.2.13 resolution: "buffer-crc32@npm:0.2.13" @@ -18068,6 +18206,19 @@ __metadata: languageName: node linkType: hard +"compress-commons@npm:^6.0.2": + version: 6.0.2 + resolution: "compress-commons@npm:6.0.2" + dependencies: + crc-32: "npm:^1.2.0" + crc32-stream: "npm:^6.0.0" + is-stream: "npm:^2.0.1" + normalize-path: "npm:^3.0.0" + readable-stream: "npm:^4.0.0" + checksum: 10/78e3ba10aeef919a1c5bbac21e120f3e1558a31b2defebbfa1635274fc7f7e8a3a0ee748a06249589acd0b33a0d58144b8238ff77afc3220f8d403a96fcc13aa + languageName: node + linkType: hard + "compressible@npm:^2.0.0, compressible@npm:~2.0.16": version: 2.0.18 resolution: "compressible@npm:2.0.18" @@ -18504,6 +18655,16 @@ __metadata: languageName: node linkType: hard +"crc32-stream@npm:^6.0.0": + version: 6.0.0 + resolution: "crc32-stream@npm:6.0.0" + dependencies: + crc-32: "npm:^1.2.0" + readable-stream: "npm:^4.0.0" + checksum: 10/e6edc2f81bc387daef6d18b2ac18c2ffcb01b554d3b5c7d8d29b177505aafffba574658fdd23922767e8dab1183d1962026c98c17e17fb272794c33293ef607c + languageName: node + linkType: hard + "crc@npm:^3.8.0": version: 3.8.0 resolution: "crc@npm:3.8.0" @@ -22234,6 +22395,26 @@ __metadata: languageName: node linkType: hard +"execa@npm:^9.5.1": + version: 9.5.2 + resolution: "execa@npm:9.5.2" + dependencies: + "@sindresorhus/merge-streams": "npm:^4.0.0" + cross-spawn: "npm:^7.0.3" + figures: "npm:^6.1.0" + get-stream: "npm:^9.0.0" + human-signals: "npm:^8.0.0" + is-plain-obj: "npm:^4.1.0" + is-stream: "npm:^4.0.1" + npm-run-path: "npm:^6.0.0" + pretty-ms: "npm:^9.0.0" + signal-exit: "npm:^4.1.0" + strip-final-newline: "npm:^4.0.0" + yoctocolors: "npm:^2.0.0" + checksum: 10/652fa492e7e1052becba12275aafd1c3d249967a4400f798877aa6c21fafcd8182ee3ce09a54f0379785635f32a4adeef77b2edb83d7e8a55b06819ed102ff2a + languageName: node + linkType: hard + "executable@npm:^4.1.1": version: 4.1.1 resolution: "executable@npm:4.1.1" @@ -23326,6 +23507,15 @@ __metadata: languageName: node linkType: hard +"figures@npm:^6.1.0": + version: 6.1.0 + resolution: "figures@npm:6.1.0" + dependencies: + is-unicode-supported: "npm:^2.0.0" + checksum: 10/9822d13630bee8e6a9f2da866713adf13854b07e0bfde042defa8bba32d47a1c0b2afa627ce73837c674cf9a5e3edce7e879ea72cb9ea7960b2390432d8e1167 + languageName: node + linkType: hard + "file-entry-cache@npm:^8.0.0": version: 8.0.0 resolution: "file-entry-cache@npm:8.0.0" @@ -24094,6 +24284,16 @@ __metadata: languageName: node linkType: hard +"get-stream@npm:^9.0.0": + version: 9.0.1 + resolution: "get-stream@npm:9.0.1" + dependencies: + "@sec-ant/readable-stream": "npm:^0.4.1" + is-stream: "npm:^4.0.1" + checksum: 10/ce56e6db6bcd29ca9027b0546af035c3e93dcd154ca456b54c298901eb0e5b2ce799c5d727341a100c99e14c523f267f1205f46f153f7b75b1f4da6d98a21c5e + languageName: node + linkType: hard + "get-symbol-description@npm:^1.0.2": version: 1.0.2 resolution: "get-symbol-description@npm:1.0.2" @@ -24541,7 +24741,7 @@ __metadata: languageName: node linkType: hard -"graceful-fs@npm:^4.1.11, graceful-fs@npm:^4.1.2, graceful-fs@npm:^4.1.6, graceful-fs@npm:^4.1.9, graceful-fs@npm:^4.2.0, graceful-fs@npm:^4.2.10, graceful-fs@npm:^4.2.11, graceful-fs@npm:^4.2.4, graceful-fs@npm:^4.2.6, graceful-fs@npm:^4.2.9": +"graceful-fs@npm:^4.1.11, graceful-fs@npm:^4.1.2, graceful-fs@npm:^4.1.6, graceful-fs@npm:^4.1.9, graceful-fs@npm:^4.2.0, graceful-fs@npm:^4.2.10, graceful-fs@npm:^4.2.11, graceful-fs@npm:^4.2.2, graceful-fs@npm:^4.2.4, graceful-fs@npm:^4.2.6, graceful-fs@npm:^4.2.9": version: 4.2.11 resolution: "graceful-fs@npm:4.2.11" checksum: 10/bf152d0ed1dc159239db1ba1f74fdbc40cb02f626770dcd5815c427ce0688c2635a06ed69af364396da4636d0408fcf7d4afdf7881724c3307e46aff30ca49e2 @@ -25518,6 +25718,16 @@ __metadata: languageName: node linkType: hard +"https-proxy-agent@npm:^7.0.4": + version: 7.0.6 + resolution: "https-proxy-agent@npm:7.0.6" + dependencies: + agent-base: "npm:^7.1.2" + debug: "npm:4" + checksum: 10/784b628cbd55b25542a9d85033bdfd03d4eda630fb8b3c9477959367f3be95dc476ed2ecbb9836c359c7c698027fc7b45723a302324433590f45d6c1706e8c13 + languageName: node + linkType: hard + "human-signals@npm:^1.1.1": version: 1.1.1 resolution: "human-signals@npm:1.1.1" @@ -25539,6 +25749,13 @@ __metadata: languageName: node linkType: hard +"human-signals@npm:^8.0.0": + version: 8.0.0 + resolution: "human-signals@npm:8.0.0" + checksum: 10/89acdc7081ac2a065e41cca7351c4b0fe2382e213b7372f90df6a554e340f31b49388a307adc1d6f4c60b2b4fe81eeff0bc1f44be6f5d844311cd92ccc7831c6 + languageName: node + linkType: hard + "humanize-ms@npm:^1.2.1": version: 1.2.1 resolution: "humanize-ms@npm:1.2.1" @@ -26388,7 +26605,7 @@ __metadata: languageName: node linkType: hard -"is-plain-obj@npm:^4.0.0": +"is-plain-obj@npm:^4.0.0, is-plain-obj@npm:^4.1.0": version: 4.1.0 resolution: "is-plain-obj@npm:4.1.0" checksum: 10/6dc45da70d04a81f35c9310971e78a6a3c7a63547ef782e3a07ee3674695081b6ca4e977fbb8efc48dae3375e0b34558d2bcd722aec9bddfa2d7db5b041be8ce @@ -26490,7 +26707,7 @@ __metadata: languageName: node linkType: hard -"is-stream@npm:^2.0.0": +"is-stream@npm:^2.0.0, is-stream@npm:^2.0.1": version: 2.0.1 resolution: "is-stream@npm:2.0.1" checksum: 10/b8e05ccdf96ac330ea83c12450304d4a591f9958c11fd17bed240af8d5ffe08aedafa4c0f4cfccd4d28dc9d4d129daca1023633d5c11601a6cbc77521f6fae66 @@ -26504,6 +26721,13 @@ __metadata: languageName: node linkType: hard +"is-stream@npm:^4.0.1": + version: 4.0.1 + resolution: "is-stream@npm:4.0.1" + checksum: 10/cbea3f1fc271b21ceb228819d0c12a0965a02b57f39423925f99530b4eb86935235f258f06310b67cd02b2d10b49e9a0998f5ececf110ab7d3760bae4055ad23 + languageName: node + linkType: hard + "is-string@npm:^1.0.5, is-string@npm:^1.0.7": version: 1.0.7 resolution: "is-string@npm:1.0.7" @@ -26545,6 +26769,13 @@ __metadata: languageName: node linkType: hard +"is-unicode-supported@npm:^2.0.0": + version: 2.1.0 + resolution: "is-unicode-supported@npm:2.1.0" + checksum: 10/f254e3da6b0ab1a57a94f7273a7798dd35d1d45b227759f600d0fa9d5649f9c07fa8d3c8a6360b0e376adf916d151ec24fc9a50c5295c58bae7ca54a76a063f9 + languageName: node + linkType: hard + "is-weakmap@npm:^2.0.1": version: 2.0.1 resolution: "is-weakmap@npm:2.0.1" @@ -27160,6 +27391,18 @@ __metadata: languageName: node linkType: hard +"jest-junit@npm:^16.0.0": + version: 16.0.0 + resolution: "jest-junit@npm:16.0.0" + dependencies: + mkdirp: "npm:^1.0.4" + strip-ansi: "npm:^6.0.1" + uuid: "npm:^8.3.2" + xml: "npm:^1.0.1" + checksum: 10/2c33ee8bfd0c83b9aa1f8ba5905084890d5f519d294ccc2829d778ac860d5adffffec75d930f44f1d498aa8370c783e0aa6a632d947fb7e81205f0e7b926669d + languageName: node + linkType: hard + "jest-leak-detector@npm:^29.7.0": version: 29.7.0 resolution: "jest-leak-detector@npm:29.7.0" @@ -28491,6 +28734,15 @@ __metadata: languageName: node linkType: hard +"lazystream@npm:^1.0.0": + version: 1.0.1 + resolution: "lazystream@npm:1.0.1" + dependencies: + readable-stream: "npm:^2.0.5" + checksum: 10/35f8cf8b5799c76570b211b079d4d706a20cbf13a4936d44cc7dbdacab1de6b346ab339ed3e3805f4693155ee5bbebbda4050fa2b666d61956e89a573089e3d4 + languageName: node + linkType: hard + "leven@npm:^3.1.0": version: 3.1.0 resolution: "leven@npm:3.1.0" @@ -31369,7 +31621,7 @@ __metadata: languageName: node linkType: hard -"minimatch@npm:^5.0.1": +"minimatch@npm:^5.0.1, minimatch@npm:^5.1.0": version: 5.1.6 resolution: "minimatch@npm:5.1.6" dependencies: @@ -32329,6 +32581,16 @@ __metadata: languageName: node linkType: hard +"npm-run-path@npm:^6.0.0": + version: 6.0.0 + resolution: "npm-run-path@npm:6.0.0" + dependencies: + path-key: "npm:^4.0.0" + unicorn-magic: "npm:^0.3.0" + checksum: 10/1a1b50aba6e6af7fd34a860ba2e252e245c4a59b316571a990356417c0cdf0414cabf735f7f52d9c330899cb56f0ab804a8e21fb12a66d53d7843e39ada4a3b6 + languageName: node + linkType: hard + "npm-to-yarn@npm:^2.1.0": version: 2.2.1 resolution: "npm-to-yarn@npm:2.2.1" @@ -33113,6 +33375,13 @@ __metadata: languageName: node linkType: hard +"parse-ms@npm:^4.0.0": + version: 4.0.0 + resolution: "parse-ms@npm:4.0.0" + checksum: 10/673c801d9f957ff79962d71ed5a24850163f4181a90dd30c4e3666b3a804f53b77f1f0556792e8b2adbb5d58757907d1aa51d7d7dc75997c2a56d72937cbc8b7 + languageName: node + linkType: hard + "parse-numeric-range@npm:^1.3.0": version: 1.3.0 resolution: "parse-numeric-range@npm:1.3.0" @@ -34381,6 +34650,15 @@ __metadata: languageName: node linkType: hard +"pretty-ms@npm:^9.0.0": + version: 9.2.0 + resolution: "pretty-ms@npm:9.2.0" + dependencies: + parse-ms: "npm:^4.0.0" + checksum: 10/a65a1d81560867f4f7128862fdbf0e1c2d3c5607bf75cae7758bf8111e2c4b744be46e084704125a38ba918bb43defa7a53aaff0f48c5c2d95367d3148c980d9 + languageName: node + linkType: hard + "proc-log@npm:^3.0.0": version: 3.0.0 resolution: "proc-log@npm:3.0.0" @@ -35837,7 +36115,7 @@ __metadata: languageName: node linkType: hard -"readable-stream@npm:^2.0.0, readable-stream@npm:^2.0.1, readable-stream@npm:^2.0.2, readable-stream@npm:^2.1.4, readable-stream@npm:^2.2.2, readable-stream@npm:^2.3.3, readable-stream@npm:^2.3.6, readable-stream@npm:~2.3.3, readable-stream@npm:~2.3.6": +"readable-stream@npm:^2.0.0, readable-stream@npm:^2.0.1, readable-stream@npm:^2.0.2, readable-stream@npm:^2.0.5, readable-stream@npm:^2.1.4, readable-stream@npm:^2.2.2, readable-stream@npm:^2.3.3, readable-stream@npm:^2.3.6, readable-stream@npm:~2.3.3, readable-stream@npm:~2.3.6": version: 2.3.8 resolution: "readable-stream@npm:2.3.8" dependencies: @@ -35876,6 +36154,15 @@ __metadata: languageName: node linkType: hard +"readdir-glob@npm:^1.1.2": + version: 1.1.3 + resolution: "readdir-glob@npm:1.1.3" + dependencies: + minimatch: "npm:^5.1.0" + checksum: 10/ca3a20aa1e715d671302d4ec785a32bf08e59d6d0dd25d5fc03e9e5a39f8c612cdf809ab3e638a79973db7ad6868492edf38504701e313328e767693671447d6 + languageName: node + linkType: hard + "readdirp@npm:^3.6.0, readdirp@npm:~3.6.0": version: 3.6.0 resolution: "readdirp@npm:3.6.0" @@ -37678,6 +37965,13 @@ __metadata: languageName: node linkType: hard +"signal-exit@npm:^4.1.0": + version: 4.1.0 + resolution: "signal-exit@npm:4.1.0" + checksum: 10/c9fa63bbbd7431066174a48ba2dd9986dfd930c3a8b59de9c29d7b6854ec1c12a80d15310869ea5166d413b99f041bfa3dd80a7947bcd44ea8e6eb3ffeabfa1f + languageName: node + linkType: hard + "simple-concat@npm:^1.0.0": version: 1.0.1 resolution: "simple-concat@npm:1.0.1" @@ -38679,6 +38973,13 @@ __metadata: languageName: node linkType: hard +"strip-final-newline@npm:^4.0.0": + version: 4.0.0 + resolution: "strip-final-newline@npm:4.0.0" + checksum: 10/b5fe48f695d74863153a3b3155220e6e9bf51f4447832998c8edec38e6559b3af87a9fe5ac0df95570a78a26f5fa91701358842eab3c15480e27980b154a145f + languageName: node + linkType: hard + "strip-indent@npm:^3.0.0": version: 3.0.0 resolution: "strip-indent@npm:3.0.0" @@ -39267,7 +39568,7 @@ __metadata: languageName: node linkType: hard -"tar-stream@npm:^3.1.5": +"tar-stream@npm:^3.0.0, tar-stream@npm:^3.1.5": version: 3.1.7 resolution: "tar-stream@npm:3.1.7" dependencies: @@ -40051,6 +40352,13 @@ __metadata: languageName: node linkType: hard +"ts-pattern@npm:^5.5.0": + version: 5.5.0 + resolution: "ts-pattern@npm:5.5.0" + checksum: 10/d07b22cc65ea4601be588f9ac6e9aeafdc36e13bb3779bcb2ca298e9010b14eca34305c61ad89c0c68e52c5ea5725584fab5e500f5efdf5922289b36b398b684 + languageName: node + linkType: hard + "tsconfck@npm:^3.0.3": version: 3.1.3 resolution: "tsconfck@npm:3.1.3" @@ -40558,6 +40866,13 @@ __metadata: languageName: node linkType: hard +"unicorn-magic@npm:^0.3.0": + version: 0.3.0 + resolution: "unicorn-magic@npm:0.3.0" + checksum: 10/bdd7d7c522f9456f32a0b77af23f8854f9a7db846088c3868ec213f9550683ab6a2bdf3803577eacbafddb4e06900974385841ccb75338d17346ccef45f9cb01 + languageName: node + linkType: hard + "unified-engine@npm:^11.2.0": version: 11.2.0 resolution: "unified-engine@npm:11.2.0" @@ -40923,6 +41238,19 @@ __metadata: languageName: node linkType: hard +"unzipper@npm:^0.12.3": + version: 0.12.3 + resolution: "unzipper@npm:0.12.3" + dependencies: + bluebird: "npm:~3.7.2" + duplexer2: "npm:~0.1.4" + fs-extra: "npm:^11.2.0" + graceful-fs: "npm:^4.2.2" + node-int64: "npm:^0.4.0" + checksum: 10/b210c421308e1913e01b54faad4ae79e758c674311892414a0697acacba9f82fa0051b677faa77e62fab422eef928c858f2d5cda9ddb47a2f3db95b0e9b36359 + languageName: node + linkType: hard + "update-browserslist-db@npm:^1.1.1": version: 1.1.1 resolution: "update-browserslist-db@npm:1.1.1" @@ -42812,6 +43140,23 @@ __metadata: languageName: node linkType: hard +"xml2js@npm:^0.6.2": + version: 0.6.2 + resolution: "xml2js@npm:0.6.2" + dependencies: + sax: "npm:>=0.6.0" + xmlbuilder: "npm:~11.0.0" + checksum: 10/df29de8eeedb762c367d87945c39bcf54db19a2c522607491c266ed6184b5a749e37ff29cfaed0ac149da9ba332ac3dcf8e5ff2bd0a206be3343eca95faa941d + languageName: node + linkType: hard + +"xml@npm:^1.0.1": + version: 1.0.1 + resolution: "xml@npm:1.0.1" + checksum: 10/6c4c31a1308e45732e5ac6b50edbca0e8f7abe5cb5de10215d8e3c688819fe7c7706e056f6fb59b1a23fdf1000c2d7a8bba0a89e94aa1796cd2376d9a5ba401e + languageName: node + linkType: hard + "xmlbuilder@npm:>=11.0.1, xmlbuilder@npm:^15.1.1": version: 15.1.1 resolution: "xmlbuilder@npm:15.1.1" @@ -43040,6 +43385,13 @@ __metadata: languageName: node linkType: hard +"yoctocolors@npm:^2.0.0": + version: 2.1.1 + resolution: "yoctocolors@npm:2.1.1" + checksum: 10/563fbec88bce9716d1044bc98c96c329e1d7a7c503e6f1af68f1ff914adc3ba55ce953c871395e2efecad329f85f1632f51a99c362032940321ff80c42a6f74d + languageName: node + linkType: hard + "yup@npm:^1.4.0": version: 1.4.0 resolution: "yup@npm:1.4.0" @@ -43052,6 +43404,17 @@ __metadata: languageName: node linkType: hard +"zip-stream@npm:^6.0.1": + version: 6.0.1 + resolution: "zip-stream@npm:6.0.1" + dependencies: + archiver-utils: "npm:^5.0.0" + compress-commons: "npm:^6.0.2" + readable-stream: "npm:^4.0.0" + checksum: 10/aa5abd6a89590eadeba040afbc375f53337f12637e5e98330012a12d9886cde7a3ccc28bd91aafab50576035bbb1de39a9a316eecf2411c8b9009c9f94f0db27 + languageName: node + linkType: hard + "zod@npm:^3.21.4, zod@npm:^3.22.3, zod@npm:^3.23.8": version: 3.23.8 resolution: "zod@npm:3.23.8"