Skip to content

Commit

Permalink
Adding command line tests.
Browse files Browse the repository at this point in the history
Signed-off-by: dblock <[email protected]>
  • Loading branch information
dblock committed May 30, 2024
1 parent 69247b0 commit e6c1624
Show file tree
Hide file tree
Showing 5 changed files with 62 additions and 28 deletions.
1 change: 1 addition & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ export default [
allowRuleToRunWithoutStrictNullChecksIKnowWhatIAmDoing: false
}
],
'@typescript-eslint/no-extraneous-class': 'off',
'array-callback-return': 'off',
'new-cap': 'off',
'no-return-assign': 'error',
Expand Down
46 changes: 24 additions & 22 deletions tools/src/tester/ResultsDisplayer.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,22 @@
import { type ChapterEvaluation, type Evaluation, Result, type StoryEvaluation } from './types/eval.types'
import { overall_result } from './helpers'

function b (text: string): string { return `\x1b[1m${text}\x1b[0m` }
function i (text: string): string { return `\x1b[3m${text}\x1b[0m` }
export class Ansi {
static b (text: string): string { return `\x1b[1m${text}\x1b[0m` }
static i (text: string): string { return `\x1b[3m${text}\x1b[0m` }

function padding (text: string, length: number, prefix: number = 0): string {
const spaces = length - text.length > 0 ? ' '.repeat(length - text.length) : ''
return `${' '.repeat(prefix)}${text}${spaces}`
}
static padding (text: string, length: number, prefix: number = 0): string {
const spaces = length - text.length > 0 ? ' '.repeat(length - text.length) : ''
return `${' '.repeat(prefix)}${text}${spaces}`
}

function green (text: string): string { return `\x1b[32m${text}\x1b[0m` }
function red (text: string): string { return `\x1b[31m${text}\x1b[0m` }
function yellow (text: string): string { return `\x1b[33m${text}\x1b[0m` }
function cyan (text: string): string { return `\x1b[36m${text}\x1b[0m` }
function gray (text: string): string { return `\x1b[90m${text}\x1b[0m` }
function magenta (text: string): string { return `\x1b[35m${text}\x1b[0m` }
static green (text: string): string { return `\x1b[32m${text}\x1b[0m` }
static red (text: string): string { return `\x1b[31m${text}\x1b[0m` }
static yellow (text: string): string { return `\x1b[33m${text}\x1b[0m` }
static cyan (text: string): string { return `\x1b[36m${text}\x1b[0m` }
static gray (text: string): string { return `\x1b[90m${text}\x1b[0m` }
static magenta (text: string): string { return `\x1b[35m${text}\x1b[0m` }
}

export interface DisplayOptions {
tab_size?: number
Expand Down Expand Up @@ -45,7 +47,7 @@ export default class ResultsDisplayer {
#display_story (): void {
const result = this.evaluation.result
const message = this.evaluation.full_path
const title = cyan(b(this.evaluation.display_path))
const title = Ansi.cyan(Ansi.b(this.evaluation.display_path))
this.#display_evaluation({ result, message }, title)
}

Expand All @@ -58,7 +60,7 @@ export default class ResultsDisplayer {
}

#display_chapter (chapter: ChapterEvaluation): void {
this.#display_evaluation(chapter.overall, i(chapter.title), this.tab_size * 2)
this.#display_evaluation(chapter.overall, Ansi.i(chapter.title), this.tab_size * 2)
if (chapter.overall.result === Result.PASSED || chapter.overall.result === Result.SKIPPED) return

this.#display_parameters(chapter.request?.parameters ?? {})
Expand Down Expand Up @@ -93,8 +95,8 @@ export default class ResultsDisplayer {
}

#display_evaluation (evaluation: Evaluation, title: string, prefix: number = 0): void {
const result = padding(this.#result(evaluation.result), 0, prefix)
const message = evaluation.message != null ? `${gray('(' + evaluation.message + ')')}` : ''
const result = Ansi.padding(this.#result(evaluation.result), 0, prefix)
const message = evaluation.message != null ? `${Ansi.gray('(' + evaluation.message + ')')}` : ''
console.log(`${result} ${title} ${message}`)
if (evaluation.error && this.verbose) {
console.log('-'.repeat(100))
Expand All @@ -104,13 +106,13 @@ export default class ResultsDisplayer {
}

#result (r: Result): string {
const text = padding(r, 7)
const text = Ansi.padding(r, 7)
switch (r) {
case Result.PASSED: return green(text)
case Result.SKIPPED: return yellow(text)
case Result.FAILED: return magenta(text)
case Result.ERROR: return red(text)
default: return gray(text)
case Result.PASSED: return Ansi.green(text)
case Result.SKIPPED: return Ansi.yellow(text)
case Result.FAILED: return Ansi.magenta(text)
case Result.ERROR: return Ansi.red(text)
default: return Ansi.gray(text)
}
}
}
12 changes: 6 additions & 6 deletions tools/src/tester/start.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,18 @@ import _ from 'lodash'

const command = new Command()
.description('Run test stories against the OpenSearch spec.')
.addOption(new Option('--spec, --spec_path <path>', 'path to the root folder of the multi-file spec').default('./spec'))
.addOption(new Option('--tests, --tests_path <path>', 'path to the root folder of the tests').default('./tests'))
.addOption(new Option('--tab_size <size>', 'tab size for displayed results').default('4'))
.addOption(new Option('--spec, --spec-path <path>', 'path to the root folder of the multi-file spec').default('./spec'))
.addOption(new Option('--tests, --tests-path <path>', 'path to the root folder of the tests').default('./tests'))
.addOption(new Option('--tab-size <size>', 'tab size for displayed results').default('4'))
.addOption(new Option('--verbose', 'whether to print the full stack trace of errors'))
.allowExcessArguments(false)
.parse()

const opts = command.opts()
const display_options = {
verbose: opts.verbose ?? false,
tab_size: Number.parseInt(opts.tab_size)
tab_size: Number.parseInt(opts.tabSize)
}
const spec = (new OpenApiMerger(opts.spec_path, LogLevel.error)).merge()
const runner = new TestsRunner(spec, opts.tests_path, display_options)
const spec = (new OpenApiMerger(opts.specPath, LogLevel.error)).merge()
const runner = new TestsRunner(spec, opts.testsPath, display_options)
void runner.run().then(() => { _.noop() })
3 changes: 3 additions & 0 deletions tools/tests/tester/fixtures/empty.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
$schema: ../json_schemas/test_story.schema.yaml

chapters: []
28 changes: 28 additions & 0 deletions tools/tests/tester/start.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import { spawnSync } from 'child_process'
import { Ansi } from '../../src/tester/ResultsDisplayer'

const spec = (args: string[]): any => {
const process = spawnSync('ts-node', ['tools/src/tester/start.ts'].concat(args))
return {
stdout: process.stdout?.toString(),
stderr: process.stderr?.toString()
}
}

test('--help', async () => {
expect(spec(['--help']).stdout).toContain('Usage: start [options]')
})

test('--invalid', async () => {
expect(spec(['--invalid']).stderr).toContain("error: unknown option '--invalid'")
})

test('--tests', async () => {
expect(spec(['--tests', 'tools/tests/tester/fixtures']).stdout).toContain(
`${Ansi.green('PASSED ')} ${Ansi.cyan(Ansi.b('empty.yaml'))}`
)
})

test.todo('--tab-size')
test.todo('--verbose')
test.todo('--spec')

0 comments on commit e6c1624

Please sign in to comment.