1 unstable release

0.1.0 Nov 14, 2024

#345 in Testing

MIT/Apache

64KB
877 lines

json-test

Crates.io Documentation License

A testing library for JSON Path assertions in Rust, providing a fluent API for validating JSON structures in tests.

Features

  • 🔍 JSONPath-based value extraction and validation
  • ⛓️ Chainable, fluent assertion API
  • 🎯 Type-safe operations
  • 🧩 Property existence and value validation
  • 📝 String pattern matching with regex support
  • 🔢 Numeric comparisons
  • 📦 Array and object validation
  • 🎨 Custom matcher support

Quick Start

Add to your Cargo.toml:

[dev-dependencies]
json-test = "0.1"

Basic usage:

use json_test::JsonTest;
use serde_json::json;

#[test]
fn test_json_structure() {
    let data = json!({
        "user": {
            "name": "John Doe",
            "age": 30,
            "roles": ["user", "admin"]
        }
    });

    let mut test = JsonTest::new(&data);
    
    test.assert_path("$.user.name")
        .exists()
        .is_string()
        .equals(json!("John Doe"));
        
    test.assert_path("$.user.roles")
        .is_array()
        .has_length(2)
        .contains(&json!("admin"));
}

Main Features

Path Assertions

test.assert_path("$.user")
    .exists()
    .has_property("name")
    .has_property_value("age", json!(30));

String Operations

test.assert_path("$.user.email")
    .is_string()
    .contains_string("@")
    .matches_pattern(r"^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$");

Numeric Comparisons

test.assert_path("$.user.age")
    .is_number()
    .is_greater_than(18)
    .is_less_than(100);

Array Operations

test.assert_path("$.user.roles")
    .is_array()
    .has_length(2)
    .contains(&json!("admin"));

Property Matching

test.assert_path("$.user")
    .has_properties(vec!["name", "age", "roles"])
    .properties_matching(|key| key.starts_with("meta_"))
        .count(0)
        .and()
    .has_property_matching("age", |v| v.as_u64().unwrap_or(0) > 18);

Custom Matchers

test.assert_path("$.timestamp")
    .matches(|value| {
        value.as_str()
            .map(|s| s.parse::<DateTime<Utc>>().is_ok())
            .unwrap_or(false)
    });

Examples

Looking for more examples? Check out the examples/ directory which showcases:

  • Basic JSON validation patterns
  • Advanced JSONPath queries
  • Property matching capabilities

Error Messages

The library provides clear, test-friendly error messages:

Property 'email' not found at $.user
Available properties: name, age, roles

Array at $.user.roles has wrong length
Expected: 3
Actual: 2

Status

This library is in active development (0.1.x). While the core API is stabilizing, minor breaking changes might occur before 1.0.

Roadmap

  • Enhanced array operations
  • Deep property traversal
  • Improved string operations
  • Additional numeric assertions

Contributing

Contributions are welcome! Please see our Contributing Guide for details.

License

Licensed under either of:

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~5–7MB
~133K SLoC