Test linters for OCI Docker #203
Workflow file for this run
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: Install OneClickInstall Docker | |
on: | |
pull_request: | |
types: [opened, reopened, synchronize] | |
paths: | |
- '.github/workflows/ci-oci-docker-install.yml' | |
- 'install/OneClickInstall/install-Docker.sh' | |
push: | |
branches: | |
- 'hotfix/**' | |
- 'release/**' | |
- 'develop' | |
- 'feature/check-lint-docker' | |
paths: | |
- 'install/OneClickInstall/install-Docker.sh' | |
- 'install/docker/*.yml' | |
- '.github/workflows/ci-oci-docker-install.yml' | |
workflow_dispatch: | |
inputs: | |
offline: | |
description: 'Publish 4testing offline archive' | |
required: true | |
default: false | |
type: boolean | |
jobs: | |
Install-OneClickInstall-Docker: | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Determine Branch Name | |
run: | | |
case "${{ github.event_name }}" in | |
"pull_request") | |
BRANCH_NAME="${{ github.event.pull_request.head.ref }}" | |
;; | |
*) | |
BRANCH_NAME="${GITHUB_REF#refs/heads/}" | |
;; | |
esac | |
echo "BRANCH_NAME=${BRANCH_NAME:-master}" >> $GITHUB_ENV | |
# - name: Free Disk Space | |
# run: | | |
# sudo docker image prune --all --force | |
# - name: Test OCI docker scripts | |
# run: | | |
# wget https://download.onlyoffice.com/docspace/docspace-enterprise-install.sh | |
# sed '/bash install-Docker.sh/i sed -i "1i set -x" install-Docker.sh' -i docspace-enterprise-install.sh | |
# sed '/bash install-Docker.sh/i sed -i "/docker-compose.*up -d/ s/$/ --quiet-pull/" install-Docker.sh' -i docspace-enterprise-install.sh | |
# sudo bash docspace-enterprise-install.sh docker -docsi onlyoffice/documentserver-ee -skiphc true -noni true $([ ${{ env.BRANCH_NAME }} != "master" ] && echo "-gb ${{ env.BRANCH_NAME }} -s 4testing-") || exit $? | |
# echo -n "Waiting for all containers to start..." | |
# timeout 300 bash -c 'while docker ps | grep -q "starting"; do sleep 5; done' && echo "OK" || echo "container_status=timeout" >> $GITHUB_ENV | |
# - name: Check container status | |
# run: | | |
# docker ps --all --format "{{.Names}}" | xargs -I {} sh -c ' | |
# status=$(docker inspect --format="{{if .State.Health}}{{.State.Health.Status}}{{else}}no healthcheck{{end}}" {}); | |
# case "$status" in | |
# healthy) color="\033[0;32m" ;; # green | |
# "no healthcheck") color="\033[0;33m" ;; # yellow | |
# *) color="\033[0;31m"; echo "container_status=red" >> $GITHUB_ENV ;; # red | |
# esac; | |
# printf "%-50s ${color}%s\033[0m\n" "{}:" "$status"; | |
# ' | |
# - name: Print logs for crashed container | |
# run: | | |
# docker ps --all --format "{{.Names}}" | xargs -I {} sh -c ' | |
# status=$(docker inspect --format="{{if .State.Health}}{{.State.Health.Status}}{{else}}no healthcheck{{end}}" {}); | |
# case "$status" in | |
# healthy | "no healthcheck") ;; | |
# *) | |
# echo "Logs for container {}:"; | |
# docker logs --tail 30 {} | sed "s/^/\t/g"; | |
# ;; | |
# esac; | |
# ' | |
# case "${{ env.container_status }}" in | |
# timeout) echo "Timeout reached. Not all containers are running."; exit 1 ;; | |
# red) echo "One or more containers have status 'red'. Job will fail."; exit 1 ;; | |
# esac | |
- name: Checkout repository | |
#if: ${{ github.event.inputs.offline == 'true' }} | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ env.BRANCH_NAME }} | |
- name: "Checking Docker scripts for errors" | |
run: | | |
set -eux | |
sudo apt-get install -y shellcheck | |
find install/docker -type f -name "*.sh" | cat - <(echo "install/OneClickInstall/install-Docker.sh") \ | |
| xargs shellcheck --exclude="$(awk '!/^#|^$/ {print $1}' tests/lint/sc_ignore | paste -sd ",")" --severity=warning | tee sc_output | |
awk '/\(warning\):/ {w++} /\(error\):/ {e++} END {if (w+e) printf "::warning ::ShellCheck detected %d warnings and %d errors\n", w+0, e+0}' sc_output | |
- name: Free Disk Space | |
if: ${{ github.event.inputs.offline == 'true' }} | |
run: | | |
docker stop $(docker ps -a -q) && docker rm $(docker ps -a -q) && docker volume rm $(docker volume ls -q) | |
sudo rm -rf /usr/local/lib/android /opt/ghc /usr/share/swift /usr/share/miniconda /usr/share/az* /usr/share/glade* /usr/local/lib/node_modules /usr/local/share/chromium /usr/local/share/powershell | |
- name: Creating 4testing offline self-extracting archive | |
if: ${{ github.event.inputs.offline == 'true' }} | |
run: | | |
INSTALL_PATH=${{ github.workspace }}/install | |
docker images --format "{{.Repository}}:{{.Tag}}" | grep "4testing-" | xargs -I{} bash -c ' | |
docker tag "$1" $(echo "${1/4testing-/}" | sed -E "s/([0-9]+\.[0-9]+\.[0-9]+)\.[0-9]+/\1/") | |
docker rmi "$1" | |
' _ {} | |
sed -i 's~\(OFFLINE_INSTALLATION="\|SKIP_HARDWARE_CHECK="\).*"$~\1true"~' "${INSTALL_PATH}/OneClickInstall/install-Docker.sh" | |
echo "Creating offline self-extracting archive..." | |
docker save $(docker images --format "{{.Repository}}:{{.Tag}}") | xz --verbose -T0 -z -9e > ${INSTALL_PATH}/docker_images.tar.xz | |
cd ${INSTALL_PATH}/docker && tar -czvf ${INSTALL_PATH}/docker.tar.gz --exclude='config/supervisor*' *.yml .env config/ | |
tar -cvf ${INSTALL_PATH}/offline-docspace.tar \ | |
-C "${INSTALL_PATH}/OneClickInstall" install-Docker.sh \ | |
-C "${INSTALL_PATH}" docker_images.tar.xz \ | |
-C "${INSTALL_PATH}" docker.tar.gz | |
rm -rf ${INSTALL_PATH}/docker_images.tar.xz ${INSTALL_PATH}/docker.tar.gz | |
echo "ARTIFACT_NAME=${ARTIFACT_NAME:=4testing-offline-docspace-installation.sh}" >> $GITHUB_ENV | |
cat ${INSTALL_PATH}/common/self-extracting.sh ${INSTALL_PATH}/offline-docspace.tar > ${INSTALL_PATH}/${ARTIFACT_NAME} | |
chmod +x ${INSTALL_PATH}/${ARTIFACT_NAME} | |
- name: Configure AWS Credentials | |
if: ${{ github.event.inputs.offline == 'true' }} | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID_OCI }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_OCI }} | |
aws-region: us-east-1 | |
- name: Upload 4testing offline self-extracting archive | |
if: ${{ github.event.inputs.offline == 'true' }} | |
run: | | |
aws s3 cp ${{ github.workspace }}/install/${{ env.ARTIFACT_NAME }} \ | |
${{ secrets.AWS_BUCKET_URL_OCI }}/${{ env.ARTIFACT_NAME }} \ | |
--acl public-read \ | |
--content-type application/x-xz \ | |
--metadata-directive REPLACE | |
aws cloudfront create-invalidation \ | |
--distribution-id ${{ secrets.AWS_DISTRIBUTION_ID_OCI }} \ | |
--paths "/docspace/${{ env.ARTIFACT_NAME }}" |