From b212241016d3c265494840fb3efb18eb55239f79 Mon Sep 17 00:00:00 2001
From: weru <onewesh@gmail.com>
Date: Tue, 06 Oct 2020 14:17:34 +0000
Subject: [PATCH] add workflow

---
 .github/workflows/ci.yaml |   72 ++++++++++++++++++++++++++++++++++++
 1 files changed, 72 insertions(+), 0 deletions(-)

diff --git a/.github/workflows/ci.yaml b/.github/workflows/ci.yaml
new file mode 100644
index 0000000..a56784b
--- /dev/null
+++ b/.github/workflows/ci.yaml
@@ -0,0 +1,72 @@
+name: DeployCI
+on:
+  push:
+    branches:
+    - master
+  pull_request:
+    branches:
+    - master
+
+jobs:
+  build:
+  # In this phase, the code is pulled from master and the site rendered in Hugo. The built site is stored as an artifact for other stages.
+    runs-on: ubuntu-latest
+    steps:
+    # Check out master branch from the repo.
+    - name: Checkout master branch
+      uses: actions/checkout@v2
+
+    - name: Build site with Hugo
+      uses: onweru/build-hugo@v0.75.1
+
+    # If build succeeds, store the public/ dir as an artifact to be used in subsequent phases.
+    - name: Upload output public dir as artifact
+      uses: actions/upload-artifact@v1
+      with:
+        name: public
+        path: exampleSite/public/
+  publish:
+  # In the publish phase, the site is pushed up to a different branch which only stores the exampleSite/public/ folder ("example" branch)
+    runs-on: ubuntu-latest
+    needs: build
+    steps:
+    # Check out the example branch this time since we have to ultimately commit those changes there.
+    - name: Checkout example branch
+      uses: actions/checkout@v2
+      with:
+        submodules: false
+        fetch-depth: 0
+        ref: ${{ env.SITE-BRANCH }}
+    # Download the artifact containing the newly built site. This overwrites the public/ dir from the check out above.
+    - name: Download artifact from build stage
+      uses: actions/download-artifact@v1
+      with:
+        name: public
+    # Add all the files/changes in public/ that were pulled down from the build stage and then commit them.
+    # The final line sets a GitHub Action output value that can be read by other steps.
+    # This function cannot store mult-line values so newline chars must be stripped.
+    - name: Commit files
+      id: can_commit
+      run: |
+        git config --local user.email "action@github.com"
+        git config --local user.name "GitHub Action"
+        git checkout -b example
+        git rm -rf .
+        mv --force exampleSite/public/* .
+        git add .
+        commit_message=$(git commit -m "Publish generated Hugo site." -a | tr -d '\n' || true)
+        echo "::set-output name=commit_message::$commit_message"
+    # Checks if previous stage had any valid commit.
+    - name: Nothing to commit
+      id: nothing_committed
+      if: contains(steps.can_commit.outputs.commit_message, 'nothing to commit')
+      run: echo "Saw that no changes were made to Hugo site."
+
+    # Push those changes back to the site branch.
+    - name: Push to example branch
+      if: steps.nothing_committed.conclusion == 'skipped'
+      uses: ad-m/github-push-action@master
+      with:
+        github_token: ${{ secrets.GITHUB_TOKEN }}
+        branch: example
+        force: true

--
Gitblit v1.10.0