launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-1b-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-1b-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
./hypervisorDescription: 'QEMU+ssh - ci-host-amd64-1b.internal.efficios.com'
./virtualMachineName: 'ci-rootnode-deb12-amd64-1b-01'
launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-1c-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-1c-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
snapshotName: ''
beforeJobSnapshotName: 'base-configuration'
launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-1d-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-1d-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
./hypervisorDescription: 'QEMU+ssh - ci-host-amd64-1d.internal.efficios.com'
./virtualMachineName: 'ci-rootnode-deb12-amd64-1d-01'
launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-2a-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-2a-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
./hypervisorDescription: 'QEMU+ssh - ci-host-amd64-2a.internal.efficios.com'
./virtualMachineName: 'ci-rootnode-deb12-amd64-2a-01'
launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-2b-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-2b-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
./hypervisorDescription: 'QEMU+ssh - ci-host-amd64-2b.internal.efficios.com'
./virtualMachineName: 'ci-rootnode-deb12-amd64-2b-01'
launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-2c-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-2c-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
./hypervisorDescription: 'QEMU+ssh - ci-host-amd64-2c.internal.efficios.com'
./virtualMachineName: 'ci-rootnode-deb12-amd64-2c-01'
launcher/virtualMachineName: 'ci-rootnode-deb12-amd64-2d-01'
launcher/delegate: 'hudson.plugins.sshslaves.SSHLauncher=class'
launcher/delegate/port: '22'
- launcher/delegate/host: 'ci-rootnode-deb12-amd64-1a-01.internal.efficios.com'
+ launcher/delegate/host: 'ci-rootnode-deb12-amd64-2d-01.internal.efficios.com'
launcher/delegate/credentialsId: 'bb5a81cf-346b-43fc-8586-3dc5e43801be'
./hypervisorDescription: 'QEMU+ssh - ci-host-amd64-2d.internal.efficios.com'
./virtualMachineName: 'ci-rootnode-deb12-amd64-2d-01'
- file:
credential-id: d023f830-9ab0-409f-b977-8cd0e1944dd5
variable: HOST_PUBLIC_KEYS
+
properties:
- build-discarder:
num-to-keep: 5
triggers:
- timed: '@daily'
+
builders:
- shell:
!include-raw: scripts/babeltrace-www/deploy.sh
scm:
- - babeltrace-www
+ - git:
+ url: https://git.internal.efficios.com/efficios/bt2-www.git
+ 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: babeltrace-www
- scm:
- - git:
- url: https://git.internal.efficios.com/efficios/bt2-www.git
- basedir: ./
- skip-tag: true
- branches:
- - master
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.
- 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
name: lttng-www
project-type: freestyle
defaults: global
- node: amd64-rootnode-jammy
+ node: amd64-rootnode
description: |
This job is responsible for updating the lttng website.
!include-raw: scripts/lttng-www/deploy.sh
scm:
- - lttng-www
+ - git:
+ url: git@git.efficios.com:lttng-www.git
+ credentials-id: 63a5abb5-9056-47e2-b419-f5946c1b8f08
+ 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: lttng-www
- scm:
- - git:
- url: git@git.efficios.com:lttng-www.git
- credentials-id: 63a5abb5-9056-47e2-b419-f5946c1b8f08
- basedir: ./
- skip-tag: true
- branches:
- - master
-
# shellcheck disable=SC2103
#
# Copyright (C) 2021 Jonathan Rajotte-Julien <jonathan.rajotte-julien@efficios.com>
+# 2023 Michael Jeanson <mjeanson@efficios.com>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
set -exu
-RUBY_VERSION=2.7
+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
-# Nodejs
-# Using Debian, as root
-apt-add-repository ppa:brightbox/ruby-ng
+export DEBIAN_FRONTEND=noninteractive
apt-get update
-apt-get install -y ruby${RUBY_VERSION} ruby${RUBY_VERSION}-dev ruby-switch ruby-bundler
-
-ruby-switch --list
-ruby-switch --set ruby${RUBY_VERSION}
-ruby -v
-export PATH="/root/.gem/ruby/${RUBY_VERSION}.0/bin:$PATH"
-bundle config set --local path "/root/.gem"
+print_header "Install web tooling dependencies"
+apt-get install -y jekyll npm grunt python3 python3-pip python3-venv linkchecker
-
-apt-get install -y jekyll npm grunt python3 python3-pip python3-venv
-
-# babeltrace dependencies
+print_header "Install babeltrace build dependencies"
apt-get install -y asciidoc xmlto libdw-dev libelf-dev elfutils autoconf automake libglib2.0-dev make doxygen flex bison
+print_header "Install NPM stuff"
npm install
-python3 -m venv build_venv && source build_venv/bin/activate
+print_header "Install Python requirements"
+python3 -m venv build_venv
+source build_venv/bin/activate
pip install -r requirements.txt
# Setting TERM avoids spurious warnings when configure is checking TPUT, as
# $TERM is not set in the build environment.
# As we've already opened a venv, set SKIP_VENV so the python job doesn't
# create a second nested virtual environment.
-TERM=dumb SKIP_VENV=1 grunt build:prod --verbose
+print_header "Build website with grunt"
+TERM=dumb SKIP_VENV=1 VERBOSE=1 grunt build:prod --verbose
-apt-get install -y linkchecker
+print_header "Check links"
grunt connect:prod watch:prod &
SERVER_PID="${!}"
sleep 10 # While serve:prod starts up
-OUTPUT_FILE="$(mktemp -d)/linkchecker-out.csv"
-chown nobody "$(dirname "${OUTPUT_FILE}")"
+
+OUTPUT_DIR="$(mktemp -d)"
+OUTPUT_FILE="${OUTPUT_DIR}/linkchecker-out.csv"
+
+# linkchecker drops privileges to 'nobody' when run as root
+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
# In the venv functions generated by the version of python installed on bionic
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
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
# lttng-www dependencies
export DPKG_FRONTEND=noninteractive
-# Nodejs
-# Using Debian, as root
apt-get update
-apt-get install -y nodejs npm
-apt-get install -y ruby ruby-bundler ruby-dev
+
+print_header "Install web tooling dependencies"
+apt-get install -y nodejs node-grunt-cli npm ruby-bundler ruby-dev python3-pip python3-venv
+
ruby -v
-apt-get install -y asciidoc xmlto python3 python3-pip doclifter
-npm install -g grunt-cli
-npm install -g sass
+apt-get install -y xmlto doclifter linkchecker
+
+python3 -m venv build_venv
+# shellcheck disable=SC1091
+source build_venv/bin/activate
bundle config set --local path "vendor/bundle"
-./bootstrap.sh
+./bootstrap-debian.sh
-bundle exec grunt build:prod --network
+print_header "Build website with grunt"
+bundle exec grunt build:prod
-apt-get install -y linkchecker
+print_header "Check links"
bundle exec grunt connect:prod watch:prod &
SERVER_PID="${!}"
sleep 10 # While serve:prod starts up
-OUTPUT_FILE="$(mktemp -d)/linkchecker-out.csv"
-chown nobody "$(dirname "${OUTPUT_FILE}")"
+
+OUTPUT_DIR="$(mktemp -d)"
+OUTPUT_FILE="${OUTPUT_DIR}/linkchecker-out.csv"
+
+# linkchecker drops privileges to 'nobody' when run as root
+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"
bundle exec grunt deploy:prod --network
# EOF