aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPinapelz <yukais@pinapelz.com>2023-09-13 00:52:46 -0700
committerPinapelz <yukais@pinapelz.com>2023-09-13 00:52:46 -0700
commit236b2804d2868811d2acf72e48e52c7f43ab1c8e (patch)
treeb44176120a6d38c6809c41d9cf0a186d79a7fcb4
parent9d03f81a34b34166b24d7da4b311d538a52a9e1b (diff)
fix build yml
-rw-r--r--.github/workflows/deploy.yml81
1 files changed, 65 insertions, 16 deletions
diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml
index da0391d..1715cff 100644
--- a/.github/workflows/deploy.yml
+++ b/.github/workflows/deploy.yml
@@ -1,39 +1,88 @@
-name: Deploy to GitHub Pages
+# Sample workflow for building and deploying an Astro site to GitHub Pages
+#
+# To get started with Astro see: https://docs.astro.build/en/getting-started/
+#
+name: Deploy Astro site to Pages
on:
- # Trigger the workflow every time you push to the `main` branch
- # Using a different branch name? Replace `main` with your branch’s name
+ # Runs on pushes targeting the default branch
push:
- branches: [ master ]
- # Allows you to run this workflow manually from the Actions tab on GitHub.
+ branches: ["master"]
+
+ # Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
-# Allow this job to clone the repo and create a page deployment
+# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: read
pages: write
id-token: write
+# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
+# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
+concurrency:
+ group: "pages"
+ cancel-in-progress: false
+
+env:
+ BUILD_PATH: "." # default value when not using subfolders
+ # BUILD_PATH: subfolder
+
jobs:
build:
+ name: Build
runs-on: ubuntu-latest
steps:
- - name: Checkout your repository using git
+ - name: Checkout
uses: actions/checkout@v3
- - name: Install, build, and upload your site
- uses: withastro/action@v0
- # with:
- # path: . # The root location of your Astro project inside the repository. (optional)
- # node-version: 16 # The specific version of Node that should be used to build your site. Defaults to 16. (optional)
- # package-manager: yarn # The Node package manager that should be used to install dependencies and build your site. Automatically detected based on your lockfile. (optional)
+ - name: Detect package manager
+ id: detect-package-manager
+ run: |
+ if [ -f "${{ github.workspace }}/yarn.lock" ]; then
+ echo "manager=yarn" >> $GITHUB_OUTPUT
+ echo "command=install" >> $GITHUB_OUTPUT
+ echo "runner=yarn" >> $GITHUB_OUTPUT
+ exit 0
+ elif [ -f "${{ github.workspace }}/package.json" ]; then
+ echo "manager=npm" >> $GITHUB_OUTPUT
+ echo "command=ci" >> $GITHUB_OUTPUT
+ echo "runner=npx --no-install" >> $GITHUB_OUTPUT
+ exit 0
+ else
+ echo "Unable to determine package manager"
+ exit 1
+ fi
+ - name: Setup Node
+ uses: actions/setup-node@v3
+ with:
+ node-version: "19"
+ cache: ${{ steps.detect-package-manager.outputs.manager }}
+ cache-dependency-path: ${{ env.BUILD_PATH }}/package-lock.json
+ - name: Setup Pages
+ id: pages
+ uses: actions/configure-pages@v3
+ - name: Install dependencies
+ run: ${{ steps.detect-package-manager.outputs.manager }} ${{ steps.detect-package-manager.outputs.command }}
+ working-directory: ${{ env.BUILD_PATH }}
+ - name: Build with Astro
+ run: |
+ ${{ steps.detect-package-manager.outputs.runner }} astro build \
+ --site "${{ steps.pages.outputs.origin }}" \
+ --base "${{ steps.pages.outputs.base_path }}"
+ working-directory: ${{ env.BUILD_PATH }}
+ - name: Upload artifact
+ uses: actions/upload-pages-artifact@v2
+ with:
+ path: ${{ env.BUILD_PATH }}/dist
deploy:
- needs: build
- runs-on: ubuntu-latest
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
+ needs: build
+ runs-on: ubuntu-latest
+ name: Deploy
steps:
- name: Deploy to GitHub Pages
id: deployment
- uses: actions/deploy-pages@v1 \ No newline at end of file
+ uses: actions/deploy-pages@v2
send patches to the email below
yukais@pinapelz.com
include the subject [PATCH repo_name]
pinapelz.com
homepage