All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.jqwik.api.configurators.ArbitraryConfigurator Maven / Gradle / Ivy

There is a newer version: 1.9.2
Show newest version
package net.jqwik.api.configurators;

import org.apiguardian.api.*;

import net.jqwik.api.*;
import net.jqwik.api.providers.*;

import static org.apiguardian.api.API.Status.*;

/**
 * Implementors can modify any arbitrary before it's being used for value generation.
 * Most implementations use {@linkplain ArbitraryConfiguratorBase} to derive from
 *
 * 

* Implementations must be registered in /META-INF/services/net.jqwik.api.configurators.ArbitraryConfigurator * so that they will be automatically considered for arbitrary configuration. *

*/ @API(status = MAINTAINED, since = "1.0") public interface ArbitraryConfigurator extends Comparable { /** * Configure a given {@code arbitrary} and return the configured instance. * * @param arbitrary The arbitrary instance to be configured * @param targetType The type of the object to be generated by the arbitrary * @return the newly configured arbitrary instance */ Arbitrary configure(Arbitrary arbitrary, TypeUsage targetType); /** * Determines the order in which a configurator will be applied in regards to other configurators. * Default value is {@code 100}. Use lower values to enforce earlier application and * higher values for later application. * * @return the order */ default int order() { return 100; } @Override default int compareTo(ArbitraryConfigurator other) { return Integer.compare(this.order(), other.order()); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy