10 releases

0.2.7 Oct 27, 2023
0.2.6 Oct 27, 2023
0.2.5 May 5, 2023
0.2.4 Sep 14, 2022
0.1.1 Aug 5, 2022

#459 in Rust patterns

Download history 11/week @ 2024-07-06 72/week @ 2024-07-13 224/week @ 2024-07-20 765/week @ 2024-07-27 1265/week @ 2024-08-03 1392/week @ 2024-08-10 1601/week @ 2024-08-17 1213/week @ 2024-08-24 1120/week @ 2024-08-31 1007/week @ 2024-09-07 862/week @ 2024-09-14 1387/week @ 2024-09-21 938/week @ 2024-09-28 862/week @ 2024-10-05 250/week @ 2024-10-12 915/week @ 2024-10-19

3,272 downloads per month
Used in diffsync

MIT license

17KB
420 lines

RandomVariant

Trait that returns a random variant of the given type, if you are creating a new type to limit some values, instead of deriving the RandomVariant, implement it manually to ensure only correct values are created Unless you also want to try the Result type Useful for hunting down unwraps or other assumptions in your code, The benefit over the crate EveryVariant is that this can be limited to A much smaller set to test, where generting every variant quickly can grow to unmanageable testing sets

Example

    use serde::Serialize;
    use std::net::IpAddr;

    #[derive(RandomVariant, Serialize)]
    enum Message {
        Log(String),
        ErrorCode(u32),
        /// This tuple will fail to serialize if flattened in serde
        Rebooting,
    }

    #[derive(RandomVariant, Serialize)]
    struct LoggedMessage {
        /// Fail to serialize, since flatteing enums is not supported
        #[serde(flatten)]
        t: Message,
        add: IpAddr,
    }
    let mut rng = crate::rand::thread_rng();
    
    /// This allows us to limit the testing set to trying 100 randomized structs
    for _i in 0..100 {
        let v = LoggedMessage::random_variant(&mut rng);
        serde_json::to_string(&v).unwrap();
    }

Dependencies

~1.5–2MB
~45K SLoC