JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 891390
  • Score
    100M100P100Q194239F
  • License MIT

Aimed at making it easier to build Jenkins compatible JUnit XML reports in plugins for testing frameworks

Package Exports

  • junit-report-builder
  • junit-report-builder/dist/index.es.js
  • junit-report-builder/dist/index.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (junit-report-builder) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

junit-report-builder

Build Status Weekly Downloads

A project aimed at making it easier to build Jenkins compatible XML based JUnit reports.

Installation

To install the latest version, run:

npm install junit-report-builder --save

Usage

import builder from 'junit-report-builder';

// Create a test suite
let suite = builder.testSuite().name('My suite');

// Create a test case
let firstTestCase = suite.testCase()
  .className('my.test.Class')
  .name('My first test');

// Create another test case which is marked as failed
let secondTestCase = suite.testCase()
  .className('my.test.Class')
  .name('My second test')
  .failure();

builder.writeTo('test-report.xml');

This will create test-report.xml containing the following:

<?xml version="1.0" encoding="UTF-8"?>
<testsuites tests="2" failures="1" errors="0" skipped="0">
  <testsuite name="My suite" tests="2" failures="1" errors="0" skipped="0">
    <testcase classname="my.test.Class" name="My first test"/>
    <testcase classname="my.test.Class" name="My second test">
      <failure/>
    </testcase>
  </testsuite>
</testsuites>

If you want to create another report file, start by getting a new builder instance like this:

// Each builder produces a single report file
let anotherBuilder = builder.newBuilder();

CommonJS is also supported:

let builder = require('junit-report-builder');

Please refer to the e2e.spec.ts for more details on the usage.

License

MIT

Changelog

5.1.0

  • Add support for multiline properties, where the value is stored as text content instead of in the value attribute. Thanks to Sebastian Sauer.

5.0.0

  • A re-release of 4.0.1 since that version broke the CommonJS API.
  • Remove an internal type from the public API.

4.0.1 (deprecated)

  • Deprecated, since the CommonJS API was accidentally changed in 4.0.1. Re-released as 5.0.0.
  • Re-introduce CommonJS support, while keeping the ES module support. Thanks to Harel Mazor and Simeon Cheeseman.
  • Export all public types from index.d.ts. Thanks to Harel Mazor and Simeon Cheeseman.
  • Full typing support for TypeScript. Thanks to Harel Mazor.

4.0.0 (deprecated)

  • Deprecated, since the CommonJS support was accidentally dropped. This is fixed again in 4.0.1.
  • Dropped support for node.js 14, 12, 10 and 8.
  • Full typing support for TypeScript. Thanks to Harel Mazor.

3.2.1

  • Update documentation.

3.2.0

  • Support name and test count attributes for the root test suites element. Thanks to Simeon Cheeseman.
  • Describe parameter types and return types with JSDoc. Thanks to Simeon Cheeseman.

3.1.0

  • Add support for generic properties for test cases. Thanks to Pietro Ferrulli.
  • Bump dependencies

3.0.1

  • Bump dependencies: lodash, make-dir, date-format, minimist

3.0.0

  • Properly prevent invalid characters from being included in the XML files.
  • Dropped support for node.js 4 and 6

2.1.0

  • Added support for adding a file attribute to a test case. Thanks to Ben Holland.

2.0.0

  • Replace mkdirp by make-dir to resolve npm advisory 1179.
  • Dropped support for node.js 0.10.x and 0.12.x

1.3.3

  • Updated lodash to a version without known vulnerabilities.

1.3.2

  • Added support for emitting the type attribute for error and failure elements of test cases
  • Added support for emitting cdata/content for the error element of a test case

Thanks to Robert Turner.

1.3.1

  • Update dependencies to versions without known vulnerabilities.

1.3.0

1.2.0

  • Support creating XML with emojis. Thanks to ischwarz.

1.1.1

  • Changed date-format to be a dependency. Previously it was incorrectly set to be a devDependency. Thanks to georgecrawford.

1.1.0

  • Added attributes for test count, failure count, error count and skipped test count to testsuite elements
  • Added ability to attach standard output and standard error logs to test cases
  • Added ability set execution time for test suites
  • Added ability set timestamp for test suites

1.0.0

  • Simplified API by making the index module export a builder instance

0.0.2

  • Corrected example in readme

0.0.1

  • Initial release