[data:image/s3,"s3://crabby-images/386f3/386f30a3f9afa41123d37e227319807a4556aa56" alt="ubuntu-latest"](https://github.com/NickelAngeStudio/tests_bin/actions/workflows/ubuntu-latest.yml)
[data:image/s3,"s3://crabby-images/a6d94/a6d948ff1a1a31caeca4cb5bfd697c066eb8681d" alt="windows-latest"](https://github.com/NickelAngeStudio/tests_bin/actions/workflows/windows-latest.yml)
[data:image/s3,"s3://crabby-images/7899d/7899d3ebe786a421a21ed8f7fb14b4b8179cfbd3" alt="macos-latest"](https://github.com/NickelAngeStudio/tests_bin/actions/workflows/macos-latest.yml)
[data:image/s3,"s3://crabby-images/2aac3/2aac3b8843554ce0322abde806b57c3c398cd116" alt="ubuntu-performance"](https://github.com/NickelAngeStudio/tests_bin/actions/workflows/ubuntu-performance.yml)
[data:image/s3,"s3://crabby-images/29d60/29d60f574af4761d5f4a0083625a2cea862fc0c7" alt="windows-performance"](https://github.com/NickelAngeStudio/tests_bin/actions/workflows/windows-performance.yml)
[data:image/s3,"s3://crabby-images/935c9/935c94539f1a897ddaeab61c121e4852ebabf2a1" alt="macos-performance"](https://github.com/NickelAngeStudio/tests_bin/actions/workflows/macos-performance.yml)
# tests_bin
This crate is aimed toward Rustacean who wish to have a bin folder where they can easily organize all their unit tests to clean their src folder. VSCode extension included! [Visit Wiki for more informations.](https://github.com/NickelAngeStudio/tests_bin/wiki)
## Features
### *Crate*
- Organize your unit tests with one relative path.
- Automatically create your unit tests module name.
- Add attribute macro directly above your item for easier unit tests tracking.
- Work with rust-analyzer to run your tests.
- Unit tests folder path is customizable.
### *VSCode Extension*
- Shortcut to create new unit tests file in bin folder.
- Open your unit tests files directly from your code.
- Shortcuts to rename and delete unit tests file.
- Customizable new unit tests file template.
- Lots of settings to fit your taste.
[More features details in wiki.](https://github.com/NickelAngeStudio/tests_bin/wiki/Features)
## Installation
```bash
cargo add tests_bin
```
## VSCode extension installation
Launch VS Code Quick Open (Ctrl+P), paste the following command, and press enter.
```
ext install nas.rust-tests-bin
```
## Usage
```rust
use tests_bin::{ unit__tests, unit_tests };
// Will link a module to `tests/unit/global_tests.rs` with a module named `global_test_rs`.
unit__tests!("global_tests.rs");
// Will link a module to `tests/unit/add.rs` with a module named `pub_fn_add_usize`.
#[unit_tests("add.rs")]
pub fn add(left: usize, right: usize) -> usize {
left + right
}
```
## Syntax
Without [item](https://doc.rust-lang.org/reference/items.html) : `unit__tests!("relative_path.rs" {, "module name"});`
With an [item](https://doc.rust-lang.org/reference/items.html) : `#[unit_tests("relative_path.rs" {, "module name"})] item`
*The element in `{}` are optional. The extension `.rs` is required.*
## License
[MIT](https://choosealicense.com/licenses/mit/)