Skip to content

Commit

Permalink
Release branch mech
Browse files Browse the repository at this point in the history
  • Loading branch information
ruuushhh committed Jun 7, 2024
1 parent 912a0ff commit 79b4634
Show file tree
Hide file tree
Showing 4 changed files with 102 additions and 3 deletions.
2 changes: 1 addition & 1 deletion .flake8
Original file line number Diff line number Diff line change
Expand Up @@ -28,4 +28,4 @@ max-line-length = 99
max-complexity = 19
ban-relative-imports = true
select = B,C,E,F,N,W,I25
exclude=*env,*.sql,*.txt,*.sh,.flake8,*.yml
exclude=*env,*.sql,*.txt,*.sh,.flake8,*.yml,*.yaml
41 changes: 41 additions & 0 deletions .github/workflows/create_release_branch.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
name: Create Release Branch
on:
schedule:
# Run every Friday at 11:30 AM UTC (5:00 PM IST)
- cron: '30 11 * * FRI'
jobs:
create-release-branch:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
with:
ref: master
- name: Get Release Branch Name
run: |
echo "release_branch=qbo_api_release_$(date +%Y_%m_%d)" >> $GITHUB_ENV
echo "last_release_branch=qbo_api_release_$(date -d 'last friday' +%Y_%m_%d)" >> $GITHUB_ENV
- name: Check if release branch exists
run: |
if git ls-remote --exit-code --heads origin ${{env.release_branch}}; then
echo "branch_exists=true" >> $GITHUB_ENV
else
echo "branch_exists=false" >> $GITHUB_ENV
fi
- name: Create release branch
if: ${{env.branch_exists == 'false'}}
run: |
git checkout -b ${{env.release_branch}}
git push origin ${{env.release_branch}}
echo "message=Branch `${{env.release_branch}}` created successfully." >> $GITHUB_ENV
- name: Branch already exists
if: ${{env.branch_exists == 'true'}}
run: echo "message=Branch `${{env.release_branch}}` already exists." >> $GITHUB_ENV
- name: Send message on Slack
uses: archive/[email protected]
id: notify
with:
# Send message to #integrations slack channel
slack-bot-user-oauth-access-token: ${{ secrets.SLACK_BOT_INTEGRATIONS_OAUTH_ACCESS_TOKEN }}
slack-channel: C074E8V8EL8
slack-text: "${{env.message}} \nCheck diff here: https://github.com/fylein/fyle-qbo-api/compare/${{env.last_release_branch}}...${{env.release_branch}}"
57 changes: 57 additions & 0 deletions .github/workflows/hulk_deployment.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
name: Deploy to Hulk

on:
create:
branches:
- 'qbo_api_release_*'
push:
branches:
- 'qbo_api_release_*'

jobs:
hulk_deploy:
runs-on: ubuntu-latest
environment: Staging
steps:
- uses: actions/checkout@v2
with:
submodules: recursive
- name: Push to dockerhub
uses: fylein/docker-release-action@master
id: generate-and-push-tag
env:
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_TOKEN }}
IMAGE_NAME: fyle_qbo-api

- name: Install kustomize
run: |
curl -s "https://raw.githubusercontent.com/kubernetes-sigs/kustomize/master/hack/install_kustomize.sh" | bash
sudo mv kustomize /usr/local/bin/
- name: Clone another repository
uses: actions/checkout@v2
with:
repository: ${{ vars.STAGING_DEPLOY_REPO }}
ref: master
path: ${{ vars.STAGING_DEPLOY_REPO }}
persist-credentials: false
token: ${{ secrets.DEPLOY_GIT_ACCESS_TOKEN }}

- name: Update Image Tag
run: |
NEW_TAG=${{ steps.generate-and-push-tag.outputs.new_tag }}
cd ${{ vars.STAGING_DEPLOY_REPO }}/${{ vars.STAGING_DEPLOY_DIR }}/hulk/integrations
kustomize edit set image docker.io/${{ secrets.DOCKERHUB_USERNAME }}/fyle_qbo-api=docker.io/${{ secrets.DOCKERHUB_USERNAME }}/fyle_qbo-api:$NEW_TAG
- name: Commit and push changes
run: |
NEW_TAG=${{ steps.generate-and-push-tag.outputs.new_tag }}
cd ${{ vars.STAGING_DEPLOY_REPO }}
git config --global user.email "[email protected]"
git config --global user.name "GitHub Actions"
git add .
git commit -m "Deployed fyle_qbo-api:$NEW_TAG to hulk"
git remote set-url origin https://x-access-token:${{ secrets.DEPLOY_GIT_ACCESS_TOKEN }}@github.com/${{ vars.STAGING_DEPLOY_REPO }}
git pull origin master
git push origin master
5 changes: 3 additions & 2 deletions .github/workflows/production_deployment.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ jobs:
submodules: recursive
- name: push to dockerhub
uses: fylein/docker-release-action@master
id: generate-and-push-tag
env:
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }}
DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_TOKEN }}
Expand All @@ -35,7 +36,7 @@ jobs:

- name: Update Image Tag
run: |
NEW_TAG="v$(git rev-parse --short HEAD)"
NEW_TAG=${{ steps.generate-and-push-tag.outputs.new_tag }}
cd ${{ vars.PROD_DEPLOY_REPO }}/${{ vars.PROD_US1_DEPLOY_DIR }}/integrations
kustomize edit set image docker.io/${{ secrets.DOCKERHUB_USERNAME }}/fyle_qbo-api=docker.io/${{ secrets.DOCKERHUB_USERNAME }}/fyle_qbo-api:$NEW_TAG
Expand All @@ -49,7 +50,7 @@ jobs:
git config --global user.email "[email protected]"
git config --global user.name "GitHub Actions"
git add .
git commit -m "Update qbo-api image tag"
git commit -m "Deployed fyle_qbo-api:$NEW_TAG to prod"
git remote set-url origin https://x-access-token:${{ secrets.DEPLOY_GIT_ACCESS_TOKEN }}@github.com/${{ vars.PROD_DEPLOY_REPO }}
git pull origin master
git push origin master
Expand Down

0 comments on commit 79b4634

Please sign in to comment.