Skip to content

Latest commit

 

History

History
146 lines (105 loc) · 6.67 KB

README.md

File metadata and controls

146 lines (105 loc) · 6.67 KB

Cypress Reporter for Spira

This is a sample cypress project that uploads Cypress test results automatically to Inflectra's SpiraTest, SpiraTeam or SpiraPlan (hereafter just Spira).

It is implemented as a custom reporter that you can easily add to your existing Cypress projects and have the benefit of the test results and screenshots automatically upload against the corresponding Spira test case.

Installing the Cypress Reporter

To install the Spira custom reporter, simply download the Spira-Cypress-Reporter.zip zip file and extract the contents (consisting of the reporter folder) and place in your Cypress project at the same level as the cypress folder. For example:

Sample file view of a Cypress project

To use the custom Spira reporter in your Cypress project, you just add it to the Cypress command line:

npx cypress run --browser edge --spec "cypress\e2e\1-getting-started\todo.cy.js" --reporter "reporter\SpiraReporter"

or you modify the cypress.config.js to include the report. We recommend this method since it avoids need to add it to the command-line each time.

However before you can use the reporter, you will need to configure it to point to Spira, and map the Cypress spec files to specified Spira test cases.

Configuring the Cypress Reporter

Locate the cypress.config.js file from the root of your Cypress project. Open this up in your favorite text/code editor, for example Visual Studio Code. This file contain something similar to the following:

const { defineConfig } = require("cypress");

module.exports = defineConfig({
    e2e: {
        setupNodeEvents(on, config) {
        on('task', { 
            log(message) {
            console.log(message)
            return null
            },
        })
        },
    }
});

Depending on how you have Cypress configured, you may have additional settings.

Now we need to modify it to enable the Spira custom reporter and configure its settings:

const { defineConfig } = require("cypress");

module.exports = defineConfig({
    e2e: {
        setupNodeEvents(on, config) {
        on('task', { 
            log(message) {
            console.log(message)
            return null
            },
        })
        },
    },
    reporter: 'reporter/SpiraReporter',
    reporterOptions: {
        projectId: 1,
        releaseId: 1,
        testSetId: null,
        login: 'fredbloggs',
        apiKey: '{7A05FD06-83C3-4436-B37F-51BCF0060483}',
        protocol: 'https',
        host: 'demo-us.spiraservice.net',
        vdir: 'mysite',
        mapping: {
        "with a checked task": 4,
        "with a checked task 2": 5
        }
    }
});

Notice that we have added reporterOptions object that specifies how the Cypress reporter will communicate with Spira:

  • projectId - this should be the ID of the Spira project (e.g. PR:5 would be just 5)
  • releaseId - this should be the ID of the Spira release we're reporting against (e.g. RL:2 would be just 2)
  • testSetId - this should be the ID of the Spira test set we're reporting against (e.g. TX:3 would be just 3)
  • login - this is the username for a valid Spira user
  • apiKey - this is the API Key / RSS Token associated with the Spira user
  • protocol - this should be either http or https
  • host - this should be the domain name of your Spira instance (e.g. demo-us.spiraservice.net or myinstance.spiraservice.net)
  • vdir - this should be the name of any virtual directory in your instance (e.g. mysite) or just empty if you have a URL that is just the domain (e.g. https://mysite.spiraservice.net)
  • mapping - this is where we map our spec files to the test cases, we will explain this next.

Mapping the Test Cases

The mapping section is where we map the name of each test suite in a spec file with a corresponding Spira test case. For example, if we have a spec file that has this context section:

context('with a checked task', () => {
    beforeEach(() => {
    cy.contains('Pay electric bill')
        .parent()
        .find('input[type=checkbox]')
        .check()
    })

Then the name of the test suite wiuld be with a checked task and then we map that to a test case in SpiraTest, for example TC:5. For our sample tests, we have the following example mapping:

mapping: {
    "with a checked task": 4,
    "with a checked task 2": 5
}

So we are mapping:

  • with a checked task to Spira test case TC:4
  • with a checked task 2 to Spira test case TC:5

We have now finished our configuration of the reporter, and can run the tests.

Running a Cypress Test

You can execute the tests using the Cypress command-line, launch-pad, CI tool or whatever method you currently use. For example, to execute one of the sample tests in this repository, you can use:

npx cypress run --browser edge --spec "cypress\e2e\1-getting-started\todo.cy.js"

to run the entire folder of tests, you can use:

npx cypress run --browser edge --spec "cypress\e2e\1-getting-started"

The system will then execute the test and let you know that it is reporting back to Spira:

Console output when running the test using the Spira reporter

Viewing the Results in Spira

Once the Cypress tests have finished running, you can view the results in Spira:

List of Cypress test runs in Spira

If you click on one of the runs, you will see the details of that specific execution, including the pass/fail steps and the actions recorded:

Details of a Cypress test run in Spira

In addition, if you choose one of the failed runs, you will see that any screenshots have been automatically uploaded as well:

List of screenshots attached to the test run in Spira

If you click on the picture link, you can view the uploaded image/screenshot directly in Spira:

Viewing a test run screenshot in Spira

Congratulations! You have now run your first Cypress test and reported back the results to Spira!

Where Can I Obtain Spira?

If you would like to learn more about the Inflectra Spira suite, please go to the following website:

  • SpiraTest, powerful requirements and test management
  • SpiraTeam, agile planning and test management for teams
  • SpiraPlan, enterprise planning and testing platform