Added service brokers datasource #122
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Terraform Provider testing workflow. | |
name: Terraform Provider Build Tests | |
# This GitHub action runs your tests for each pull request and push. | |
# Optionally, you can turn it on using a schedule for regular testing. | |
on: | |
pull_request: | |
types: | |
- opened | |
- reopened | |
- synchronize | |
- ready_for_review | |
paths-ignore: | |
- '*.md' | |
push: | |
branches: | |
- main | |
paths-ignore: | |
- '*.md' | |
workflow_dispatch: | |
workflow_call: | |
# Testing only needs permissions to read the repository contents. | |
permissions: | |
contents: read | |
# Define the latest Terraform version to use for upload of coverage report | |
env: | |
LATEST_VERSION: 1.9.* | |
jobs: | |
# Ensure project builds before running testing matrix | |
build: | |
name: Build | |
runs-on: ubuntu-latest | |
timeout-minutes: 5 | |
steps: | |
- uses: actions/checkout@v4 # v4.0.0 | |
- uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 # v5.0.2 | |
with: | |
go-version-file: 'go.mod' | |
#cache: true | |
- run: go mod download | |
- run: go build -v . | |
- name: Run linters | |
uses: golangci/golangci-lint-action@971e284b6050e8a5849b72094c50ab08da042db8 # v3.7.1 | |
with: | |
version: latest | |
generate: | |
if: github.event.pull_request.draft == false | |
name: Docu Generation | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 # v4.0.0 | |
- uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 # v5.0.2 | |
with: | |
go-version-file: 'go.mod' | |
cache: true | |
- run: go generate ./... | |
- name: git diff | |
run: | | |
git diff --compact-summary --exit-code || \ | |
(echo; echo "Unexpected difference in directories after code generation. Run 'go generate ./...' command and commit."; exit 1) | |
# Run acceptance tests in a matrix with Terraform CLI versions | |
test_with_terraform_versions: | |
if: github.event.pull_request.draft == false | |
name: Terraform Provider Acceptance Tests | |
needs: build | |
runs-on: ubuntu-latest | |
timeout-minutes: 15 | |
strategy: | |
fail-fast: false | |
matrix: | |
# list whatever Terraform versions here you would like to support | |
terraform: | |
- '1.5.*' #end of security support under MPL 31 Dec 2023 | |
- '1.6.*' #end of security support under BSL 31 Dec 2025 | |
- '1.7.*' #end of security support under BSL 31 Dec 2026 | |
- '1.8.*' #end of security support under BSL 31 Dec 2026 | |
- '1.9.*' #end of security support under | |
steps: | |
- uses: actions/checkout@v4 # v4.0.0 | |
- uses: actions/setup-go@0a12ed9d6a96ab950c8f026ed9f722fe0da7ef32 # v5.0.2 | |
with: | |
go-version-file: 'go.mod' | |
cache: true | |
- uses: hashicorp/setup-terraform@b9cd54a3c349d3f38e8881555d616ced269862dd # v3.1.2 | |
with: | |
terraform_version: ${{ matrix.terraform }} | |
terraform_wrapper: false | |
- run: go mod download | |
- if: ${{ matrix.terraform != env.LATEST_VERSION}} | |
env: | |
TF_ACC: "1" | |
run: go test -v -timeout=900s -parallel=4 ./... | |
timeout-minutes: 20 | |
- if: ${{ matrix.terraform == env.LATEST_VERSION}} | |
env: | |
TF_ACC: "1" | |
uses: robherley/go-test-action@v0 | |
with: | |
testArguments: -v -cover -coverprofile=cover.out -timeout=900s -parallel=4 ./... | |
- uses: actions/upload-artifact@v4 | |
if: ${{ matrix.terraform == env.LATEST_VERSION}}} | |
with: | |
name: coverage-report | |
path: cover.out | |
# sonarcloud: | |
# if: github.event.pull_request.draft == false | |
# name: SonarCloud | |
# needs: test_with_terraform_versions | |
# runs-on: ubuntu-latest | |
# steps: | |
# - uses: actions/checkout@v4 | |
# with: | |
# fetch-depth: 0 # Shallow clones should be disabled for a better relevancy of analysis | |
# - uses: actions/download-artifact@v4 | |
# with: | |
# name: coverage-report | |
# - name: SonarCloud Scan | |
# uses: SonarSource/sonarcloud-github-action@master | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
# SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} |