diff options
| author | mo khan <mo@mokhan.ca> | 2025-07-02 18:36:06 -0600 |
|---|---|---|
| committer | mo khan <mo@mokhan.ca> | 2025-07-02 18:36:06 -0600 |
| commit | 8cdfa445d6629ffef4cb84967ff7017654045bc2 (patch) | |
| tree | 22f0b0907c024c78d26a731e2e1f5219407d8102 /vendor/logos-codegen/tests/codegen.rs | |
| parent | 4351c74c7c5f97156bc94d3a8549b9940ac80e3f (diff) | |
chore: add vendor directory
Diffstat (limited to 'vendor/logos-codegen/tests/codegen.rs')
| -rw-r--r-- | vendor/logos-codegen/tests/codegen.rs | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/vendor/logos-codegen/tests/codegen.rs b/vendor/logos-codegen/tests/codegen.rs new file mode 100644 index 00000000..5f53c0db --- /dev/null +++ b/vendor/logos-codegen/tests/codegen.rs @@ -0,0 +1,31 @@ +use std::{error::Error, io, path::PathBuf}; + +#[rstest::rstest] +#[case("simple")] +#[case("no_error_lut")] +pub fn test_codegen(#[case] fixture: &str) -> Result<(), Box<dyn Error>> { + let mut fixture_dir = PathBuf::new(); + fixture_dir.push(env!("CARGO_MANIFEST_DIR")); + fixture_dir.push("tests"); + fixture_dir.push("data"); + fixture_dir.push(fixture); + + let input = fixture_dir.join("input.rs"); + fixture_dir.push("output.rs"); + let output_file = fixture_dir; + + let input = std::fs::read_to_string(input)?; + let output = std::fs::read_to_string(&output_file)?; + + let generated = logos_codegen::generate(input.parse()?); + let generated = generated.to_string(); + + if std::env::var("BLESS_CODEGEN").is_ok_and(|value| value == "1") { + std::fs::write(&output_file, &generated)?; + return Ok(()); + } + + assert_eq!(generated, output, "Codegen test failed: `{fixture}`, run tests again with env var `BLESS_CODEGEN=1` to bless these changes"); + + Ok(()) +} |
