Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cicd: Workflow updates (#2) #256

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
44 changes: 44 additions & 0 deletions .github/ISSUE_TEMPLATE/bug-report.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
name: 🐞 Bug
description: File a bug/issue
title: "[BUG] <title>"
labels: [bug]
body:
- type: checkboxes
attributes:
label: Is there an existing issue for this?
description: Please search to see if an issue already exists for the bug you encountered.
options:
- label: I have searched the existing issues
required: true
- type: textarea
attributes:
label: Current Behavior
description: A concise description of what you're experiencing.
validations:
required: true
- type: textarea
attributes:
label: Expected Behavior
description: A concise description of what you expected to happen.
validations:
required: true
- type: textarea
attributes:
label: Steps To Reproduce
description: Steps to reproduce the behavior.
placeholder: |
1. In this environment...
2. With this config...
3. Run '...'
4. See error...
validations:
required: true
- type: textarea
attributes:
label: Anything else?
description: |
Links? References? Anything that will give us more context about the issue you are encountering!

Tip: You can attach images or log files by clicking this area to highlight it and then dragging files in.
validations:
required: false
1 change: 1 addition & 0 deletions .github/ISSUE_TEMPLATE/config.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
blank_issues_enabled: false
29 changes: 29 additions & 0 deletions .github/ISSUE_TEMPLATE/feature-request.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
name: Feature Request
description: Suggest an idea for this project
title: "[FEATURE] <title>"
labels: 'enhancement'
body:
- type: textarea
attributes:
label: Describe the Feature
description: A concise description of what you're experiencing.
validations:
required: true
- type: textarea
attributes:
label: Use Case
description: Is your feature request related to a problem/challenge you are trying to solve? Please provide some additional context of why this feature or capability will be valuable.
validations:
required: true
- type: textarea
attributes:
label: Describe Ideal Solution
description: A clear and concise description of what you want to happen. If you don't know, that's okay.
validations:
required: false
- type: markdown
attributes:
value: |
## Community Note
* Please vote on this issue by adding a 👍 [reaction](https://blog.github.com/2016-03-10-add-reactions-to-pull-requests-issues-and-comments/) to the original issue to help the community and maintainers prioritize this request
* If you are interested in working on this issue or have submitted a pull request, please leave a comment
13 changes: 13 additions & 0 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
version: 2
updates:
# Maintain dependencies for GitHub Actions
- package-ecosystem: "github-actions"
directory: "/"
schedule:
interval: "daily"

# Maintain dependencies for docker
- package-ecosystem: "docker"
directory: "/"
schedule:
interval: "daily"
10 changes: 10 additions & 0 deletions .github/workflows/commit-issue.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
name: Commit Issue Commenter
on: push
jobs:
checkCommit:
name: Comment From Commit
runs-on: ubuntu-latest
steps:
- uses: adamzolyak/commit-issue-commenter-action@master
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
11 changes: 11 additions & 0 deletions .github/workflows/dependency-review.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
name: 'Dependency Review'
on: [pull_request]

jobs:
dependency-review:
runs-on: ubuntu-latest
steps:
- name: 'Checkout Repository'
uses: actions/checkout@v3
- name: 'Dependency Review'
uses: actions/dependency-review-action@v2
19 changes: 19 additions & 0 deletions .github/workflows/docker-pr-clean-up.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
name: 'Docker PR Clean Up'

on:
pull_request:
types: [closed]

jobs:
purge-image:
name: Delete image from ghcr.io
runs-on: ubuntu-latest
steps:
- name: Prune
uses: vlaurin/action-ghcr-prune@main
with:
token: ${{ secrets.ACTIONS_TOKEN }}
container: ${{ github.event.repository.name }}
dry-run: false
tag-regex: pr-${{github.event.pull_request.number}}
untagged: true
68 changes: 68 additions & 0 deletions .github/workflows/docker.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
name: Docker Build and Publish

on:
push:
branches:
- 'master'
tags:
- 'v*'
pull_request:
branches:
- master

jobs:
docker:
runs-on: ubuntu-latest
steps:
-
name: Checkout
uses: actions/checkout@v3
-
name: Docker meta
id: meta
uses: docker/metadata-action@v4
with:
# list of Docker images to use as base name for tags
images: |
${{ github.repository }}
ghcr.io/${{ github.repository }}
# generate Docker tags based on the following events/attributes
tags: |
type=ref,event=pr
type=semver,pattern=v{{version}}
type=semver,pattern=v{{major}}.{{minor}}
type=semver,pattern=v{{major}}
type=edge,branch=main
-
name: Set up QEMU
uses: docker/setup-qemu-action@v2
-
name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
-
name: Login to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
-
name: Login to DockerHub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
-
name: Build and push
uses: docker/build-push-action@v3
with:
context: .
# Due to build time, only building the one currently needed.
# If needed, we can add more platforms when requested.
platforms: "linux/amd64"
# Do not push pull requests
#push: ${{ github.event_name != 'pull_request' }}
# Push pull requests so they can be tested
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
10 changes: 6 additions & 4 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
name: Publish former2.com
name: Publish Former2 to S3

on:
push:
branches: [ master ]
tags:
- 'v*'

jobs:
deploy:
Expand All @@ -20,6 +21,7 @@ jobs:
aws-secret-access-key: ${{ secrets.FORMER2_AWS_SECRET_ACCESS_KEY }}
aws-region: us-east-1

- name: Copy files to origin S3 bucket
- name: Sync files to origin S3 bucket
run: |
aws s3 cp --cache-control max-age=300 --recursive . s3://former2.com/ --exclude ".git/*" --exclude "cli/*" --exclude ".*" --exclude "notes.txt" --exclude "*.md" --exclude "Dockerfile" --exclude "LICENSE" --exclude "*.yml" --exclude ".gitignore" --exclude "util/*" --exclude "lib/*"
aws s3 sync --delete --cache-control max-age=300 . s3://${{ secrets.FORMER2_AWS_S3_BUCKET }}/ --exclude ".git/*" --exclude "cli/*" --exclude ".*" --exclude "notes.txt" --exclude "*.md" --exclude "Dockerfile" --exclude "LICENSE" --exclude "*.yml" --exclude ".gitignore" --exclude "util/*" --exclude "lib/*" && \
aws cloudfront create-invalidation --distribution-id ${{ secrets.FORMER2_AWS_CLOUDFRONT_DISTRIBUTION_ID }} --paths "/*"
70 changes: 70 additions & 0 deletions .github/workflows/release-please-branches.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
name: Create Releases From Branches

on:
push:
branches:
# See https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#filter-pattern-cheat-sheet
- releases/v[0-9]+
jobs:
create-release:
runs-on: ubuntu-latest
steps:
- name: Extract branch name
shell: bash
run: echo "##[set-output name=branch;]${GITHUB_REF#refs/heads/}"
id: extract_branch

- uses: GoogleCloudPlatform/[email protected]
id: release
with:
release-type: simple
default-branch: ${{ steps.extract_branch.outputs.branch }}
token: "${{ secrets.ACTIONS_TOKEN }}"

- uses: actions/checkout@v2
with:
fetch-depth: '0'

- name: Tag major and patch versions
if: ${{ steps.release.outputs.release_created }}
run: |
git config user.name github-actions[bot]
git config user.email 41898282+github-actions[bot]@users.noreply.github.com
git remote add gh-token "https://${{ secrets.ACTIONS_TOKEN}}@github.com/google-github-actions/release-please-action.git"
git tag -d v${{ steps.release.outputs.major }} || true
git tag -d v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }} || true
git push origin :v${{ steps.release.outputs.major }} || true
git push origin :v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }} || true
git tag -a v${{ steps.release.outputs.major }} -m "Release v${{ steps.release.outputs.major }}"
git tag -a v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }} -m "Release v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }}"
git push origin v${{ steps.release.outputs.major }}
git push origin v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }}

- name: Recreate latest tags for release ordering
if: ${{ steps.release.outputs.release_created }}
id: recreate-latest-tags
run: |
git fetch -avtf
LATEST="$(git tag -l|tail -1)"
LATEST_MAJOR="$(git tag -l|tail -1|awk -F"." '{print $1}')"
LATEST_MINOR="$(git tag -l|tail -1|awk -F"." '{print $1"."$2}')"
git checkout main
git tag -d "${LATEST}"
git tag -d "${LATEST_MAJOR}"
git tag -d "${LATEST_MINOR}"
git push origin :"${LATEST}"
git push origin :"${LATEST_MAJOR}"
git push origin :"${LATEST_MINOR}"
git tag -a "${LATEST}" -m "Release ${LATEST}"
git tag -a "${LATEST_MAJOR}" -m "Release ${LATEST_MAJOR}"
git tag -a "${LATEST_MINOR}" -m "Release ${LATEST_MINOR}"
git push origin "${LATEST}"
git push origin "${LATEST_MAJOR}"
git push origin "${LATEST_MINOR}"
echo "::set-output name=LATEST_RELEASE::${LATEST}"

- name: Publish release on GitHub
if: ${{ steps.release.outputs.release_created }}
uses: test-room-7/action-publish-release-drafts@v0
with:
tag-name: ${{ steps.recreate-latest-tags.outputs.LATEST_RELEASE }}
40 changes: 40 additions & 0 deletions .github/workflows/release-please.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
name: Create Releases From Default Branch

on:
push:
branches:
- master
jobs:
create-release:
runs-on: ubuntu-latest
steps:
- uses: GoogleCloudPlatform/[email protected]
id: release
with:
token: "${{ secrets.ACTIONS_TOKEN }}"
release-type: simple

- uses: actions/checkout@v2

- name: Create major branch and tag also patch tag versions
if: ${{ steps.release.outputs.release_created }}
run: |
git config user.name github-actions[bot]
git config user.email 41898282+github-actions[bot]@users.noreply.github.com
git remote add gh-token "https://${{ secrets.ACTIONS_TOKEN}}@github.com/google-github-actions/release-please-action.git"
git tag -d v${{ steps.release.outputs.major }} || true
git tag -d v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }} || true
git push origin :v${{ steps.release.outputs.major }} || true
git push origin :v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }} || true
git tag -a v${{ steps.release.outputs.major }} -m "Release v${{ steps.release.outputs.major }}"
git tag -a v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }} -m "Release v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }}"
git push origin v${{ steps.release.outputs.major }}
git push origin v${{ steps.release.outputs.major }}.${{ steps.release.outputs.minor }}
OLD_MAJOR="$( echo ${{ steps.release.outputs.major }} - 1 | bc )"
if ! git branch -r | grep "releases/v${OLD_MAJOR}"; then
git fetch -avt
if git tag -l | grep -x "^v${OLD_MAJOR}"; then
git branch releases/v${OLD_MAJOR} v${OLD_MAJOR}
git push origin releases/v${OLD_MAJOR}
fi
fi