Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kuy/macro-harness
Test harness for procedural macros
https://github.com/kuy/macro-harness
assert proc-macro rust testing-library
Last synced: 2 months ago
JSON representation
Test harness for procedural macros
- Host: GitHub
- URL: https://github.com/kuy/macro-harness
- Owner: kuy
- License: mit
- Created: 2021-08-15T13:06:50.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-05-05T09:48:23.000Z (9 months ago)
- Last Synced: 2024-05-05T10:37:28.428Z (9 months ago)
- Topics: assert, proc-macro, rust, testing-library
- Language: Rust
- Homepage:
- Size: 239 KB
- Stars: 7
- Watchers: 2
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
macro-harness
Test harness for procedural macros[![CI](https://github.com/kuy/macro-harness/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/kuy/macro-harness/actions/workflows/ci.yml)
![screen](./assets/screen.gif)
## 🚨 UNDERDEVELOPMENT 🚨
Working on MVP :)
## Usage
### 1. Prepare `Cargo.template.toml` file in `tests` directory
You can use a relative path to the local dependency.
No need to put `[lib]` section.```toml
[package]
name = "awesome-project-tests"
edition = "2018"
publish = false[dependencies]
futures = "1"
my-lunatic-dep = { path = "../../my-lunatic-dep" }
```### 2. Put a pair of source and output files in `tests` directory
`test_nodes.rs`
```rust
use flaterm_macro::layout;pub fn test() {
layout! {
};
}
````test_nodes.stdout`
```rust
#![feature(prelude_import)]
#[prelude_import]
use std::prelude::rust_2018::*;
#[macro_use]
extern crate std;
use flaterm_macro::layout;
pub fn test() {
{
let mut __flaterm_l = ::flaterm::Node::new(::std::string::String::from("Block"));
let mut __flaterm_c: ::std::vec::Vec<::flaterm::Node> = ::std::default::Default::default();
__flaterm_c.push(::std::convert::Into::into({
let mut __flaterm_l = ::flaterm::Node::new(::std::string::String::from("Text"));
__flaterm_l
}));
__flaterm_l.children = __flaterm_c;
__flaterm_l
};
}
```### 3. Write test file
`test.rs`
```rust
use macro_harness::run;#[test]
fn test_node() {
run("tests/test_nodes.rs");
}
```### 4. Run `cargo test` and get result
Here is a structure of an example project.
```
.
├── Cargo.toml
├── src
│ └── lib.rs
└── tests
├── Cargo.template.toml
├── test_nodes.rs
├── test_nodes.stdout
└── test.rs
```### 5. Use `MACRO_HARNESS=overwrite` environment variable to update `.stdout` files
`MACRO_HARNESS=overwrite cargo test`
## Example
See [`tests`](https://github.com/kuy/decom/tree/main/flaterm-macro/tests) in [flaterm-macro](https://github.com/kuy/decom/tree/main/flaterm-macro).
## TODOs
- [ ] Support glob match
- [ ] Stop using `panic!()` on everything
- [ ] Improve printing result
- [ ] CI using GitHub Actions
- [ ] Publish to crates.io
- [ ] Handle various errors
- [ ] Not installed `cargo-expand` crate
- [ ] Version mismatch of `cargo-expand` (require `1.0.8` or later)## License
MIT
## Author
Yuki Kodama / [@kuy](https://twitter.com/kuy)