Skip to content

Try pigz in actions/cache #557

Try pigz in actions/cache

Try pigz in actions/cache #557

Workflow file for this run

name: deploy bot stack
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
on:
push:
branches: [main]
pull_request:
types: [opened, reopened, synchronize, ready_for_review]
jobs:
deploy:
name: Deploy Stack
runs-on: ubuntu-latest
container: swift:6.0-jammy
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Restore .build
if: ${{ !(github.run_attempt > 1) }} # Because maybe the cache is causing issues
id: "restore-cache"
uses: mahdibm/cache/restore@mmbm-pigz
with:
path: .build
key: "penny-release-static-build-${{ runner.os }}-${{ github.event.after }}"
restore-keys: "penny-release-static-build-${{ runner.os }}-"
- name: Build Penny
run: |
apt-get update -y
apt-get install -y libjemalloc-dev
swift build \
--product Penny \
-c release \
--force-resolved-versions \
--static-swift-stdlib \
-Xlinker -ljemalloc
- name: Cache .build
if: steps.restore-cache.outputs.cache-hit != 'true'
uses: mahdibm/cache/save@mmbm-pigz
with:
path: .build
key: "penny-release-static-build-${{ runner.os }}-${{ github.event.after }}"
# - name: Install Docker
# run: |
# # Make scripts executable
# chmod +x ./.github/scripts/*
# # Install Docker
# ./.github/scripts/install-docker.bash
# - name: Configure AWS credentials
# uses: aws-actions/configure-aws-credentials@v4
# with:
# aws-access-key-id: ${{ secrets.DEPLOYER_ACCESS_KEY_ID }}
# aws-secret-access-key: ${{ secrets.DEPLOYER_ACCESS_SECRET_KEY }}
# aws-region: "eu-west-1"
# - name: Login to Amazon ECR
# id: login-ecr
# uses: aws-actions/amazon-ecr-login@v2
# - name: Build, tag, and push image to Amazon ECR
# id: build-image
# env:
# ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }}
# ECR_REPOSITORY: penny-bot-discord-image
# IMAGE_TAG: ${{ github.sha }}
# run: |
# # Build a docker container and
# # push it to ECR so that it can
# # be deployed to ECS.
# docker build -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG -f Dockerfile . \
# --build-arg SWIFT_CONFIGURATION=release \
# --build-arg EXEC_NAME=Penny
# docker push $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG
# echo "image=$ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG" >> $GITHUB_OUTPUT
# - name: Fill in the new image ID in the Amazon ECS task definition
# id: task-def
# uses: aws-actions/amazon-ecs-render-task-definition@v1
# with:
# task-definition: ./deploy/penny-discord-bot-task.json
# container-name: penny-bot
# image: ${{ steps.build-image.outputs.image }}
# - name: Deploy to Amazon ECS Service
# id: task-dep
# uses: aws-actions/amazon-ecs-deploy-task-definition@v2
# with:
# task-definition: ${{ steps.task-def.outputs.task-definition }}
# wait-for-service-stability: true
# - name: Deploy to AWS cloudformation
# uses: aws-actions/aws-cloudformation-github-deploy@v1
# with:
# name: penny-discord-bot-stack
# template: ./deploy/penny-discord-bot-stack.yml
# no-fail-on-empty-changeset: "1"
# parameter-overrides: >-
# TaskDefinition=${{ steps.task-dep.outputs.task-definition-arn }}