NUnit Integration with CI Insights
Report your test results from NUnit tests to CI Insights
This guide shows how to generate JUnit reports from your NUnit tests and upload them to CI Insights using a GitHub Actions workflow.
1. Generate a JUnit Report with NUnit
Section titled 1. Generate a JUnit Report with NUnitNUnit can generate JUnit-compatible XML reports using the built-in test adapter
and various loggers available for dotnet test
.
Using dotnet test with JUnit Logger
Section titled Using dotnet test with JUnit LoggerInstall the JUnit test logger:
dotnet add package JunitXml.TestLogger
Run tests with JUnit output:
dotnet test --logger "junit;LogFilePath=junit.xml"
Using NUnit Console Runner
Section titled Using NUnit Console RunnerIf you’re using the NUnit Console Runner directly:
nunit3-console.exe your-test.dll --result=junit.xml;format=junit
Using NUnit Test Adapter
Section titled Using NUnit Test AdapterAdd the NUnit test adapter to your test project:
<PackageReference Include="NUnit" Version="3.13.3" />
<PackageReference Include="NUnit3TestAdapter" Version="5.0.0" />
<PackageReference Include="JunitXml.TestLogger" Version="6.1.0" />
Then run:
dotnet test --logger junit
Using Multiple Test Result Formats
Section titled Using Multiple Test Result FormatsYou can generate multiple formats simultaneously:
dotnet test --logger "console;verbosity=detailed" --logger "junit;LogFilePath=junit.xml" --logger "trx;LogFileName=results.trx"
Using NUnit with Custom Settings
Section titled Using NUnit with Custom SettingsYou can also configure test settings in a .runsettings
file:
<?xml version="1.0" encoding="utf-8"?>
<RunSettings>
<LoggerRunSettings>
<Loggers>
<Logger friendlyName="junit" enabled="true">
<Configuration>
<LogFilePath>junit.xml</LogFilePath>
</Configuration>
</Logger>
</Loggers>
</LoggerRunSettings>
</RunSettings>
Then run:
dotnet test --settings test.runsettings
2. Update Your GitHub Actions Workflow
Section titled 2. Update Your GitHub Actions WorkflowAfter generating the JUnit report, add a step to upload the results to CI Insights using the mergifyio/gha-mergify-ci action.
For example, in your workflow file:
- name: Run NUnit Tests and Generate JUnit Report
continue-on-error: true
run: dotnet test --logger "junit;LogFilePath=junit.xml"
- name: Mergify CI Upload
if: success() || failure()
uses: mergifyio/gha-mergify-ci@v8
with:
token: ${{ secrets.MERGIFY_TOKEN }}
report_path: junit.xml
Key Points:
-
if: success() || failure()
: Runs the upload step even if tests fail, ensuring CI Insights has the full report. -
report_path: junit.xml
: Points to where your JUnit file is located. Make sure it matches the path you set in your CI job.
If you use a job matrix in your workflow (e.g., to test across multiple versions), ensure you set
the job_name
input (or MERGIFY_JOB_NAME
environment variable) so CI Insights can properly distinguish reports for each matrix job.
For example, with:
jobs:
example_matrix:
strategy:
matrix:
version: [10, 12, 14]
Your upload step should look like:
- name: Mergify CI Upload
if: success() || failure()
uses: mergifyio/gha-mergify-ci@v8
with:
job_name: example_matrix (${{ matrix.version }})
token: ${{ secrets.MERGIFY_TOKEN }}
report_path: junit.xml
In order to benefit from CI Insights Quarantine, you need to add continue-on-error: true
in your GitHb Actions step that execute your tests and generates the JUnit file.
The step running the gha-mergify-ci
action will determine the success or failure conclusion,
considering quarantined tests.
3. Verify and Review in CI Insights
Section titled 3. Verify and Review in CI InsightsAfter pushing these changes:
- Your GitHub Actions workflow will execute your NUnit tests.
- A JUnit report (junit.xml) is generated.
- The Mergify CI action uploads the report to CI Insights.
You can then review your test results, including any failures or flaky tests, directly in the CI Insights dashboard.
Troubleshooting Tips
Section titled Troubleshooting Tips- Test Adapter: Ensure both NUnit and NUnit3TestAdapter packages are properly referenced in your test project.
- Logger Package: Make sure the JunitXml.TestLogger package is installed and compatible with your .NET version.
- The CLI provides information about the upload. Check the logs in GitHub Actions.
- File Paths: Double-check that the output file matches the path used in
report_path
. - Permissions: Make sure the
MERGIFY_TOKEN
is valid and setup in your GitHub Actions secrets as explained in the docs. - Workflow Conditions: If your step is not running, confirm the if condition is actually triggered in your job.