Rand derive 2

Latest Version Build Status

Derive macro for generating random types with the rand crate. It will implement the rand::distributions::Standard for a given type.

Usage

Check out the example crate or follow the instructions below.

  1. Add this to your Cargo.toml file:

toml [dependencies] rand-derive = "0.1" rand = "0.7"

  1. Import the macro somewhere in your file where your type is: rust use rand_derive2::RandGen;

Alternatively, use this to global import the macro: ```rust

[macro_use]

extern crate rand_derive2; ```

  1. Add the RandGen derive macro for your type: ```rust

    [derive(RandGen)]

struct MyStruct {} ```

  1. Generate your struct: ```rust fn generatemystruct() -> MyStruct { rand::random() }

// Or like this fn generatemystructdirect() -> MyStruct { MyStruct::generaterandom() } ```

Customization

Note: all things that can be customized is covered in the example crate

Options

To make sure an option is never generated with None, add the rand_derive(none) attribute on top of the property. To make sure an option is never generated with Some, add the rand_derive(some) attribute on top of the property.

Skip enum variant

If a variant should never be generated, add the rand_derive(skip) attribute on the variant.

Custom value

If you want a custom value for one of the properties, add the rand_derive(custom) attribute. A trait is created called TestDataProviderFor$TYPE$. This trait will require the user to provider the values.

No rand

Panic implementation of the property, making the type unable to be random generated. Add the rand_derive(panic) attribute for this case.

Default value

Place rand_derive(default) above a field to make it generate the default value.

Fixed value

Place rand_derive(fixed = "MY_VALUE") above a field to make it generate the fixed value.

How it works

Structs

It calls rng.gen() on all the fields.

Enums

It will generate a random variant.

Types with lifetimes

It doesn't make sense to generate a type with a lifetime attached, because than a type with the owned values must be created somewhere, but where? It could be maybe done by leaking the type that owns the values, but that isn't implemented at the moment.

TODO

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.


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