#arbitrary #testing


The trait for generating structured data from unstructured data

19 releases (2 stable)

1.0.1 May 20, 2021
1.0.0 Feb 24, 2021
1.0.0-rc1 Nov 26, 2020
0.4.7 Oct 14, 2020
0.1.0 May 8, 2017

#5 in Testing

Download history 16221/week @ 2021-02-24 17796/week @ 2021-03-03 19891/week @ 2021-03-10 17100/week @ 2021-03-17 17223/week @ 2021-03-24 16235/week @ 2021-03-31 15783/week @ 2021-04-07 15681/week @ 2021-04-14 14347/week @ 2021-04-21 16359/week @ 2021-04-28 15974/week @ 2021-05-05 16592/week @ 2021-05-12 17751/week @ 2021-05-19 16230/week @ 2021-05-26 22123/week @ 2021-06-02 17073/week @ 2021-06-09

70,143 downloads per month
Used in 99 crates (63 directly)


1.5K SLoC


The trait for generating structured data from arbitrary, unstructured input.

GitHub Actions Status


The Arbitrary crate lets you construct arbitrary instances of a type.

This crate is primarily intended to be combined with a fuzzer like libFuzzer and cargo-fuzz or AFL, and to help you turn the raw, untyped byte buffers that they produce into well-typed, valid, structured values. This allows you to combine structure-aware test case generation with coverage-guided, mutation-based fuzzers.


Read the API documentation on docs.rs!


Say you're writing a color conversion library, and you have an Rgb struct to represent RGB colors. You might want to implement Arbitrary for Rgb so that you could take arbitrary Rgb instances in a test function that asserts some property (for example, asserting that RGB converted to HSL and converted back to RGB always ends up exactly where we started).

Automatically Deriving Arbitrary

Automatically deriving the Arbitrary trait is the recommended way to implement Arbitrary for your types.

Automatically deriving Arbitrary requires you to enable the "derive" cargo feature:

# Cargo.toml

arbitrary = { version = "1", features = ["derive"] }

And then you can simply add #[derive(Arbitrary)] annotations to your types:

// rgb.rs

use arbitrary::Arbitrary;

pub struct Rgb {
    pub r: u8,
    pub g: u8,
    pub b: u8,

Implementing Arbitrary By Hand

Alternatively, you can write an Arbitrary implementation by hand:

// rgb.rs

use arbitrary::{Arbitrary, Result, Unstructured};

#[derive(Copy, Clone, Debug)]
pub struct Rgb {
    pub r: u8,
    pub g: u8,
    pub b: u8,

impl<'a> Arbitrary<'a> for Rgb {
    fn arbitrary(u: &mut Unstructured<'a>) -> Result<Self> {
        let r = u8::arbitrary(u)?;
        let g = u8::arbitrary(u)?;
        let b = u8::arbitrary(u)?;
        Ok(Rgb { r, g, b })


Licensed under dual MIT or Apache-2.0 at your choice.

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