Reporter plugin for japa that generates a html report with your tests
The table-driven-html-reporter
plugin makes it simple to generate a report for your tests suites
Just install the plugin and import to your japa config file and a report
folder will be generated with a html file after running your tests
Install the package from the npm registry as follows:
npm i -D table-driven-html-reporter
yarn add -D table-driven-html-reporter
pnpm add -D table-driven-html-reporter
Import the package function and add it to reporters
array
import { specReporter } from '@japa/spec-reporter'
import { tableDrivenHtmlReporter } from 'table-driven-html-reporter'
configure({
reporters: [specReporter(), tableDrivenHtmlReporter()],
})
Just run your tests now. Imagine you have the default Math.add
test group from japa. This is the resulting report:
The folder report
will be generated with the following files:
template.mustache
testReport.html
testReport.html
is the report itself, just open on your default browser
template.mustache
is the report template that you change to meet your needs
import { specReporter } from '@japa/spec-reporter'
import { tableDrivenHtmlReporter, TableDrivenHtmlReporterConfig} from 'table-driven-html-reporter'
const htmlReporterConf: TableDrivenHtmlReporterConfig = {
reportName: 'customReportName' //this will be the name of the report
}
configure({
reporters: [specReporter(), tableDrivenHtmlReporter(htmlReporterConf)],
})
import { specReporter } from '@japa/spec-reporter'
import { tableDrivenHtmlReporter, TestDrivenHtmlReporterConfig} from 'table-driven-html-reporter'
const htmlReporterConf: TestDrivenHtmlReporterConfig = {
directory: 'customDir' //this will be the name of the directory
}
configure({
reporters: [specReporter(), tableDrivenHtmlReporter(htmlReporterConf)],
})
If you want to minify please install the following dependencies:
npm i -D htmlnano cssnano postcss terser
yarn add -D htmlnano cssnano postcss terser
pnpm add -D htmlnano cssnano postcss terser
import { specReporter } from '@japa/spec-reporter'
import { tableDrivenHtmlReporter, TestDrivenHtmlReporterConfig} from 'table-driven-html-reporter'
const htmlReporterConf: TestDrivenHtmlReporterConfig = {
minify: true
}
configure({
reporters: [specReporter(), tableDrivenHtmlReporter(htmlReporterConf)],
})
import { specReporter } from '@japa/spec-reporter'
import { tableDrivenHtmlReporter, TestDrivenHtmlReporterConfig} from 'table-driven-html-reporter'
const htmlReporterConf: TestDrivenHtmlReporterConfig = {
projectName: "TODO" //you project name
}
configure({
reporters: [specReporter(), tableDrivenHtmlReporter(htmlReporterConf)],
})
This reporter goes well with table-driven-tests plugin
You can change the template anytime. Just edit template.mustache
to fit your project requirements.
When you minify your project you'll gain about 10 - 13% reduction in size.
This package is heavily inspired in gauge report
Please open an issue if you find a problem.