npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@postman/wdio-allure-reporter

v0.0.6

Published

A WebdriverIO reporter plugin to create Allure Test Reports

Downloads

2,814

Maintainers

eddie.davieseddie.daviesshubham.shukla-postmanshubham.shukla-postmanbasile.barrinciobasile.barrinciohoanguyennhoanguyennshreyansh.goyalshreyansh.goyalharikrishna.postmanharikrishna.postmansajal001sajal001michaelhudelsonpostmanmichaelhudelsonpostmandima-postmandima-postmanihor.mariichynihor.mariichynandrii.lymychandrii.lymychmichael.browningmichael.browningyevhenii.stepanovyevhenii.stepanovarpit.sahuarpit.sahuakshat-nemaakshat-nemapostman-web-platform-functional-accountpostman-web-platform-functional-accountian.cundiffian.cundiffrebecca.krosnickrebecca.krosnicksoriatsoriatmeetsuraj2meetsuraj2nitish-postmannitish-postmanshub_postmanshub_postmanjoshnedelkapostmanjoshnedelkapostmankevin.corbettkevin.corbettcarlos.garcia.postmancarlos.garcia.postmananirudh.msanirudh.msakira28akira28cecilytorocecilytorosumedha.kulkarnisumedha.kulkarnisuman.dassuman.dasyashishduayashishduarljohnsnrljohnsnsalomekbg_postmansalomekbg_postmanvtysonvtysonindraneel_postmanindraneel_postmangrantkingpostmangrantkingpostmanshivangibajpai12shivangibajpai12abhilash-postmanabhilash-postmanraghavendra-postmanraghavendra-postmanravi-postmanravi-postmanjedliu-postmanjedliu-postmanamaan.khan.postmanamaan.khan.postmandiwakarshukla_postmandiwakarshukla_postmanimran.munirimran.munirmarkgritterpmmarkgritterpmshruthiveeshruthiveerajaswarajaswaaki-kusanagiaki-kusanagiyokawasayokawasaankit834ankit834saurabh.agarwalsaurabh.agarwalitsaamirpostmanitsaamirpostmanpostmanautpostmanautnoah.schwartznoah.schwartzdkrapedkrapesaurabh.vartaksaurabh.vartakwheatspaghettiwheatspaghettihimanshu.ng056himanshu.ng056honeynairhoneynairtonyzebastiantonyzebastiankasey.seokasey.seoparthvermaparthvermaneha.kauraneha.kaurajosephpsjosephpsparthpvermaparthpvermamuskaan06muskaan06sapnanayaksapnanayakakshay_postmanakshay_postmanjeroenvdpolljeroenvdpollharsuyashharsuyashayush.chowdhuryayush.chowdhuryplgahplgahsobtiankitsobtiankitaravind-arunaravind-arunsmoyasmoyamcturcomcturcoskatikiaskatikiadhinesh.sridhardhinesh.sridharaman-pmaman-pmdanek_szydanek_szyalexgul4enkoalexgul4enkopamzanipamzanifran.mendezfran.mendezjonaslagonijonaslagoniguru.pochineniguru.pochineninavneetbholenavneetbholepiyush.dagapiyush.dagahimanshu.vishwakarmahimanshu.vishwakarmashraddha-arora-postmanshraddha-arora-postmananshitbansalanshitbansalprathameshhprathameshhnitishpostmannitishpostmanyashja.inyashja.invarshini59varshini59aviralpostmanaviralpostmantheerthasenantheerthasenanshikharpostmanshikharpostmanamanpostmanamanpostmangreenblade29greenblade29anuragmewaranuragmewarchris_pmchris_pmjk-postmanjk-postmantphippstphippsakshay.kulkarniakshay.kulkarnivedkribhuvedkribhusamarth.gulatisamarth.gulatirazvi07razvi07cleveromcleveromplanetabhiplanetabhitiara.johnsontiara.johnsonjoe.fuscojoe.fuscojonathanhavivjonathanhavivmudit.joshimudit.joshipiyush.rpiyush.ranjali2022anjali2022gkorosc-postmangkorosc-postmanraisintenraisintenitsaamiritsaamirvinayak.parasharvinayak.parasharrafaeltfrafaeltfapoorv.gupta.postmanapoorv.gupta.postmanadrian.santanaadrian.santanakylerrenn94kylerrenn94jelle.vandeveldejelle.vandeveldeatanas.aatanas.asamithjaganathsamithjaganathpranavj2000pranavj2000pwitcherpwitcheranandh619anandh619diegog24diegog24atchyut.pulavarthiatchyut.pulavarthikevinswiber-postmankevinswiber-postmansanketpathsanketpathopi-danihelkaopi-danihelkaarvind.khadriarvind.khadricboornaziancboornazianirena-postmanirena-postmanrohan.groverrohan.grovervincentbarthvincentbarthaniketbewalaniketbewalromulo-nascimentoromulo-nascimentoruben.barautruben.barautarsh_13arsh_13tapanchudasamatapanchudasamaakash.rajpurohit_postmanakash.rajpurohit_postmanharsh.postmanharsh.postmanrtlockwoodrtlockwoodharshit.kocharharshit.kocharauddypostmanauddypostmanpatricksevatpatricksevatakinard-pmakinard-pmayush.jainayush.jainlaszlogreczilaszlogreczibhoomikaduapostmanbhoomikaduapostmanroy-himanshuroy-himanshunidhi_goyalnidhi_goyalalexander-rubiaalexander-rubiaarjun.golabhanviarjun.golabhanvianil.jnanojianil.jnanojigbadebo.bellogbadebo.belloravi.prasadravi.prasadjatin-postmanjatin-postmanbharadwajpoduri7bharadwajpoduri7liteshpatil17liteshpatil17tilak-patel-postmantilak-patel-postmanhasnain.rajanhasnain.rajanelizabeth.fungelizabeth.fungmanavbharambemanavbharambepreetham.mpreetham.mdhuhindhan.ilangodhuhindhan.ilangonishat.sayyednishat.sayyedrubencasasrubencasassterling.chin-postmansterling.chin-postmananubhav-vatsanubhav-vatsadityabaradwajadityabaradwajtimhalltimhallasutosh.sahooasutosh.sahooprasant.patelprasant.patelbot_marketing_engineeringbot_marketing_engineeringshreyansh_postshreyansh_postvaishnavichallavaishnavichallalorenzo.ambrosilorenzo.ambrosiarnaudlauret_postmanarnaudlauret_postmanchristina.hastenrathplus1christina.hastenrathplus1postman-dakshraj.sharmapostman-dakshraj.sharmaekansh-01ekansh-01devsharmadevsharmaayushman9454ayushman9454tonygotonygopostmanianpostmaniandavidtran33davidtran33rutvik_gsrutvik_gsdsanders11dsanders11akkeshavanakkeshavanrishabh.shuklarishabh.shuklariyasainiriyasainiyash-postmanyash-postmankarnsharmakarnsharmapriyambadamadalapriyambadamadalagaurav.rakhejagaurav.rakhejasuhas_gaikwadsuhas_gaikwadumeshp7umeshp7darshan.sendarshan.senyatin1997yatin1997kartikjkartikjsaswatdssaswatdssujayvenaiksujayvenaikkratigyakratigyashubham.ranjanshubham.ranjandavidespidavidespinumaanashrafnumaanashrafshamasisshamasisgodfrzerogodfrzeroabhijitkaneabhijitkanekunagpalkunagpalhg07hg07kamalaknnkamalaknnnikithaachhininikithaachhinishreyas.pandurangashreyas.pandurangapratiksolimpratiksolimsivcansinghsivcansinghbhargavkaranam96bhargavkaranam96ronak.npmronak.npmcodenirvanacodenirvanatristandenyertristandenyersabih.siddiquisabih.siddiquishashwat.dixitshashwat.dixitkriss1897kriss1897gunjan4542gunjan4542meetdevelopermeetdeveloperpawanbanapawanbanashreyshahshreyshahvshingalavshingalabarshan23barshan23coditvacoditvaskrplskrpljibinmathews7jibinmathews7diudadiudapostbot-bitbucketpostbot-bitbucketpostbot-buildkitepostbot-buildkitedannydaintondannydaintonbrandonmcastillobrandonmcastillomichaelclausmichaelclausdevansh21devansh21arshad.ayubarshad.ayubsharma.nikhil1997sharma.nikhil1997smitshah173smitshah173atishay-postmanatishay-postmansaket_ranjansaket_ranjandhawan29dhawan29arlemi.postmanarlemi.postmanakshaytate01akshaytate01pankajk0791pankajk0791mdamankhmdamankhapoorvajain08apoorvajain08james-postmanjames-postmanarvind-kalraarvind-kalradiptaragdiptaragdip_postmandip_postmanakshay24akshay24chetan.waingankarchetan.waingankaraxelonetaxelonetbalakrishna.avulapatibalakrishna.avulapatiharsha.dixitharsha.dixitsaialekhya.yerraguntasaialekhya.yerraguntapranav.singhalpranav.singhalamrindersandhuamrindersandhudeepanshuranadeepanshuranamudit1804mudit1804prashant-raghuprashant-raghuwaseem.siddiquiwaseem.siddiquihemendra.kumarhemendra.kumarbswisherbswisherhimanshu0809himanshu0809avinashchoudharyavinashchoudharygouthamajgouthamajshubham.joshishubham.joshiankitsainiankitsainidev-pawankumardev-pawankumartim.beauchamptim.beauchampiamnishantgargiamnishantgargamrit_vyasamrit_vyasayush.rajayush.rajhimanshu.shimanshu.sbrent.cromartybrent.cromartysandeep.singhsandeep.singhabhijeetboroleabhijeetborolemehul.agrawalmehul.agrawalsonymathewsonymathewhardik286hardik286appurvamurawatappurvamurawatpoojatpoojatphani-postmanphani-postmanchinmayj195chinmayj195harsh_bansalharsh_bansalsrinivas.kinisrinivas.kinijony.cheung.postmanjony.cheung.postmanrrc083rrc083diya.ninandiya.ninanshruti_paranjapeshruti_paranjapeutsav.kapoor1994utsav.kapoor1994abhishek_sabhishek_ssubhash.yadavsubhash.yadavpankajkumar05pankajkumar05prithvi.tharunprithvi.tharunashish.gupta1ashish.gupta1joshuawise_postmanjoshuawise_postmanbot.npm.cf.starshipbot.npm.cf.starshipdivy.kharedivy.kharemeenakshi.dhananimeenakshi.dhanani

Readme

WDIO Allure Reporter

A WebdriverIO reporter plugin to create Allure Test Reports.

Allure Reporter Example

Installation

The easiest way is to include @wdio/allure-reporter as a devDependency in your package.json.

{
  "devDependencies": {
    "@wdio/allure-reporter": "^7.0.0"
  }
}

You can simply do it by:

npm install @wdio/allure-reporter --save-dev

Configuration

Configure the output directory in your wdio.conf.js file:

exports.config = {
    // ...
    reporters: [['allure', {
        outputDir: 'allure-results',
        disableWebdriverStepsReporting: true,
        disableWebdriverScreenshotsReporting: true,
    }]],
    // ...
}
  • outputDir defaults to ./allure-results. After a test run is complete, you will find that this directory has been populated with an .xml file for each spec, plus a number of .txt and .png files and other attachments.
  • disableWebdriverStepsReporting - optional parameter(false by default), in order to log only custom steps to the reporter.
  • issueLinkTemplate - optional parameter, in order to specify the issue link pattern. Reporter will replace {} placeholder with value specified in addIssue(value) call parameter. The same logic is applied if Cucumber is used and tag issue is set at any level, it will be converted to the link in the report. The parameter value example:
    https://example.org/issue/{}
  • tmsLinkTemplate - optional parameter, in order to specify TMS (Test Management System) link pattern. Reporter will replace {} placeholder with value specified in addTestId(value) call parameter. The same logic is applied if Cucumber is used and tag testId is set at any level, it will be converted to the link in the report. The parameter value example:
    https://example.org/tms/{}
  • disableWebdriverScreenshotsReporting - optional parameter(false by default), in order to not attach screenshots to the reporter.
  • useCucumberStepReporter - optional parameter (false by default), set it to true in order to change the report hierarchy when using cucumber. Try it for yourself and see how it looks.
  • disableMochaHooks - optional parameter (false by default), set it to true in order to not fetch the before/after stacktrace/screenshot/result hooks into the Allure Reporter.
  • addConsoleLogs - optional parameter(false by default), set to true in order to attach console logs from step to the reporter.

Supported Allure API

  • addLabel(name, value) - assign a custom label to test
  • addFeature(featureName) – assign feature to test
  • addStory(storyName) – assign user story to test
  • addSeverity(value) – assign severity to test, accepts one of these values: blocker, critical, normal, minor, trivial
  • addIssue(value) – assign issue id to test
  • addTestId(value) – assign TMS test id to test
  • addEnvironment(name, value) – save environment value
  • addAttachment(name, content, [type]) – save attachment to test.
    • name (String) - attachment name.
    • content – attachment content.
    • type (String, optional) – attachment MIME-type, text/plain by default
  • addArgument(name, value) - add additional argument to test
  • addDescription(description, [type]) – add description to test.
    • description (String) - description of the test.
    • type (String, optional) – description type, text by default. Values ['text', 'html','markdown']
  • addStep(title, [{content, name = 'attachment'}], [status]) - add step to test.
    • title (String) - name of the step.
    • content (String, optional) - step attachment
    • name (String, optional) - step attachment name, attachment by default.
    • status (String, optional) - step status, passed by default. Must be "failed", "passed" or "broken"
  • startStep(title) - start with a step
    • title (String) - name of the step.
  • endStep(status) - end with a step
    • status (String, optional) - step status, passed by default. Must be "failed", "passed" or "broken"

Usage

Allure Api can be accessed using:

ES5

const allureReporter = require('@wdio/allure-reporter').default

ES6

import allureReporter from '@wdio/allure-reporter'

Mocha example

describe('Suite', () => {
    it('Case', () => {
        allureReporter.addFeature('Feature')
    })
})

Cucumber

Basic Cucumber example:

Given('I include feature and story name', () => {
    allureReporter.addFeature('Feature_name');
    allureReporter.addStory('Story_name');
})
Cucumber Tags

Cucumber tags with special names (issue and testId) are converted to the links (the corresponding link templates must be configured before):

@issue=BUG-1
@testId=TST-2
Feature: This is a feature with global tags that will be converted to Allure links
  @issue=BUG-3
  @testId=TST-4
  Scenario: This is a scenario with tags that will be converted to Allure links
    Given I do something

Cucumber tags with special names (feature) are mapped to Allure labels:

Feature: Test user role
  @feature=login
  Scenario: Login
    Given I test login

Displaying the report

The results can be consumed by any of the reporting tools offered by Allure. For example:

Command-line

Install the Allure command-line tool, and process the results directory:

allure generate [allure_output_dir] && allure open

This will generate a report (by default in ./allure-report), and open it in your browser.

Autogenerate Report

You can also auto generate the report by using the Allure command line tool programmatically. To do so install the package in your project by:

npm i allure-commandline

Then add or extend your onComplete hook or create a custom service for this:

// wdio.conf.js
const allure = require('allure-commandline')

exports.config = {
    // ...
    onComplete: function() {
        const reportError = new Error('Could not generate Allure report')
        const generation = allure(['generate', 'allure-results', '--clean'])
        return new Promise((resolve, reject) => {
            const generationTimeout = setTimeout(
                () => reject(reportError),
                5000)

            generation.on('exit', function(exitCode) {
                clearTimeout(generationTimeout)

                if (exitCode !== 0) {
                    return reject(reportError)
                }

                console.log('Allure report successfully generated')
                resolve()
            })
        })
    }
    // ...
}

Jenkins

Install and configure the Allure Jenkins plugin

Add Screenshots

Screenshots can be attached to the report by using the takeScreenshot function from WebDriverIO in the afterStep hook. First set disableWebdriverScreenshotsReporting: false in reporter options, then add in afterStep hook:

afterStep: async function (step, scenario, { error, duration, passed }, context) {
  if (error) {
    await browser.takeScreenshot();
  }
}

As shown in the example above, when this function is called, a screenshot image will be attached to the allure report.