Xray supports integration with Continuous Integration tools, thanks to its REST API.
Xray team has made some add-ons for Jenkins and Bamboo that make this integration easy. While we're working on making them also compatible with Xray Cloud (soon available), you can still integrate your CI pipeline using the instructions provided here.
For TeamCity, there is a free plugin that already supports Xray Cloud. More info here. |
The steps include:
Authenticate
Export Cucumber, Gherkin base tests from Jira
token=$(curl -H "Content-Type: application/json" -X POST --data '{ "client_id": "${***}","client_secret": "${***}" }' https://xray.cloud.xpand-it.com/api/v1/authenticate| tr -d '"') |
curl -H "Content-Type: application/json" --output featureBundle.zip -X GET -H "Authorization: Bearer ${token}" "https://xray.cloud.xpand-it.com/api/v1/export/cucumber?keys=CALC-1;CALC-3" |
unzip -o featureBundle.zip -d features/ |
cucumber -x -f json -o report.json |
curl -H "Content-Type: application/json" -X POST -H "Authorization: Bearer ${token}" --data @report.json https://xray.cloud.xpand-it.com/api/v1/import/execution/cucumber |
If you are using any other framework to specify your test cases, you can also use a CI tool to import the execution results into Xray and Jira.
Xray supports the most common Test Runner reports when importing execution results. These are listed bellow:
If the Test cases being imported are not yet created in Xray/Jira, then Xray will create them automatically. The created tests will have the Generic test type and will contain the identifier or the name in the definition field. Xray will reuse the same Test issues in JIRA for subsequent imports of execution results.
Only one additional step is needed in order to import the execution results using the test runners specified above:
Run the Tests
Authenticate with the Xray REST API
token=$(curl -H "Content-Type: application/json" -X POST --data '{ "client_id": "${***}","client_secret": "${***}" }' https://xray.cloud.xpand-it.com/api/v1/authenticate| tr -d '"') |
curl -H "Content-Type: text/xml" -X POST -H "Authorization: Bearer ${token}" --data @report.xml https://xray.cloud.xpand-it.com/api/v1/import/execution/junit |