-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Golden Testing Commands
Harsha Nalluru edited this page Jan 7, 2025
·
8 revisions
If you're not familiar with the recorder refer to recorder-readme.
If you're looking to migrate your existing package from recorder v1 to v3, refer to migrate-v1-to-v3.
If you're looking to be onboarded to the asset-sync workflow to push out the test recordings to Azure/azure-sdk-assets
repository, refer to asset-sync-migration.
script name | What does it do? |
---|---|
rush update |
Updates dependencies |
rush build -t . |
Expected to be run from inside your package(sdk/service-name/package-name ). Builds the whole dependency tree. |
script name | command(usually) |
---|---|
rushx unit-test:browser |
dev-tool run test:browser |
rushx unit-test:node |
dev-tool run test:node-ts-input -- --timeout 1200000 --exclude 'test/**/browser/*.spec.ts' 'test/**/*.spec.ts' |
rushx integration-test:browser |
dev-tool run test:browser |
rushx integration-test:node |
dev-tool run test:node-js-input -- --timeout 5000000 'dist-esm/test/**/*.spec.js' |
Expects that you have dev-tool
among your devDependencies.
Expects that you have powershell installed.
script command | What does it do? |
---|---|
npx dev-tool test-proxy init |
[Only once per package] Generates the assets.json with an empty tag. After init , run test commands such as rushx test:node to generate test recordings and push them. |
npx dev-tool test-proxy migrate --initial-push |
[Only once per package] To migrate the test recordings to the assets repo for the first time. Also generates assets.json
|
npx dev-tool test-proxy push |
To push the test recordings to the assets repo. |
npx dev-tool test-proxy reset |
Reverts the local changes to recordings and resets to what is currently checked in to the assets repo. This is a destructive operation. |
npx dev-tool test-proxy restore |
Pulls the recordings from the assets repo that are referenced in your assets.json . Typically this will be done automatically when you first run tests in playback if the recordings haven't been downloaded already. But you can run this command in advance if you'd like to download them earlier, for example for offline work. |
script command | What does it do? |
---|---|
dev-tool run test:vitest --test-proxy-debug |
Provides helpful test-proxy debug logs that include sanitization modifications for both the central sanitizers and the user-specified ones. |
- Update the vitest.config.ts as follows to include the test file you're interested in.
export default mergeConfig(
{
...viteConfig,
test: {
include: ["test/public/node/analysis.spec.ts"],
},
},
defineConfig({
test: {
testTimeout: 1200000,
hookTimeout: 1200000,
},
}),
);
- Set
.only
on the test you're interested in
it.only("test title...")
Run the test command such as rushx unit-test:node
to run the test