Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/replaysmike/nunit.commander
A wrapper for running NUnit tests using NUnit-Console or dotnet test with real-time updates
https://github.com/replaysmike/nunit.commander
extension nunit nunit-console nunit3 real-time test testing
Last synced: about 2 months ago
JSON representation
A wrapper for running NUnit tests using NUnit-Console or dotnet test with real-time updates
- Host: GitHub
- URL: https://github.com/replaysmike/nunit.commander
- Owner: replaysMike
- License: mit
- Created: 2020-02-18T00:56:53.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T14:57:26.000Z (about 2 years ago)
- Last Synced: 2024-10-13T14:23:40.917Z (3 months ago)
- Topics: extension, nunit, nunit-console, nunit3, real-time, test, testing
- Language: C#
- Homepage:
- Size: 320 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# NUnit.Commander
[![Github Badge](https://img.shields.io/github/v/release/replaysMike/NUnit.Commander)](https://github.com/replaysMike/NUnit.Commander/releases/latest)
[![Build status](https://ci.appveyor.com/api/projects/status/6vxd3cq83kuo4hg1?svg=true)](https://ci.appveyor.com/project/MichaelBrown/NUnit.Commander)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/a549220ae45b459c96ed1a5572dab40c)](https://www.codacy.com/manual/replaysMike/NUnit.Commander?utm_source=github.com&utm_medium=referral&utm_content=replaysMike/NUnit.Commander&utm_campaign=Badge_Grade)
[![Codacy Badge](https://api.codacy.com/project/badge/Coverage/a549220ae45b459c96ed1a5572dab40c)](https://www.codacy.com/manual/replaysMike/NUnit.Commander?utm_source=github.com&utm_medium=referral&utm_content=replaysMike/NUnit.Commander&utm_campaign=Badge_Coverage)
[![Github Badge](https://img.shields.io/github/downloads/replaysMike/NUNit.Commander/total)](https://github.com/replaysMike/NUNit.Commander/latest)A wrapper for running NUnit tests using NUnit-Console or dotnet test with real-time updates and analysis
## Description
NUnit.Commander provides real-time test status output for tests run via the [NUnit-Console](https://github.com/nunit/nunit-console) or `dotnet test`. It works in conjunction with [NUnit.Extension.TestMonitor](https://github.com/replaysMike/NUnit.Extension.TestMonitor) (required for Commander to function) which provides insight into your tests as they run. It is a crucial tool for projects with complicated test architecture.## Features
* Real-Time test output to stdout / piped log
* Full final report
* Multiple test run support for repeated running
* Test Analysis - report on changes in test duration, test stability
* Tabbed console interface for viewing real-time test errors and summaries while running
* Prettify of stack traces
* Generate log reports of test durations, results
* Generate log report summaries# Installation
Download and install the [latest release](https://github.com/replaysMike/NUnit.Commander/releases).
## Requirements
[NUnit.Extension.TestMonitor](https://github.com/replaysMike/NUnit.Extension.TestMonitor) must be installed along with your [NUnit-Console](https://github.com/nunit/nunit-console) test runner, or as a nuget package on your test project when using the `dotnet test` test runner. Please refer to installation instructions for [NUnit.Extension.TestMonitor](https://github.com/replaysMike/NUnit.Extension.TestMonitor)
## Screenshots
See the [wiki](https://github.com/replaysMike/NUnit.Commander/wiki) for further examples.
![NUnit.Commander](https://github.com/replaysMike/NUnit.Commander/wiki/screenshots/NUnit.Commander.png)
Real-time output of test status![NUnit.Commander](https://github.com/replaysMike/NUnit.Commander/wiki/screenshots/NUnit.Commander-summary.png)
Summary report# Usage
## How it works
The [NUnit.Extension.TestMonitor](https://github.com/replaysMike/NUnit.Extension.TestMonitor) extension is an NUnit engine extension which sends test events over IPC/Named pipes. Commander connects to the IPC/Named pipe server the extension creates and receives test events in real-time. Therefore, timeouts are required to give Commander a chance to connect to the extension when NUnit engine executes the tests and ensure we do not miss any events.## Examples
### Run using NUnit-Console
Here you can tell Commander where the NUnitConsole installation folder is. This is optional, otherwise it will use the default path `C:\Program Files (x86)\NUnit.org\nunit-console`. You can pass the usual NUnit-Console test runner arguments using the `--args` option and escape any required quotes with `\"`
```
> NUnit.Commander.exe --timeout=15 --test-runner NUnitConsole --path=C:\Path-to-NUnit-console-installation-folder --args="--workers=16 --where \"cat == UnitTests\" C:/Path-to/MyTestProject1.dll C:/Path-to/MyTestProject2.dll"
```
### Run using dotnet testDotnet test is a little more flexible as you only need to give it the path to your solution or test project(s).
```
> NUnit.Commander.exe --timeout=15 --test-runner DotNetTest --args="C:/Path-to/MyTestProject"
```### Run using automatic test runner detection
NUnit.Commander can detect the runtime of your test assembly and schedule the appropriate test runner. Results will be aggregated and displayed for each runtime as well as a final summary.
```
> NUnit.Commander.exe --timeout=15 --test-runner Auto --nunit-args="--noheader --noresult --workers=16 --where \"cat != CategoryToExclude\"" --dotnet-args="--filter TestCategory!=CategoryToExclude" --test-assemblies="C:/Path-to/MyTestProject1.dll C:/Path-to/MyTestProject2.dll"
```