Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/blyxyas/cargo-is-tested
Assure that your tests are there, and well written.
https://github.com/blyxyas/cargo-is-tested
binary cargo cargo-subcommand rust rust-tools testing testing-tools
Last synced: 2 months ago
JSON representation
Assure that your tests are there, and well written.
- Host: GitHub
- URL: https://github.com/blyxyas/cargo-is-tested
- Owner: blyxyas
- License: mit
- Created: 2022-12-28T18:42:57.000Z (about 2 years ago)
- Default Branch: master
- Last Pushed: 2023-01-19T15:52:49.000Z (almost 2 years ago)
- Last Synced: 2024-10-20T00:19:38.268Z (3 months ago)
- Topics: binary, cargo, cargo-subcommand, rust, rust-tools, testing, testing-tools
- Language: Rust
- Homepage: https://blyxyas.github.io/cargo-is-tested/
- Size: 1.19 MB
- Stars: 15
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
cargo-is-tested
[🇪🇸] [El libro](https://blyxyas.github.io/cargo-is-tested) contiene instrucciones e información detallada en Español.
---
`cargo-is-tested` is a way to check which of your items are tested and which aren't, very configurable and with a scripting-friendly API ready to use with your Git hooks.
Also, is uses *✨ pretty colors ✨* for error reporting.
**You can also [read the book](https://blyxyas.github.io/cargo-is-tested) for a more user-friendly guide.**
## Example
To check if all functions are tested in the current directory.
```bash
$ cargo is-tested .
``````toml
# Cargo.toml
# [...][dependencies]
is_tested = "0.1.1" # Check crates.io for the current version of the crate.# [...]
``````rust
// src/main.rs#! is-tested functions
// Yes, it uses shebangs to enable testing and flags!use is_tested::is_tested;
#[is_tested("test/myfunction_testing_path.rs")]
fn my_function() {
// [...]
}
```Then, it will check if `test/myfunction_testing_path.rs` exists, if it doesn't, it will output an error.
If the file exists, the program checks all lints against your test, assuring the best quality possible. For example, the lint `emptiness` will check that your functions aren't empty.
## Installation and usage
To get started using `cargo-is-tested`, install the binary.
```bash
$ cargo install cargo-is-tested
```Now [document yourself](https://docs.rs/cargo-is-tested/latest/cargo-is-tested/lints) about all the lints you can apply to your tests. You can also use `strict` to activate them all (currently, recommendable)
More lints will be added with time.
---
Once you know the lints you want to apply, import the attribute `is_tested`, then choose a struct, function or any item that you want to test, and add to that item the attribute `#[is_tested(".rs")]`
The result should be something like:
```rust
#! is-tested strictuse is_tested::is_tested;
#[is_tested("tests/mystruct.rs")]
struct MyStruct<'a> {
string: &'a str
}
```Don't worry, the attribute won't change anything in your code, it's just a marker for a later-parser to know that you're testing the item.
---
It's time to run the parser, it will read check that all tested items are tested, and with the correct code quality dicted using the lints.
```rust
// tests/mystruct.rsuse mycrate::MyStruct;
fn main() {
// [...]
}
``````bash
$ cargo is-tested .
```This will check that all tests are well written. You can use flags to customize your experience, for example, use `--structs` to check that all structs have tests associated, or use `--test` to, if all tests are confirmed, run `cargo test` automatically.
---
### Stargazers
[![Stargazers repo roster for @blyxyas/cargo-is-tested](https://reporoster.com/stars/blyxyas/cargo-is-tested)](https://github.com/blyxyas/cargo-is-tested/stargazers)
### License
`cargo-is-tested` uses the **MIT License**, 2023.
You can check the [LICENSE](https://github.com/blyxyas/cargo-is-tested/blob/master/LICENSE) for more information about licensing.