Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Info

AIO APIs and Jenkins plugin can be used to publish results from any framework capable of generating JUnit files like Robot/Cypress/NUnit amongst many others.

Installing the Plugin

AIO Tests Jenkins plugin can be installed from the Jenkins marketplace as below.

  1. Login to your Jenkins instance.

  2. Go to Manage Jenkins > Manage Plugins > Available

  3. Now search for AIO Tests and click Install

Requirements

  1. Jenkins 2.235.1 or higher

  2. Jira cloud/server/data centre instance with AIO Tests for Jira installed

Reporting Results

The plugin works in the post build actions step after the build steps are run.
Assuming that the tests have run and a results file (Cucumber.json/Junit/TestNG/any XUnit framework which generates a JUnit XML report) has been generated, the AIO Tests plugin can be used as below to report results of cases in the report to Jira. For information on how to map cases with AIO Tests for different frameworks, please refer to Test Framework Integration.

...

  1. The following options need to be configured for publishing results to AIO Tests

    1. Cloud Authentication- Use the API Token generated from Access Token.

    2. Server/DataCenter Authentication- Use Jira server/DC username and password with basic authentication

       

  2. Choose if the results should be published synchronously or in batches.

...

Field

Details

1

Cycle Preference

Select between existing and new cycle, new cycle or search for an existing cycle by name and create if not found

2

Cycle Prefix

In case of new cycle, Cycle prefix will be used to prefix the cycle title

3

Cycle Key

If existing cycle is selected, specify AIO Tests cycle key eg. SCRUM-CY-121

4

Cycle Name

Uses the cycle name to search for an existing cycle with an exact match. If cycle is found, then the cycle is updated. If it is not found, then a new cycle is created.

5

Add Case

If checked, cases not already in cycle are added, else the cases are reported as errors

56

Create New Run

If checked, new run is created for each case execution, else existing run is overwritten

67

Create Case

If checked and no case exists with a matching case key or automation key, a new case is created

78

Update BDD Case Steps [Cucumber Only]

If checked, if the automated case steps are different from the steps in AIO Tests, then the automated steps will update the steps in the AIO Tests cases

89

Force Update Case

If checked, updates case steps from steps in automaton results files. (Works for robot only)

910

Hide Publish Result Details

If checked, it would hide testcase wise details

1011

Fail build if result publishing fails

If checked, the build result will be updated to failed, in case publishing of results to AIO Tests fails

Reporting Results in the Pipeline

The AIO Tests Jenkins plugin has support for being run as a pipeline task.
For the security of API Key/Jira Password, secret text credentials can be used to avoid putting the key in plain text. A plain text API Key would work as well.

Cloud Example

Code Block
pipeline {
       agent any
       environment {
           AIO_TESTS_API_KEY = credentials('aioTestApiKey')
       }
       stages {
           stage('SCM') {
               steps {
                   git 'https://github.com/org/sample-testng-tests.git'                       
               }
           }
           stage('Build') {
               steps {
                   sh 'mvn test'
               }
           }
       }
       post {
           always {
                   aioImport jiraInstanceType: 'cloud',
                         frameworkType : 'TestNG',
                         addCaseToCycle :true,
                         createCase :true,
                         createNewRun: true,
                         bddForceUpdateCase: true,
                         entry: [$class: 'NewCycle', cyclePrefix: 'Regression Run V1.0'],
                        //For existing cycles : entry: [$class: 'ExistingCycle', cycleKey: 'SCRUM-CY-191'],
                         apiKey : hudson.util.Secret.fromString(env.AIO_TESTS_API_KEY),
                         resultsFilePath : '/target/surefire-reports/testng-results.xml',
                         projectKey: 'SCRUM',
                         hideDetails: false
           }
       }
   }

Server/Data Center Example

Code Block
pipeline {
       agent any
       environment {
           AIO_TESTS_PWD = credentials('JIRA_PWD')
       }
       stages {
           stage('SCM') {
               steps {
                   git url:'https://github.com/yourco/testng-report-samples.git',
                       branch: 'main'
               }
           }
           stage('Build') {
               steps {
                   sh 'mvn test'}
           }
       }
       post {
           always {
                   aioImport jiraInstanceType: 'server',
                         jiraPassword: hudson.util.Secret.fromString(env.AIO_TESTS_PWD),
                         jiraServerUrl: '<your jira server/DC url>',
                         jiraUsername: '<jira username>',
                         frameworkType : 'TestNG',
                         addCaseToCycle :true,
                         createNewRun: true,
                         createCase :true,
                         bddForceUpdateCase: true,
                         apiKey: null, //mandatory to set null 
                         entry: [$class: 'NewCycle', cyclePrefix: 'Regression Run V1.0'],
                        //For existing cycles : entry: [$class: 'ExistingCycle', cycleKey: 'SCRUM-CY-191'],
                         resultsFilePath : '/src/testng-results.xml',
                         projectKey: 'NV',
                         hideDetails: false
               
           }
       }
   }

Parameters

If the job is a parameterized build, the plugin supports parametrization for the project key, results file path, cycle prefix, existing cycle key, and API key fields.

Trouble seeing AIO Tests Plugin Options?

Jenkins version 2.263.x version had an issue with elements related to radio blocks being hidden [Jenkins Issue- 64040issue 64136]. Upgrading to the latest version resolves this issue.

...