Providers are used to feed data into test entities. Rhino framework is capable inject provider instances into injection points, that are class fields annotated with @Provider annotations. Provider interface’s take() method newly created objects which can be used in DSLs. There are standard providers provided by the framework, like UUIDProvider and UserProvider, which can be used to feed user information into the tests.

The provider instances are injected to class fields annotated with @Provider annotation, except the user providers which have their own annotation @UserProvider:

@Simulation(name = "Server-Status Simulation")
public class PerformanceTestingExample {

  private OAuthUserProvider userProvider;

  @Provider(factory = UUIDProvider.class)
  private UUIDProvider uuidProvider;

Now, you can use the providers to create new objects:

  @Dsl(name = "Upload File")
  public LoadDsl testUploadAndGetFile() {
    return Start
        .session("2. User", () -> userProvider.take())
        .run(http("PUT text.txt")
            .header(session -> from(X_REQUEST_ID, "Rhino-" + uuidProvider.take()))
            .header(X_API_KEY, SimulationConfig.getApiKey())
            .endpoint(session -> FILES_ENDPOINT)
            .upload(() -> file("classpath:///test.txt"))

In addition to standard providers, the developers may wish to create their custom providers by implementing the interface Provider<T>:

public class UUIDProvider implements Provider<String> {

  public String take() {
    return UUID.randomUUID().toString();

In the com.adobe.rhino.sdk.providers package, you will find some useful provider implementations, that you can use in your projects.