Skip to content

[GR-76196] github worflow hardening #10

[GR-76196] github worflow hardening

[GR-76196] github worflow hardening #10

Workflow file for this run

name: Build and deploy website
on:
pull_request:
paths:
- 'docs/site/**'
- '.github/workflows/build-website.yml'
push:
branches:
- master
paths:
- 'docs/site/**'
- '.github/workflows/build-website.yml'
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# 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
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Check out repository
uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
- name: Set up Ruby
uses: ruby/setup-ruby@afeafc3d1ab54a631816aba4c914a0081c12ff2f # v1.310.0
with:
ruby-version: '3.2'
- name: Install website dependencies
working-directory: docs/site
run: bundle install
- name: Build website
working-directory: docs/site
env:
JEKYLL_ENV: production
run: bundle exec jekyll build
- name: Upload artifact
uses: actions/upload-pages-artifact@fc324d3547104276b827a68afc52ff2a11cc49c9 # v5.0.0
with:
path: docs/site/_site
deploy:
# The website should only be deployed from a release branch:
# if: startsWith(github.head_ref, 'release/graal-vm/')
if: github.event_name == 'push' && github.ref == 'refs/heads/master'
runs-on: ubuntu-latest
needs: build
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@cd2ce8fcbc39b97be8ca5fce6e763baed58fa128 # v5.0.0