Service flag support for AWS Backup (#804) #1552
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: CI | |
on: [push] | |
jobs: | |
test: | |
name: Unit Tests | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v1 | |
# https://github.com/mvdan/github-actions-golang#how-do-i-set-up-caching-between-builds | |
- uses: actions/cache@v2 | |
with: | |
# In order: | |
# * Module download cache | |
# * Build cache (Linux) | |
# * Build cache (Mac) | |
# * Build cache (Windows) | |
path: | | |
~/go/pkg/mod | |
~/.cache/go-build | |
~/Library/Caches/go-build | |
%LocalAppData%\go-build | |
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }} | |
restore-keys: | | |
${{ runner.os }}-go- | |
- name: Setup Go | |
uses: actions/setup-go@v2 | |
with: | |
go-version: "1.22.1" | |
- name: Build All Platforms | |
run: make ci-cli-all-platforms | |
# Upload the built binaries to use in later tests on each platform | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: go-binaries-linux | |
path: ./bin/linux/ | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: go-binaries-macos | |
path: ./bin/macos/ | |
- uses: actions/upload-artifact@v3 | |
with: | |
name: go-binaries-windows | |
path: ./bin/windows/ | |
- name: Lint | |
run: go vet ./... | |
- name: Test | |
run: go test ./... | |
golangci-lint: | |
name: Go Lint | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/setup-go@v3 | |
with: | |
go-version: 1.22.1 | |
- uses: actions/checkout@v2 | |
- name: golangci-lint | |
uses: golangci/golangci-lint-action@v3 | |
timeout-minutes: 5 | |
with: | |
version: latest | |
args: --timeout 5m | |
shellcheck: | |
name: Shellcheck | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Run ShellCheck | |
uses: ludeeus/action-shellcheck@94e0aab03ca135d11a35e5bfc14e6746dc56e7e9 | |
# linux-installs: | |
# needs: test | |
# name: Smoke Test (Linux) | |
# env: | |
# TEST_ACCESS_KEY_ID: 1234578910abcdefghij | |
# TEST_ACCESS_KEY: 1234578910abcdefghijklmnopqrstuvwxyz1234 | |
# TEST_REGION: ap-southeast-2 | |
# runs-on: ubuntu-latest | |
# steps: | |
# - uses: actions/download-artifact@v3 | |
# with: | |
# name: go-binaries-linux | |
# - name: move binaries | |
# run: | | |
# chmod +x ./dassumego && mv ./dassumego /usr/local/bin/ | |
# chmod +x ./dgranted && mv ./dgranted /usr/local/bin/ | |
# chmod +x ./tbrowser && mv ./tbrowser /usr/local/bin/ | |
# chmod +x ./tcreds && mv ./tcreds /usr/local/bin/ | |
# chmod +x ./dassume && mv ./dassume /usr/local/bin/ | |
# chmod +x ./dassume.fish && mv ./dassume.fish /usr/local/bin/ | |
# - name: set default browser | |
# # configures granted to use the test browser binary | |
# run: dgranted browser set -b chrome -p /usr/local/bin/tbrowser | |
# - name: setup aws config files | |
# run: mkdir ~/.aws; touch ~/.aws/config; touch ~/.aws/credentials; | |
# - name: setup fake aws profile | |
# run: | | |
# cat << EOF >> ~/.aws/config | |
# [profile test] | |
# region = ${TEST_REGION} | |
# EOF | |
# - name: setup fake aws profile credentials | |
# run: | | |
# cat << EOF >> ~/.aws/credentials | |
# [test] | |
# aws_access_key_id=${TEST_ACCESS_KEY_ID} | |
# aws_secret_access_key=${TEST_ACCESS_KEY} | |
# EOF | |
# - name: bash | |
# run: dassume -auto-configure-shell | |
# # it seems not possible to reload the bash_profile in github actions here, so we will have to skip this test | |
# # the below does not work | |
# # - name: assume bash | |
# # run: | | |
# # source ~/.bash_profile | |
# # bash dassume test | |
# # ./bin/tcreds -aws-access-key-id $TEST_ACCESS_KEY_ID -aws-secret-key $TEST_ACCESS_KEY -aws-region $TEST_REGION | |
# # shell: bash | |
# - name: Install zsh | |
# run: sudo apt-get update; sudo apt-get install zsh | |
# - name: zsh | |
# run: dassume -auto-configure-shell | |
# shell: zsh {0} | |
# - name: assume zsh | |
# run: | | |
# dassume test | |
# tcreds -aws-access-key-id $TEST_ACCESS_KEY_ID -aws-secret-key $TEST_ACCESS_KEY -aws-region $TEST_REGION | |
# shell: zsh {0} | |
# - name: install fish | |
# run: sudo apt-add-repository ppa:fish-shell/release-3; sudo apt update; sudo apt install fish | |
# - name: fish | |
# run: SHELL=fish dassume -auto-configure-shell | |
# shell: fish {0} | |
# - name: assume zsh | |
# run: | | |
# SHELL=fish dassume test | |
# tcreds -aws-access-key-id $TEST_ACCESS_KEY_ID -aws-secret-key $TEST_ACCESS_KEY -aws-region $TEST_REGION | |
# shell: fish {0} | |
# osx-installs: | |
# needs: test | |
# name: Smoke Test (MacOS) | |
# runs-on: macos-11 | |
# env: | |
# TEST_ACCESS_KEY_ID: 1234578910abcdefghij | |
# TEST_ACCESS_KEY: 1234578910abcdefghijklmnopqrstuvwxyz1234 | |
# TEST_REGION: ap-southeast-2 | |
# steps: | |
# - uses: actions/download-artifact@v3 | |
# with: | |
# name: go-binaries-macos | |
# - name: move binaries | |
# run: | | |
# chmod +x ./dassumego && mv ./dassumego /usr/local/bin/ | |
# chmod +x ./dgranted && mv ./dgranted /usr/local/bin/ | |
# chmod +x ./tbrowser && mv ./tbrowser /usr/local/bin/ | |
# chmod +x ./tcreds && mv ./tcreds /usr/local/bin/ | |
# chmod +x ./dassume && mv ./dassume /usr/local/bin/ | |
# chmod +x ./dassume.fish && mv ./dassume.fish /usr/local/bin/ | |
# - name: set default browser | |
# # configures granted to use the test browser binary | |
# run: dgranted browser set -b chrome -p /usr/local/bin/tbrowser | |
# - name: setup aws config files | |
# run: mkdir ~/.aws; touch ~/.aws/config; touch ~/.aws/credentials; | |
# - name: setup fake aws profile | |
# run: | | |
# cat << EOF >> ~/.aws/config | |
# [profile test] | |
# region = ${TEST_REGION} | |
# EOF | |
# - name: setup fake aws profile credentials | |
# run: | | |
# cat << EOF >> ~/.aws/credentials | |
# [test] | |
# aws_access_key_id=${TEST_ACCESS_KEY_ID} | |
# aws_secret_access_key=${TEST_ACCESS_KEY} | |
# EOF | |
# - name: bash | |
# run: dassume -auto-configure-shell | |
# shell: bash {0} | |
# # bash doesn't work in github actions | |
# # - name: assume bash | |
# # run: | | |
# # dassume test | |
# # ./bin/tcreds -aws-access-key-id $TEST_ACCESS_KEY_ID -aws-secret-key $TEST_ACCESS_KEY -aws-region $TEST_REGION | |
# # shell: bash -l {0} | |
# - name: zsh | |
# run: dassume -auto-configure-shell | |
# shell: zsh {0} | |
# - name: assume zsh | |
# run: | | |
# dassume test | |
# /usr/local/bin/tcreds -aws-access-key-id $TEST_ACCESS_KEY_ID -aws-secret-key $TEST_ACCESS_KEY -aws-region $TEST_REGION | |
# shell: zsh {0} | |
# - name: install fish | |
# run: brew install fish | |
# - name: fish | |
# run: dassume -auto-configure-shell | |
# shell: fish {0} | |
# - name: assume fish | |
# run: | | |
# dassume test | |
# tcreds -aws-access-key-id $TEST_ACCESS_KEY_ID -aws-secret-key $TEST_ACCESS_KEY -aws-region $TEST_REGION | |
# shell: fish {0} |