1.23.1 • Published 10 months ago

newman-reporter-htmlextra v1.23.1

Weekly downloads
52,599
License
Apache-2.0
Repository
github
Last release
10 months ago

newman-reporter-htmlextra

Newman htmlextra Reporter Logo

Build and Test NPM Version NPM Weekly Downloads NPM Downloads Docker Pulls

A Newman HTML reporter that has been extended to include the separation of the iteration runs so these are no longer aggregated together and also some additional handlebars helpers to enable users to create better custom templates.

This reporter comes with a dashboard style summary landing page and a set of different tabs which contain the detailed request information. There are also a few optional configuration flags available, to tailor the final report in a number of different ways.


This project will always continue to be fully maintained free of charge - If you're a fan of the project and it's something you get value from, it would be lovely to pay that forward in the means of a donation.

All donations are not kept by me, these are passed on to local charities. Other people need the help that these donations will provide more than I need coffee. 😍


Report Example

Default Report


Interactive Example Report

To give you an idea of what the final report will look like, I've added a working example here for you to get your hands on:


Install

The reporter works as a plugin with Newman so ensure that you have already installed that package globally, using npm install -g newman.

To globally install the htmlextra package:

npm install -g newman-reporter-htmlextra

To use htmlextra as a library, install the package as a dependency into a nodejs project's package.json file using:

npm install -S newman-reporter-htmlextra

To install node, newman and the htmlextra packages together, use this command to pull the Docker image:

docker pull dannydainton/htmlextra

Usage

In order to enable this reporter, specify htmlextra in Newman's -r or --reporters option. The following command will create a new report in the ./newman directory, if the directory does not exist, it will be created as part of the Newman run.

newman run collection.json -r htmlextra

CLI Options

With Newman CLI

CLI OptionDescriptionExample
--reporter-htmlextra-export <path>Specify a path where the output HTML file will be written to disk. If not specified, the file will be written to newman/ in the current working directory.newman run collection.json -r htmlextra --reporter-htmlextra-export ./results/report.html
--reporter-htmlextra-template <path>Specify a path to the custom template which will be used to render the HTML report. This option depends on --reporter htmlextra and --reporter-htmlextra-export being present in the run command. If this option is not specified, the default template is usednewman run collection.json -r htmlextra --reporter-htmlextra-template ./template.hbs
--reporter-htmlextra-showOnlyFailsUse this optional flag to tell the reporter to display only the requests with failed tests.newman run collection.json -r htmlextra --reporter-htmlextra-showOnlyFails
--reporter-htmlextra-testPagingUse this optional flag to add pagination to the tests in the request view.newman run collection.json -r htmlextra --reporter-htmlextra-testPaging
--reporter-htmlextra-browserTitleUse this optional flag to change the name of the title in the browser tab. The default name is "Newman Summary Report".newman run collection.json -r htmlextra --reporter-htmlextra-browserTitle "My Newman report"
--reporter-htmlextra-titleThis optional flag can be used to give your report a different main Title in the centre of the report. If this is not set, the report will show "Newman Run Dashboard".newman run collection.json -r htmlextra --reporter-htmlextra-title "My Newman Report"
--reporter-htmlextra-titleSizeAn optional flag to reduce the size of the main report title. The sizes range from 1 to 6, the higher the number, the smaller the title will be. The default size is 2.newman run collection.json -r htmlextra --reporter-htmlextra-titleSize 4
--reporter-htmlextra-logsThis optional flag shows any console log statements in the collection, on the final report. This is false by default.newman run collection.json -r htmlextra --reporter-htmlextra-logs
--reporter-htmlextra-omitRequestBodiesAn optional flag which allows you to exclude all Request Bodies from the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-omitRequestBodies
--reporter-htmlextra-omitResponseBodiesAn optional flag which allows you to exclude all Response Bodies from the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-omitResponseBodies
--reporter-htmlextra-hideRequestBodyAn optional flag which allows you to exclude certain Request Bodies from the final report. Enter the name of the request that you wish to hide.newman run collection.json -r htmlextra --reporter-htmlextra-hideRequestBody "Login"
--reporter-htmlextra-hideResponseBodyAn optional flag which allows you to exclude certain Response Bodies from the final report. Enter the name of the request that you wish to hide.newman run collection.json -r htmlextra --reporter-htmlextra-hideResponseBody "Auth Request"
--reporter-htmlextra-showEnvironmentDataAn optional flag which allows you to show all the Environment variables used during the run, in the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-showEnvironmentData
--reporter-htmlextra-skipEnvironmentVarsAn optional flag which allows you to exclude certain Environment variables from the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-skipEnvironmentVars "API_KEY"
--reporter-htmlextra-showGlobalDataAn optional flag which allows you to show all the Global variables used during the run, in the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-showGlobalData
--reporter-htmlextra-skipGlobalVarsAn optional flag which allows you to exclude certain Global variables from the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-skipGlobalVars "API_TOKEN"
--reporter-htmlextra-omitHeadersAn optional flag which allows you to exclude all Headers from the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-omitHeaders
--reporter-htmlextra-skipHeadersAn optional flag which allows you to exclude certain Headers from the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-skipHeaders "Authorization"
--reporter-htmlextra-skipSensitiveDataAn optional flag that will exclude all the Request/Response Headers and the Request/Response bodies, from each request in the final report. This will only show the main request info and the Test Results. This is false by default.newman run collection.json -r htmlextra --reporter-htmlextra-skipSensitiveData
--reporter-htmlextra-skipFoldersAn optional flag that will exclude specified folders and their corresponding requests, in the final report. Ensure that folder names are separated with comma ',' and without space.newman run collection.json -r htmlextra --reporter-htmlextra-skipFolders "folder name with space,folderWithoutSpace"
--reporter-htmlextra-skipRequestsAn optional flag that will exclude specified requests, in the final report. Ensure that request names are separated with comma ',' and without space.newman run collection.json -r htmlextra --reporter-htmlextra-skipRequests "request name with space,requestWithoutSpace"
--reporter-htmlextra-showMarkdownLinksAn optional flag which allows you render Markdown links from the test names and pm.expect() statements, in the final report. This could be useful if you use an external bug tracker.newman run collection.json -r htmlextra --reporter-htmlextra-showMarkdownLinks
--reporter-htmlextra-noSyntaxHighlightingAn optional flag which allows you disable the code syntax highlighting. This could enhance the performance of opening larger reports.newman run collection.json -r htmlextra --reporter-htmlextra-noSyntaxHighlighting
--reporter-htmlextra-showFolderDescriptionAn optional flag which allows you to show all the folder descriptions, in the final reportnewman run collection.json -r htmlextra --reporter-htmlextra-showFolderDescription
--reporter-htmlextra-timezoneAn optional flag which allows you to set the timezone on the final report's timestampnewman run collection.json -r htmlextra --reporter-htmlextra-timezone "Australia/Sydney"
--reporter-htmlextra-displayProgressBarAn optional flag which displays the progress of the current Newman run in the CLInewman run collection.json -r htmlextra --reporter-htmlextra-displayProgressBar

With Newman as a Library

All the CLI functionality is available for programmatic use within a nodejs script.

Creating a very basic nodejs project can be done like this:

  • Create a new directory using mkdir <new dir name>
  • Move to the new directory using cd <new dir name>
  • Create a package.json file using npm init -y
  • Install the required node modules using npm i -S newman newman-reporter-htmlextra
  • Create a new <filename>.js file and add the script below which contains the current list of reporter options
  • Add your collection.json file reference to the script and run using node <filename>.js

Once the node script has run, the report will be created in the default ./newman directory. A new save location can be specified using the export flag.

To enable the functionality of a given feature, uncomment any of the options within the htmlextra object.

const newman = require('newman');

newman.run({
    collection: './pathToFile/collection.json', // Collection URL from a public link or the Postman API can also be used
    reporters: ['htmlextra'],
    iterationCount: 1,
    reporter: {
        htmlextra: {
            // export: './report.html',
            // template: './template.hbs'
            // logs: true,
            // showOnlyFails: true,
            // noSyntaxHighlighting: true,
            // testPaging: true,
            // browserTitle: "My Newman report",
            // title: "My Newman Report",
            // titleSize: 4,
            // omitHeaders: true,
            // skipHeaders: "Authorization",
            // omitRequestBodies: true,
            // omitResponseBodies: true,
            // hideRequestBody: ["Login"],
            // hideResponseBody: ["Auth Request"],
            // showEnvironmentData: true,
            // skipEnvironmentVars: ["API_KEY"],
            // showGlobalData: true,
            // skipGlobalVars: ["API_TOKEN"],
            // skipSensitiveData: true,
            // showMarkdownLinks: true,
            // showFolderDescription: true,
            // timezone: "Australia/Sydney",
            // skipFolders: "folder name with space,folderWithoutSpace",
            // skipRequests: "request name with space,requestNameWithoutSpace",
            // displayProgressBar: true
        }
    }
});

Running The Reporter With Docker

A docker image dannydainton/htmlextra has been created for the reporter and can be found on Docker Hub

Basic Usage

Using this command, it will pull down the image and run the Postman Collection with Newman. Once the run has completed it will create a new report file in the /newman dir.

docker run -t -v $(pwd):/etc/newman dannydainton/htmlextra run collection.json -r htmlextra

Using an environment file during the Newman run:

docker run -t -v $(pwd):/etc/newman dannydainton/htmlextra run collection.json -e environment.json -r htmlextra

Using either the Shared Collection link from the Postman App or using the Postman API Link to the files:

docker run -t -v $(pwd):/etc/newman dannydainton/htmlextra run <URL to Collection> -e <URL to Environment> -r htmlextra

Each of these command can be used with the different CLI flags to create the final report that you require.


Compatibility

newman-reporter-htmlextranewmannode
>= v1.1.0>= v4.2.3>= v14.x

Contributing To The Project

This is an open soruce project and PRs for improvements and bug fixes are ALWAYS welcome!!

The easiest way to contribute is to locally pull down the repository code, make your awesome changes and submit a PR - I've listed a few steps here to hopefully make this a simple process:

  1. Clone the newman-reporter-htmlextra repository
  2. Create a New Branch
  3. Run npm i
  4. Run npm run local-dev to globally link the project with Newman
  5. Make your changes to the reporter
  6. Run npx newman run collection_file.json -r htmlextra to create a new report and see your changes in the output
  7. Submit a PR for review

Project Contributors

I would be lying if I said that I've created this reporter all on my own, I need to say a massive Thank You! to the following folks for helping make htmlextra even better:

A huge amount of love and appreciation also goes to Bruce The Legend, for creating the awesome project logo ♥️


License

This software is licensed under Apache-2.0. See the LICENSE.md file for more information.


Special mention

This work have been hugely inspired and copied several aspects of the great work done by Martijn Vander Vlag to create the newman-reporter-htmlfull package. Check out that package too, this contains many of the same aggregation features.

It was also brought together by reviewing the feature requests, from the official Postman HTML reporter and implementing them into this reporter.

1.23.1

10 months ago

1.23.0

1 year ago

1.22.11

2 years ago

1.22.10

3 years ago

1.22.9

3 years ago

1.22.8

3 years ago

1.22.4

3 years ago

1.22.7

3 years ago

1.22.5

3 years ago

1.22.6

3 years ago

1.22.3

3 years ago

1.22.2

3 years ago

1.22.1

3 years ago

1.22.0

3 years ago

1.21.0

4 years ago

1.20.4

4 years ago

1.20.2

4 years ago

1.20.3

4 years ago

1.20.1

4 years ago

1.20.0

4 years ago

1.19.7

4 years ago

1.19.6

4 years ago

1.19.5

4 years ago

1.19.4

4 years ago

1.19.2

4 years ago

1.19.1

4 years ago

1.19.0

4 years ago

1.18.0

4 years ago

1.17.4

4 years ago

1.17.3

4 years ago

1.17.2

5 years ago

1.17.1

5 years ago

1.17.0

5 years ago

1.16.2

5 years ago

1.16.1

5 years ago

1.16.0

5 years ago

1.15.4

5 years ago

1.15.3

5 years ago

1.15.2

5 years ago

1.15.1

5 years ago

1.15.0

5 years ago

1.14.1

5 years ago

1.14.0

5 years ago

1.13.2

5 years ago

1.13.1

5 years ago

1.13.0

5 years ago

1.12.1

5 years ago

1.12.0

5 years ago

1.11.3

5 years ago

1.11.2

5 years ago

1.11.1

5 years ago

1.11.0

5 years ago

1.10.1

5 years ago

1.10.0

5 years ago

1.9.2

5 years ago

1.9.1

5 years ago

1.9.0

5 years ago

1.8.9

5 years ago

1.8.8

5 years ago

1.8.7

5 years ago

1.8.6

5 years ago

1.8.5

5 years ago

1.8.4

5 years ago

1.8.3

5 years ago

1.8.2

5 years ago

1.8.1

6 years ago

1.8.0

6 years ago

1.7.6

6 years ago

1.7.5

6 years ago

1.7.4

6 years ago

1.7.3

6 years ago

1.7.2

6 years ago

1.7.1

6 years ago

1.7.0

6 years ago

1.6.11

6 years ago

1.6.10

6 years ago

1.6.9

6 years ago

1.6.8

6 years ago

1.6.7

6 years ago

1.6.6

6 years ago

1.6.5

6 years ago

1.6.4

6 years ago

1.6.3

6 years ago

1.6.2

6 years ago

1.6.1

6 years ago

1.6.0

6 years ago

1.5.7

6 years ago

1.5.6

6 years ago

1.5.5

6 years ago

1.5.4

6 years ago

1.5.3

6 years ago

1.5.2

6 years ago

1.5.1

6 years ago

1.5.0

6 years ago

1.4.5

6 years ago

1.4.4

6 years ago

1.4.3

6 years ago

1.4.2

6 years ago

1.4.1

6 years ago

1.4.0

6 years ago

1.3.1

6 years ago

1.3.0

6 years ago

1.2.7

6 years ago

1.2.6

6 years ago

1.2.5

6 years ago

1.2.4

6 years ago

1.2.3

6 years ago

1.2.2

6 years ago

1.2.0

6 years ago

1.1.3

6 years ago

1.1.0

6 years ago

1.0.5

6 years ago

1.0.4

6 years ago

1.0.3

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago