tiktok-sparo/build-tests/test-utilities/README.md

47 lines
1.4 KiB
Markdown
Raw Normal View History

2024-03-07 14:27:54 -05:00
# build-test-utilities
2024-03-06 20:25:24 -05:00
2024-03-07 14:27:54 -05:00
The project contains several utility function for build tests.
2024-03-06 20:25:24 -05:00
2024-03-07 14:27:54 -05:00
# Test sparo output with Heft run-script plugin
2024-03-06 20:25:24 -05:00
2024-03-07 14:27:54 -05:00
```ts
import {
ICommandDefinition,
executeCommandsAndCollectOutputs,
updateOrCompareOutputs
} from 'build-test-utilities';
import type { IRunScriptOptions } from '@rushstack/heft';
2024-03-06 20:25:24 -05:00
2024-03-07 14:27:54 -05:00
export async function runAsync(runScriptOptions: IRunScriptOptions): Promise<void> {
const {
heftTaskSession: {
logger,
parameters: { production }
},
heftConfiguration: { buildFolderPath }
} = runScriptOptions;
2024-03-06 20:25:24 -05:00
2024-03-07 14:27:54 -05:00
const commandDefinitions: ICommandDefinition[] = [
{
kind: 'sparo-command',
name: 'clone-help',
args: ['clone', '--help']
}
];
await executeCommandsAndCollectOutputs({
commandDefinitions,
buildFolderPath,
})
await updateOrCompareOutput({
buildFolderPath,
logger,
production,
})
}
```
`executeCommandsAndCollectOutputs` runs the list of specified command definitions, it collects sparo command outputs and save them to `<buildFolderPath>/temp/etc`.
`updateOrCompareOutput` copies the output text files from `<buildFolderPath>/temp/etc` to `<buildFolderPath>/etc`, this ensures the output text files are always up to date, and it must get reviewed in the PR. In CI builds, this function will compares the content between these two folders, and throw a error for unmatched content.