Updating generated source matching API 10.10.1.45 #378
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
name: New broker build Module Test | |
on: | |
push: | |
branches-ignore: | |
- dev* | |
- v* | |
- main | |
jobs: | |
test: | |
name: Run Provider setup and tests | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out code | |
uses: actions/checkout@v4 | |
- name: Set up Go | |
uses: actions/setup-go@v3 | |
with: | |
go-version: "1.22" | |
- name: Set up Terraform latest | |
uses: hashicorp/setup-terraform@v3 | |
with: | |
terraform_wrapper: false | |
- name: Checkout generator | |
uses: actions/checkout@v4 | |
with: | |
repository: SolaceDev/broker-terraform-code-generator | |
token: ${{ secrets.GH_PAT }} # `GH_PAT` is a secret that contains your PAT | |
path: broker-terraform-code-generator | |
ref: "main" | |
- name: Build and install generator | |
run: | | |
pushd broker-terraform-code-generator | |
go install . | |
ls ~/go/bin | |
popd | |
- name: Generate provider code | |
run: | | |
SWAGGER_SPEC_NAME=`ls ci/swagger_spec` | |
echo "Generating code using spec $SWAGGER_SPEC_NAME" | |
rm ./*.tf | |
SEMP_V2_SWAGGER_CONFIG_EXTENDED_JSON="ci/swagger_spec/$SWAGGER_SPEC_NAME" MODULE_TEMPLATE_FOLDER="internal/gen-template" ~/go/bin/broker-terraform-code-generator software-module | |
- name: Add copyright headers where needed | |
run: | | |
go install github.com/google/addlicense@latest | |
addlicense -c 'Solace Corporation. All rights reserved.' -v -l apache ./*.tf | |
addlicense -c 'Solace Corporation. All rights reserved.' -v -l apache $(find ./examples -name "*.tf" -type f -print0 | xargs -0) | |
- name: Check changed files | |
uses: tj-actions/verify-changed-files@v17 | |
id: check-changed-files | |
with: | |
files: | | |
!broker-terraform-code-generator | |
!VERSION | |
- name: Run step only when no change detected | |
if: steps.check-changed-files.outputs.files_changed == 'false' | |
run: | | |
echo "No changes detected, skipping further steps" | |
- name: Setup Test broker | |
if: steps.check-changed-files.outputs.files_changed == 'true' | |
run: | | |
mkdir -p $HOME/solace; chmod 777 $HOME/solace | |
docker run -d -p 8080:8080 -p 55555:55555 --shm-size=1g --env username_admin_globalaccesslevel=admin --env username_admin_password=admin --env system_scaling_maxkafkabridgecount="10" --name=solace \ | |
--env system_scaling_maxconnectioncount="1000" --mount type=bind,source=$HOME/solace,destination=/var/lib/solace,ro=false solace/solace-pubsub-standard:latest | |
while ! curl -s localhost:8080 | grep aurelia ; do sleep 1 ; done | |
- name: List changed files - from now on all tests are run only if there were changes | |
if: steps.check-changed-files.outputs.files_changed == 'true' | |
run: | | |
echo "Changed files: ${{ steps.check-changed-files.outputs.changed_files }}" | |
git diff | |
- name: Test module from template on test broker | |
if: steps.check-changed-files.outputs.files_changed == 'true' | |
run: | | |
ci/scripts/test-module.sh ci/template-test | |
- name: Test module root on test broker | |
if: steps.check-changed-files.outputs.files_changed == 'true' | |
run: | | |
ci/scripts/test-module.sh ci/module-test | |
- name: Test examples | |
if: steps.check-changed-files.outputs.files_changed == 'true' | |
run: | | |
shopt -s extglob | |
for d in examples/!(basic-client-username)/; do (ci/scripts/test-module.sh "$d"); done | |
# ci/scripts/test-module.sh examples/basic-client-username/ -var-file=secret.tfvars | |