Skip to content
This repository has been archived by the owner on Sep 24, 2024. It is now read-only.

Latest commit

 

History

History
73 lines (48 loc) · 2.84 KB

DEVELOPMENT.md

File metadata and controls

73 lines (48 loc) · 2.84 KB

Development

This doc explains the development workflow so you can get started contributing to the GorillaStack Terraform Provider!

Getting started

First you will need to setup your GitHub account and create a fork:

  1. Create a GitHub account
  2. Setup GitHub access via SSH
  3. Create and checkout a repo fork

Once you have those, you can iterate on the provider:

  1. Run tests

When you're ready, you can create a PR!

Checkout your fork

To check out this repository:

  1. Create your own fork of this repo
  2. Clone it to your machine:
mkdir -p ${GOPATH}/src/github.com/gorillastack
cd ${GOPATH}/src/github.com/gorillastack
git clone [email protected]:${YOUR_GITHUB_USERNAME}/terraform-provider-gorillastack.git
cd terraform-provider-gorillastack
git remote add upstream [email protected]:gorillastack/terraform-provider-gorillastack.git
git remote set-url --push upstream no_push

Adding the upstream remote sets you up nicely for regularly syncing your fork.

Testing

The provider has both unit tests and acceptance tests.

Unit Tests

To run unit tests simply run

make test

Acceptance tests

Acceptance tests are run against real infrastructure and thus require credentials for an GorillaStack team. Be sure not to run this anywhere but a test org. Start by copying .env.sample and installing a version of dotenv cli or simply export these values into your environment.

cp .env.sample .env
dotenv make testacc

Creating a PR

When you have changes you would like to propose to kritis, you will need to:

  1. Ensure the commit message(s) describe what issue you are fixing and how you are fixing it (include references to issue numbers if appropriate)
  2. Create a pull request
  3. Post a screenshot of the passing ACC tests. If you do not have access to a GorillaStack team, you can request a maintainer run the ACC tests. These tests make ALOT of API calls so free dev accounts, the configured number of retries, and the backoff duration may not be enough to get through all of the tests.

Reviews

Each PR must be reviewed by a maintainer. In order for a PR to merge you must post a screenshot of the ACC tests passing. We do not run these via Travis due to GorillaStack rate limiting. It gets to be untenable. Maintainers have access to GorillaStack team they can run this against so if you are an outside contributor feel free to request ACC tests be run.