jjb: efficios-www: move to deb12 builders
authorMichael Jeanson <mjeanson@efficios.com>
Tue, 15 Aug 2023 15:18:40 +0000 (11:18 -0400)
committerMichael Jeanson <mjeanson@efficios.com>
Tue, 15 Aug 2023 15:46:38 +0000 (11:46 -0400)
Change-Id: I39043ae45b5645ac798dce6184812418fe9687d1
Signed-off-by: Michael Jeanson <mjeanson@efficios.com>
jobs/efficios-www.yaml
scripts/efficios-www/deploy.sh

index 19cd30a1d5b2dbd0375549c51e193dd528aa1c9c..f4ab347c6eb0dc2b3242f163847d7fc566855240 100644 (file)
@@ -2,7 +2,7 @@
     name: efficios-www
     project-type: freestyle
     defaults: global
-    node: amd64-rootnode-jammy
+    node: amd64-rootnode
 
     description: |
       This job is responsible for updating the efficios website.
@@ -21,6 +21,7 @@
         - file:
             credential-id: d023f830-9ab0-409f-b977-8cd0e1944dd5
             variable: HOST_PUBLIC_KEYS
+
     properties:
       - build-discarder:
           num-to-keep: 5
     triggers:
       - pollscm:
           cron: "@hourly"
+
     builders:
       - shell:
           !include-raw: scripts/efficios-www/deploy.sh
 
     scm:
-      - efficios-www
+      - git:
+          url: git@git.internal.efficios.com:efficios/efficios-www.git
+          credentials-id: f3c907b6-7485-49e1-afe1-4df24fac4ca1
+          basedir: ./
+          skip-tag: true
+          branches:
+            - master
 
     publishers:
+      - archive:
+          artifacts: 'site/**,prod/**'
+          follow-symlinks: true
+          allow-empty: false
       - ircbot:
           strategy: statechange-only
           message-type: summary
           matrix-trigger: only-parent
           send-to:
             - recipients
-
-- scm:
-    name: efficios-www
-    scm:
-      - git:
-          url: git@git.internal.efficios.com:efficios/efficios-www.git
-          credentials-id: f3c907b6-7485-49e1-afe1-4df24fac4ca1
-          basedir: ./
-          skip-tag: true
-          branches:
-            - master
index f1c22d9b6cd737e60c0d5852fabb9c3aa274221c..9f0fb1386b35002f10c4b500690533812f0ee373 100644 (file)
 
 set -exu
 
+print_header() {
+    set +x
+
+    local message=" $1 "
+    local message_len
+    local padding_len
+
+    message_len="${#message}"
+    padding_len=$(( (80 - (message_len)) / 2 ))
+
+    printf '\n'; printf -- '#%.0s' {1..80}; printf '\n'
+    printf -- '-%.0s' {1..80}; printf '\n'
+    printf -- '#%.0s' $(seq 1 $padding_len); printf '%s' "$message"; printf -- '#%.0s' $(seq 1 $padding_len); printf '\n'
+    printf -- '-%.0s' {1..80}; printf '\n'
+    printf -- '#%.0s' {1..80}; printf '\n\n'
+
+    set -x
+}
+
 # Add ssh key for deployment
 cp "$HOST_PUBLIC_KEYS" ~/.ssh/known_hosts
 cp "$KEY_FILE_VARIABLE" ~/.ssh/id_rsa
 
+export DEBIAN_FRONTEND=noninteractive
 apt-get update
 
-# Nodejs
+print_header "Install web tooling dependencies"
 apt-get install --no-install-recommends -y npm
 ./bootstrap-ubuntu.sh
+
+print_header "Install NPM stuff"
 npm install
 
+print_header "Build website with grunt"
 grunt build:dev --verbose
 grunt deploy:pre --verbose
 
 grunt build:prod --verbose
 
 # Check for broken internal links
+print_header "Check links"
 apt-get install -y linkchecker
 grunt connect:prod watch:prod &
 SERVER_PID="${!}"
 sleep 10 # While serve:prod starts up
-OUTPUT_FILE="$(mktemp -d)/linkchecker-out.csv"
+
+OUTPUT_DIR="$(mktemp -d)"
+OUTPUT_FILE="${OUTPUT_DIR}/linkchecker-out.csv"
+
 # linkchecker drops privileges to 'nobody' when run as root
-chown nobody "$(dirname "${OUTPUT_FILE}")"
+chown nobody "${OUTPUT_DIR}"
+
 # @Note: Only internal links are checked by default
 if ! linkchecker -q -F "csv/utf-8/${OUTPUT_FILE}" http://localhost:10000/ ; then
     echo "Linkchecker failed or found broken links"
     cat "${OUTPUT_FILE}"
     kill "${SERVER_PID}"
-    rm -rf "${OUTPUT_FILE}/.."
+    rm -rf "${OUTPUT_DIR}"
     sleep 5 # Let serve:prod stop
     exit 1
 else
-    rm -rf "${OUTPUT_FILE}/.."
+    rm -rf "${OUTPUT_DIR}"
     kill "${SERVER_PID}"
 fi
 
+print_header "Deploy website"
 grunt deploy:prod --verbose
 # EOF
This page took 0.035603 seconds and 4 git commands to generate.