Skip to content

Latest commit

 

History

History
102 lines (72 loc) · 4.45 KB

CONTRIBUTING.md

File metadata and controls

102 lines (72 loc) · 4.45 KB

Contributing

We appreciate feedback and contribution to this provider. Before you submit a pull request, there are a couple requirements to satisfy.

Prerequisites

Reading Material

Getting Started

To work on the provider, you'll need Go installed on your machine (version 1.18+ is required). You'll also need to set up a $GOPATH, and add $GOPATH/bin to your $PATH.

To compile the provider, run make install VERSION=X.X.X. This will build the provider and install the provider binary in the ${HOME}/.terraform.d/plugins directory, so it can be used directly in terraform required_providers block.

make install VERSION=0.2.0
...
# On macOS, this will install the provider in a location like the following:
# ~/.terraform.d/plugins/registry.terraform.io/auth0/auth0/0.2.0/darwin_amd64/terraform-provider-auth0_v0.2.0
...
terraform {
    required_providers {
        auth0 = {
            source  = "auth0/auth0"
            version = "0.2.0"
        }
    }
}

Documentation

The documentation found in the docs folder is generated using terraform-plugin-docs. Do not edit files within this folder manually.

Run make docs to regenerate documentation for newly added resources and schema attributes or if changes are needed to existing schemas.

make docs

Running the Tests

The tests can be run using the following make commands:

  • make test-unit - runs all the unit tests.
  • make test-acc - runs the tests with http recordings. To run a specific test pass the FILTER var. Usage make test-acc FILTER="TestAccResourceServer".
  • make test-acc-e2e - runs the tests against a real Auth0 tenant. To run a specific test pass the FILTER var. Usage make test-acc-e2e FILTER="TestAccResourceServer".

Note The http test recordings can be found in the recordings folder.

To run the tests against an Auth0 tenant start by creating an M2M app in the tenant, that has been authorized to request access tokens for the Management API and has all the required permissions.

Then set the following environment variables on your machine:

  • AUTH0_DOMAIN: The Domain of the M2M app
  • AUTH0_CLIENT_ID: The Client ID of the M2M app
  • AUTH0_CLIENT_SECRET: The Client Secret of the M2M app
  • AUTH0_DEBUG: Set to true to call the Management API in debug mode, which dumps the HTTP requests and responses to the output

Warning The e2e acceptance tests make calls to a real Auth0 tenant, and create real resources. Certain tests also require a paid Auth0 subscription to be able to run successfully, e.g. TestAccCustomDomain and the ones starting with TestAccLogStream*.

Note At the time of writing, the following configuration steps are also required for the test tenant:

  • The Username-Password-Authentication connection must have Requires Username option enabled for the user tests to successfully run.

Adding New HTTP Test Recordings

When creating a new Terraform resource or adding a new resource property, the http recordings will need to be re-recorded. To add new http test recordings or to regenerate old ones, use the make test-acc-record command.

Warning If you need to regenerate an old recording, make sure to delete the corresponding recording file first.

To add only one specific http test recording pass the FILTER var, for example make test-acc-record FILTER="TestAccResourceServer".

Warning Recording a new http test interaction will make use of a real Auth0 test tenant.

Resetting the Test Tenant

All resources created through running the tests against an Auth0 tenant can be removed by running make test-sweep.