Merge pull request #22 from IONOS-WordPress/dependabot/npm_and_yarn/p… #16
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Updates the gh-pages branch to contain the current trunk | |
on: | |
push: | |
branches: | |
- trunk | |
permissions: | |
contents: write | |
jobs: | |
build-and-deploy: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repository | |
uses: actions/checkout@v4 | |
with: | |
submodules: 'true' | |
- name: Set up Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version: 'lts/*' | |
- name: Set up pnpm | |
uses: pnpm/action-setup@v4 | |
with: | |
version: 9.10.0 | |
run_install: | | |
- recursive: true | |
cwd: . | |
args: [--frozen-lockfile, --strict-peer-dependencies] | |
- name: Setting up GITHUB_ENV for later steps | |
run: | | |
TARGET_DIR="trunk" | |
TARGET_HOST=${GITHUB_REPOSITORY%%/*}/${GITHUB_REPOSITORY##*/} | |
echo "TARGET_DIR=$TARGET_DIR" >> $GITHUB_ENV | |
echo "TARGET_HOST=$TARGET_HOST" >> $GITHUB_ENV | |
- name: Set up Git credentials and ensure gh-pages branch exists | |
run: | | |
# Configure the bot's name and email and | |
git config --global user.name "github-actions[bot]" | |
git config --global user.email "github-actions[bot]@users.noreply.github.com" | |
# Ensure that a gh-pages branch exists and push it to the remote | |
# HACK: since refs are not properly updated, we have to fetch the refs first | |
# and then check if the gh-pages branch exists | |
echo "Updating refs" | |
git fetch > /dev/null 2>&1 | |
ref=$(git show-ref | grep "gh-pages") || true | |
if [ -z "$ref" ]; then | |
echo "Creating gh-pages branch" | |
BASE_BRANCH=$(git branch --show-current) | |
git checkout --orphan gh-pages | |
git reset --hard | |
git commit --allow-empty -m "Initial commit" | |
git push origin gh-pages | |
git checkout $BASE_BRANCH | |
git branch -D gh-pages | |
fi | |
- name: Clone the gh-pages branch | |
run: | | |
# this will create a gh-pages directory with the content of the gh-pages branch. this makes it easier to work | |
# with the gh-pages branch instead of having to switch branches all the time | |
git clone --single-branch --branch gh-pages https://${{ github.actor }}:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }} gh-pages | |
- name: Preparing Folders for Deployment | |
run: | | |
# this will create the target directory if it does not exist | |
# and ensure that it is empty | |
printf "%s\n" "Creating gh-pages/$TARGET_DIR" | |
rm -rf gh-pages/$TARGET_DIR | |
mkdir -p "gh-pages/$TARGET_DIR" | |
- name: Prepare Branch for Deployment | |
run: | | |
# this whould be to much work to do in a single step. | |
# please refer th scripts/playground.sh for more details | |
# this script will build and zip all Plugins for deployment | |
# it will also create a playground for the trunk | |
./scripts/playground.sh $TARGET_HOST | |
- name: Copy dist folder to gh-pages/trunk | |
run: | | |
# Move all Files from dist to gh-pages/trunk and commit the changes | |
# HACK: The mv command does not work as expected, so we have to use the dirname command | |
echo "copying dist/$TARGET_DIR to gh-pages/$TARGET_DIR" | |
mv dist/$TARGET_DIR $(dirname gh-pages/$TARGET_DIR) | |
- name: Commit and push changes | |
run: | | |
# Adding changes to git | |
cd gh-pages | |
git add . | |
git commit -m "Deploying state of PR ${{ github.pr_number}} from ${{ github.head_ref}}" | |
git push origin gh-pages --force | |