# NTest
[data:image/s3,"s3://crabby-images/cc775/cc775e91f7bc1e81fd8219238b4c82749809ceb4" alt=""](https://docs.rs/ntest)
[data:image/s3,"s3://crabby-images/e3cdf/e3cdf0b8791354a008f6cd987cfaf7096351882b" alt=""](https://crates.io/crates/ntest)
[data:image/s3,"s3://crabby-images/36370/36370c22be4f6d5b99f713a36f0b7988dc3cb1dc" alt=""](https://crates.io/crates/ntest)
[data:image/s3,"s3://crabby-images/21a62/21a62d724144d6fe5d66a0b9912a150460b2000e" alt="Build Status"](https://gitlab.com/becheran/ntest_ci/pipelines)
[data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt=""](https://opensource.org/licenses/MIT)
Testing framework for rust which enhances the built-in library with some useful features. Inspired by the *.Net* unit-testing framework [NUnit](https://github.com/nunit/nunit).
- [documentation](https://docs.rs/ntest/)
- [library on crates.io](https://crates.io/crates/ntest)
## Getting Started
Some functions of *NTest* use [procedural macros](https://doc.rust-lang.org/reference/procedural-macros.html) which are stable for rust edition 2018.
If you use the library make sure that you are using the *2018 version* of rust. Update the *Cargo.toml* file:
```toml
[package]
edition = "2018"
# ..
```
Add the *NTest library* to your developer dependencies in the *Cargo.toml* file:
```toml
[dev-dependencies]
ntest = "*"
```
## Content
- `#[timeout()]` Attribute used for timeouts in tests.
- `#[test_case()]` Attribute used to define multiple test cases for a test function.
- `assert_about_equal!()` Compare two floating point values or vectors for equality.
- `assert_false!()` Expects false argument for test case.
- `assert_true!()` Expects true argument for test case.
- `assert_panics!()` Expects block to panic. Otherwise the test fails.
For more information read the [documentation](https://docs.rs/ntest/).
## Examples
### Create test cases
```rust
use ntest::test_case;
#[test_case("https://doc.rust-lang.org.html")]
#[test_case("http://www.website.php", name="important_test")]
fn test_http_link_types(link: &str) {
test_link(link, &LinkType::HTTP);
}
```
### Timeout for long running functions
```rust
use ntest::timeout;
#[test]
#[timeout(10)]
#[should_panic]
fn timeout() {
loop {};
}
```
### Combine attributes
```rust
use std::{thread, time};
use ntest::timeout;
use ntest::test_case;
#[test_case(200)]
#[timeout(100)]
#[should_panic]
#[test_case(10)]
#[timeout(100)]
fn test_function(i : u32) {
let sleep_time = time::Duration::from_millis(i);
thread::sleep(sleep_time);
}
```
## Changelog
Checkout the [changelog file](https://github.com/becheran/ntest/blob/master/CHANGELOG.md) to see the changes between different versions.
## License
This project is licensed under the MIT License - see the [LICENSE](https://github.com/becheran/ntest/blob/master/LICENSE) file for details.