setup-lisp/.github/actions/build-docs/action.yml
Alexander Artemenko 0044213c5e Wasting time.
2021-02-06 23:06:11 +03:00

222 lines
7.4 KiB
YAML

name: 'Build Docs'
inputs:
asdf-system:
description: 'ASDF system to build system for'
required: true
qlfile-template:
description: "Djula template for qlfile. All environment variables are available in it's context"
required: false
# SSH_PASS:
# description: 'Password for SSH session'
# required: true
# NGROK_AUTH_TOKEN:
# description: 'Authentification token for ngrok'
# required: true
# NGROK_REGION:
# description: 'Region for ngrok session'
# required: false
# default: 'us'
# NGROK_TIMEOUT:
# description: 'Timeout in seconds for ngrok session'
# default: 21500
runs:
using: composite
steps:
- name: Install Documentation Builder
shell: bash
run: |
echo ::group::Install Documentation Builder
echo 'github docs-builder 40ants/docs-builder' >> qlfile
qlot update
qlot exec ros install docs-builder
echo ::endgroup::
# - name: Check inputs
# run: |
# if [ -z "${{ inputs.SSH_PASS }}" ]
# then
# echo "SSH_PASS needs to be passed in the 'with' field."
# exit 1
# fi
# if [ -z "${{ inputs.NGROK_AUTH_TOKEN }}" ]
# then
# echo "NGROK_AUTH_TOKEN needs to be passed in the 'with' field."
# exit 1
# fi
# shell: bash
# - name: Meet OS specific prerequisites
# run: |
# if('${{ runner.os }}' -eq 'Linux')
# {
# printf "# Preparing environment..."
# echo "ngrok-stable-linux-386.zip" > ngrok_zip_name
# whoami > ssh_user
# printf " [DONE]\n\n"
# echo "# Change the SSH user password"
# echo "${{ inputs.SSH_PASS }}`n${{ inputs.SSH_PASS }}" | sudo passwd $(cat ssh_user)
# }
# elseif('${{ runner.os }}' -eq 'macOS')
# {
# printf "# Preparing environment..."
# echo "ngrok-stable-darwin-amd64.zip" > ngrok_zip_name
# echo "root" > ssh_user
# printf " [DONE]\n\n"
# echo "# Change the SSH user password"
# echo 'PermitRootLogin yes' | sudo tee -a /etc/ssh/sshd_config >/dev/null
# sudo launchctl unload /System/Library/LaunchDaemons/ssh.plist
# sudo launchctl load -w /System/Library/LaunchDaemons/ssh.plist
# echo "${{ inputs.SSH_PASS }}`n${{ inputs.SSH_PASS }}" | sudo passwd "root"
# }
# elseif('${{ runner.os }}' -eq 'Windows')
# {
# printf "# Preparing environment..."
# echo "ngrok-stable-windows-amd64.zip" > ngrok_zip_name
# echo $env:UserName > ssh_user
# printf " [DONE]\n\n"
# echo "# Install SSH server"
# curl https://dl.bitvise.com/BvSshServer-Inst.exe --output BvSshServer-Inst.exe
# .\BvSshServer-Inst.exe -acceptEULA -defaultInstance
# printf "# Setting up the SSH server to allow access..."
# $cfg = new-object -com "BssCfg815.BssCfg815"
# $cfg.settings.SetDefaults()
# $cfg.settings.access.SetDefaults()
# $cfg.settings.access.winGroups.Clear()
# $cfg.settings.access.winGroups.new.SetDefaults()
# $cfg.settings.access.winGroups.new.loginAllowed = $true
# $cfg.settings.access.winGroups.NewCommit()
# $cfg.settings.Save()
# printf " [DONE]\n\n"
# echo "# Add Firewall rule to allow inbound TCP connection on local port 22"
# New-NetFirewallRule -Name ngrok -DisplayName 'ngrok' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
# echo "# Start the SSH server"
# net start BvSshServer
# echo "# Change the SSH user password"
# net user $env:UserName ${{ inputs.SSH_PASS }}
# }
# shell: pwsh
# - name: Install and setup ngrok
# run: |
# echo "# Install ngrok"
# curl https://bin.equinox.io/c/4VmDzA7iaHb/$(cat ngrok_zip_name) --output ngrok.zip
# unzip ngrok.zip
# chmod +x ./ngrok
# echo "# Set ngrok with the given authentification token"
# ./ngrok authtoken ${{ inputs.NGROK_AUTH_TOKEN }}
# shell: bash
# - name: Start ngrok
# run: |
# set -Eeuo pipefail
# printf "# Starting ngrok..."
# ./ngrok tcp 22 --log ".ngrok.log" --region "${{ inputs.NGROK_REGION }}" &
# printf " [DONE]\n\n"
# printf "# Waiting for '.ngrok.log' file to be properly generated..."
# while ! grep -osqE "tcp://(.+)" .ngrok.log;do
# sleep 1
# if grep -sq "command failed" .ngrok.log
# then
# exit 1
# fi
# done
# printf " [DONE]\n\n"
# ssh_string=$(grep -oE "tcp://(.+)" .ngrok.log | sed "s/tcp:\/\//ssh $(cat ssh_user)@/" | sed "s/:/ -p /")
# continue_path=$(eval echo ~$(cat ssh_user)/continue)
# time=${{ inputs.NGROK_TIMEOUT }}
# while [ ! -e $continue_path ] && [ $time -gt 1 ]
# do
# echo ""
# echo "#################"
# echo "# Connect to this runner using:"
# echo "#########################################"
# echo $ssh_string
# echo "#########################################"
# echo "#"
# echo "# Allow workflow to continue using:"
# echo "#########################################"
# echo "bash -c \"touch $continue_path\""
# echo "#########################################"
# echo "#"
# echo "# SSH session time left:"
# echo "########################################"
# printf '#%-14s%dh:%02dm:%02ds%-14s#\n' '' $(($time/3600)) $(($time%3600/60)) $(($time%60)) ''
# echo "########################################"
# echo ""
# sleep 10
# time=$((time-10))
# done
# echo "# SSH session terminated. Allowing workflow to continue..."
# shell: bash
- name: Build Docs
id: build-docs
shell: bash
run: |
echo ::group::Build Docs
echo "TRACE 1"
# OUTPUT_DIR=`build-docs ${{ inputs.asdf-system }}`
cat > test.sh <<EOF
echo Foo >&1
echo Bar >&2
EOF
bash test.sh > out 2> err
echo TTTTT 1_out
cat out
echo TTTTT 1_err
cat err
build-docs ${{ inputs.asdf-system }} > build-docs.out 2> build-docs.err
# echo "TRACE 1_1"
# echo =============
# echo ${OUTPUT_DIR}
# echo =============
echo "TRACE 1_out"
echo =============
cat build-docs.out
echo =============
echo "TRACE 1_err"
echo =============
cat build-docs.err
echo =============
OUTPUT_DIR=$(cat build-docs.out)
echo "TRACE 2"
echo "::set-output name=build-dir::${OUTPUT_DIR}"
echo "TRACE 3"
echo ::endgroup::
echo "TRACE 4"
- name: Upload Docs
shell: bash
run: |
set -x
set -Eeuo pipefail
echo "TRACE 5"
echo ::group::Upload Docs
echo "TRACE 6"
BUILD_DIR="${{ steps.build-docs.outputs.build-dir }}"
echo "TRACE 7"
${{ github.action_path }}/upload.ros "${BUILD_DIR}"
echo "TRACE 8"
echo ::endgroup::