Azure Resource Manager LoadTest client library for Java - version 1.0.0

Azure Resource Manager LoadTest client library for Java.

This package contains Microsoft Azure SDK for LoadTest Management SDK. LoadTest client provides access to LoadTest Resource and it's status operations. Package tag package-2022-12-01. For documentation on how to use this package, please see Azure Management Libraries for Java.

We'd love to hear your feedback

We're always working on improving our products and the way we communicate with our users. So we'd love to learn what's working and how we can do better.

If you haven't already, please take a few minutes to complete this short survey we have put together.

Thank you in advance for your collaboration. We really appreciate your time!

Documentation

Various documentation is available to help you get started

Getting started

Prerequisites

Adding the package to your product

<dependency>
    <groupId>com.azure.resourcemanager</groupId>
    <artifactId>azure-resourcemanager-loadtesting</artifactId>
    <version>1.0.0</version>
</dependency>

Azure Management Libraries require a TokenCredential implementation for authentication and an HttpClient implementation for HTTP client.

Azure Identity and Azure Core Netty HTTP packages provide the default implementation.

Authentication

By default, Azure Active Directory token authentication depends on correct configuration of the following environment variables.

  • AZURE_CLIENT_ID for Azure client ID.
  • AZURE_TENANT_ID for Azure tenant ID.
  • AZURE_CLIENT_SECRET or AZURE_CLIENT_CERTIFICATE_PATH for client secret or client certificate.

In addition, Azure subscription ID can be configured via AZURE_SUBSCRIPTION_ID environment variable.

With above configuration, azure client can be authenticated using the following code:

AzureProfile profile = new AzureProfile(AzureEnvironment.AZURE);
TokenCredential credential = new DefaultAzureCredentialBuilder()
    .authorityHost(profile.getEnvironment().getActiveDirectoryEndpoint())
    .build();
LoadTestManager manager = LoadTestManager
    .authenticate(credential, profile);

The sample code assumes global Azure. Please change AzureEnvironment.AZURE variable if otherwise.

See Authentication for more options.

Key concepts

See API design for general introduction on design and key concepts on Azure Management Libraries.

Examples

Create a new Azure Load Testing resource

Create an Azure Load Testing resource.

LoadTestResource resource = manager
    .loadTests()
    .define("sample-loadtesting-resource")
    .withRegion(Region.US_WEST2)
    .withExistingResourceGroup("sample-rg")
    .create();

Create an Azure Load Testing resource configured with CMK encryption.

// map of user-assigned managed identities to be assigned to the loadtest resource
Map<String, UserAssignedIdentity> map = new HashMap<String, UserAssignedIdentity>();
map.put("/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/sample-rg/providers/microsoft.managedidentity/userassignedidentities/identity1", new UserAssignedIdentity());

// encryption identity must be assigned to the load test resource, before using it
LoadTestResource resource = manager
    .loadTests()
    .define("sample-loadtesting-resource")
    .withRegion(Region.US_WEST2)
    .withExistingResourceGroup("sample-rg")
    .withIdentity(
        new ManagedServiceIdentity()
        .withType(ManagedServiceIdentityType.SYSTEM_ASSIGNED_USER_ASSIGNED)
        .withUserAssignedIdentities(map)
    )
    .withEncryption(
        new EncryptionProperties()
        .withIdentity(
            new EncryptionPropertiesIdentity()
            .withResourceId("/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/sample-rg/providers/microsoft.managedidentity/userassignedidentities/identity1")
            .withType(Type.USER_ASSIGNED)
        )
        .withKeyUrl("https://sample-kv.vault.azure.net/keys/cmkkey/2d1ccd5c50234ea2a0858fe148b69cde")
    )
    .create();

Get details of an Azure Load Testing resource

LoadTestResource resource = manager
    .loadTests()
    .getByResourceGroup("sample-rg", "sample-loadtesting-resource");

Update an Azure Load Testing resource

Update an Azure Load Testing resource to configure CMK encryption using system-assigned managed identity.

LoadTestResource resource = manager
    .loadTests()
    .getByResourceGroup("sample-rg", "sample-loadtesting-resource");

LoadTestResource resourcePostUpdate = resource
    .update()
    .withIdentity(
        new ManagedServiceIdentity()
        .withType(ManagedServiceIdentityType.SYSTEM_ASSIGNED)
    )
    .withEncryption(
        new EncryptionProperties()
        .withIdentity(
            new EncryptionPropertiesIdentity()
            .withResourceId(null)
            .withType(Type.SYSTEM_ASSIGNED)
            // make sure that system-assigned managed identity is enabled on the resource and the identity has been granted required permissions to access the key.
        )
        .withKeyUrl("https://sample-kv.vault.azure.net/keys/cmkkey/2d1ccd5c50234ea2a0858fe148b69cde")
    )
    .apply();

Update an Azure Load Testing resource to update user-assigned managed identities.

Map<String, UserAssignedIdentity> map = new HashMap<String, UserAssignedIdentity>();
// Note: the value of <identity1> set to null, removes the previously assigned managed identity from the load test resource
map.put("/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/sample-rg/providers/microsoft.managedidentity/userassignedidentities/identity1", null);
map.put("/subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/sample-rg/providers/microsoft.managedidentity/userassignedidentities/identity2", new UserAssignedIdentity());

LoadTestResource resource = manager
    .loadTests()
    .getByResourceGroup("sample-rg", "sample-loadtesting-resource");

LoadTestResource resourcePostUpdate = resource
    .update()
    .withIdentity(
        new ManagedServiceIdentity()
        .withType(ManagedServiceIdentityType.USER_ASSIGNED)
        .withUserAssignedIdentities(map)
    )
    .apply();

Delete an Azure Load Testing resource

manager
    .loadTests()
    .deleteByResourceGroup("sample-rg", "sample-loadtesting-resource");

Quota Operations

Get quota values for all quota buckets.

PagedIterable<QuotaResource> resource = manager
    .quotas()
    .list("westus2");

for (QuotaResource quotaResource : resource) {
    // use the quotaResource
    System.out.println(quotaResource.limit());
}

Get quota values for a particular quota bucket.

QuotaResource resource = manager
    .quotas()
    .get("westus2", "maxConcurrentTestRuns");
System.out.println(resource.limit());

Check quota availability.

QuotaResource resource = manager
    .quotas()
    .get("westus2", "maxConcurrentTestRuns");

QuotaBucketRequestPropertiesDimensions dimensions = new QuotaBucketRequestPropertiesDimensions()
    .withLocation("westus2")
    .withSubscriptionId(manager.serviceClient().getSubscriptionId());

QuotaBucketRequest request = new QuotaBucketRequest()
    .withCurrentQuota(resource.limit())
    .withCurrentUsage(resource.usage())
    .withNewQuota(resource.limit())
    .withDimensions(dimensions);

CheckQuotaAvailabilityResponse availability = manager
    .quotas()
    .checkAvailability("westus2", "maxConcurrentTestRuns", request);

System.out.println(availability.isAvailable());

Code snippets and samples

Troubleshooting

Next steps

Contributing

For details on contributing to this repository, see the contributing guide.

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.

When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repositories using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.