From 74cd758a5d1f62be0a216710fbf39ea9fc5d4fa1 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 4 Apr 2024 12:27:10 -0600 Subject: [PATCH 01/23] Per #521, add hooks for a SonarQube GHA workflow. --- .github/jobs/configure_sonarqube.sh | 65 ++++++++++++++++ .github/pull_request_template.md | 3 + .github/workflows/sonarqube.yml | 76 +++++++++++++++++++ .../sonarqube/sonar-project.properties | 11 +++ 4 files changed, 155 insertions(+) create mode 100755 .github/jobs/configure_sonarqube.sh create mode 100644 .github/workflows/sonarqube.yml create mode 100644 internal/scripts/sonarqube/sonar-project.properties diff --git a/.github/jobs/configure_sonarqube.sh b/.github/jobs/configure_sonarqube.sh new file mode 100755 index 00000000..929b03fa --- /dev/null +++ b/.github/jobs/configure_sonarqube.sh @@ -0,0 +1,65 @@ +#!/bin/bash + +# Constants +SONAR_PROPERTIES_DIR=internal/scripts/sonarqube +SONAR_PROPERTIES=sonar-project.properties + +# Check that this is being run from the top-level METdataio directory +if [ ! -e $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES ]; then + echo "ERROR: ${0} -> must be run from the top-level METdataio directory" + exit 1 +fi + +# Check required environment variables +if [ -z ${SOURCE_BRANCH+x} ]; then + echo "ERROR: ${0} -> \$SOURCE_BRANCH not defined!" + exit 1 +fi +if [ -z ${WD_REFERENCE_BRANCH+x} ]; then + echo "ERROR: ${0} -> \$WD_REFERENCE_BRANCH not defined!" + exit 1 +fi +if [ -z ${SONAR_HOST_URL+x} ]; then + echo "ERROR: ${0} -> \$SONAR_HOST_URL not defined!" + exit 1 +fi +if [ -z ${SONAR_TOKEN+x} ]; then + echo "ERROR: ${0} -> \$SONAR_TOKEN not defined!" + exit 1 +fi + +# Define the version string +SONAR_PROJECT_VERSION=$(cat docs/version | cut -d'=' -f2 | tr -d '" ') + +# +# Define the $SONAR_REFERENCE_BRANCH as the +# - Target of any requests +# - Manual setting for workflow dispatch +# - Source branch for any pushes (e.g. develop) +# +if [ "$GITHUB_EVENT_NAME" == "pull_request" ]; then + export SONAR_REFERENCE_BRANCH=$GITHUB_BASE_REF +elif [ "$GITHUB_EVENT_NAME" == "workflow_dispatch" ]; then + export SONAR_REFERENCE_BRANCH=$WD_REFERENCE_BRANCH +else + export SONAR_REFERENCE_BRANCH=$SOURCE_BRANCH +fi + +# Configure the sonar-project.properties +[ -e $SONAR_PROPERTIES ] && rm $SONAR_PROPERTIES +sed -e "s|SONAR_PROJECT_KEY|METdataio-GHA|" \ + -e "s|SONAR_PROJECT_NAME|METdataio GHA|" \ + -e "s|SONAR_PROJECT_VERSION|$SONAR_PROJECT_VERSION|" \ + -e "s|SONAR_HOST_URL|$SONAR_HOST_URL|" \ + -e "s|SONAR_TOKEN|$SONAR_TOKEN|" \ + -e "s|SONAR_BRANCH_NAME|$SOURCE_BRANCH|" \ + $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES > $SONAR_PROPERTIES + +# Define new code when the source and reference branches differ +if [ "$SOURCE_BRANCH" != "$SONAR_REFERENCE_BRANCH" ]; then + echo "sonar.newCode.referenceBranch=${SONAR_REFERENCE_BRANCH}" >> $SONAR_PROPERTIES +fi + +echo "Contents of the $SONAR_PROPERTIES file:" +cat $SONAR_PROPERTIES + diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md index 86b368fd..dec23969 100644 --- a/.github/pull_request_template.md +++ b/.github/pull_request_template.md @@ -11,6 +11,9 @@ - [ ] Will this PR result in changes to the test suite? **[Yes or No]**
If **yes**, describe the new output and/or changes to the existing output:
+- [ ] Do these changes introduce new SonarQube findings? **[Yes or No]**
+If **yes**, please describe: + - [ ] Please complete this pull request review by **[Fill in date]**.
## Pull Request Checklist ## diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml new file mode 100644 index 00000000..d48e1237 --- /dev/null +++ b/.github/workflows/sonarqube.yml @@ -0,0 +1,76 @@ +name: SonarQube Scan + +# Run SonarQube for Pull Requests and changes to the develop and main_vX.Y branches + +on: + + # Trigger analysis for pushes to develop and main_vX.Y branches + push: + branches: + - develop + - 'main_v**' + paths-ignore: + - 'docs/**' + - '.github/pull_request_template.md' + - '.github/ISSUE_TEMPLATE/**' + - '**/README.md' + - '**/LICENSE.md' + + # Trigger analysis for pull requests to develop and main_vX.Y branches + pull_request: + types: [opened, synchronize, reopened] + branches: + - develop + - 'main_v**' + paths-ignore: + - 'docs/**' + - '.github/pull_request_template.md' + - '.github/ISSUE_TEMPLATE/**' + - '**/README.md' + - '**/LICENSE.md' + + workflow_dispatch: + inputs: + reference_branch: + description: 'Reference Branch' + default: develop + type: string + +jobs: + sonarqube: + name: SonarQube Scan + runs-on: ubuntu-latest + + steps: + + - uses: actions/checkout@v4 + with: + # Disable shallow clones for better analysis + fetch-depth: 0 + + - name: Get branch name + id: get_branch_name + run: echo branch_name=${GITHUB_REF#refs/heads/} >> $GITHUB_OUTPUT + + - name: Configure SonarQube + run: .github/jobs/configure_sonarqube.sh + env: + SOURCE_BRANCH: ${{ steps.get_branch_name.outputs.branch_name }} + WD_REFERENCE_BRANCH: ${{ github.event.inputs.reference_branch }} + SONAR_HOST_URL: ${{ secrets.SONAR_HOST_URL }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} + + - name: SonarQube Scan + uses: sonarsource/sonarqube-scan-action@master + env: + SONAR_HOST_URL: ${{ secrets.SONAR_HOST_URL }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} + + - name: SonarQube Quality Gate check + id: sonarqube-quality-gate-check + uses: sonarsource/sonarqube-quality-gate-action@master + # Force to fail step after specific time. + timeout-minutes: 5 + env: + SONAR_HOST_URL: ${{ secrets.SONAR_HOST_URL }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} diff --git a/internal/scripts/sonarqube/sonar-project.properties b/internal/scripts/sonarqube/sonar-project.properties new file mode 100644 index 00000000..ea7c7a8b --- /dev/null +++ b/internal/scripts/sonarqube/sonar-project.properties @@ -0,0 +1,11 @@ +# Project and source code settings +sonar.projectKey=SONAR_PROJECT_KEY +sonar.projectName=SONAR_PROJECT_NAME +sonar.projectVersion=SONAR_PROJECT_VERSION +sonar.branch.name=SONAR_BRANCH_NAME +sonar.sources=. +sonar.sourceEncoding=UTF-8 + +# SonarQube server +sonar.host.url=SONAR_HOST_URL +sonar.token=SONAR_TOKEN From 5dc9c71fb0b734800cad756d5e895482ad9acdcb Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 4 Apr 2024 15:09:58 -0600 Subject: [PATCH 02/23] Per #521, fix cut/paste error configure_sonarqube.sh --- .github/jobs/configure_sonarqube.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/jobs/configure_sonarqube.sh b/.github/jobs/configure_sonarqube.sh index 929b03fa..1be0c137 100755 --- a/.github/jobs/configure_sonarqube.sh +++ b/.github/jobs/configure_sonarqube.sh @@ -4,9 +4,9 @@ SONAR_PROPERTIES_DIR=internal/scripts/sonarqube SONAR_PROPERTIES=sonar-project.properties -# Check that this is being run from the top-level METdataio directory +# Check that this is being run from the top-level METviewer directory if [ ! -e $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES ]; then - echo "ERROR: ${0} -> must be run from the top-level METdataio directory" + echo "ERROR: ${0} -> must be run from the top-level METviewer directory" exit 1 fi @@ -47,8 +47,8 @@ fi # Configure the sonar-project.properties [ -e $SONAR_PROPERTIES ] && rm $SONAR_PROPERTIES -sed -e "s|SONAR_PROJECT_KEY|METdataio-GHA|" \ - -e "s|SONAR_PROJECT_NAME|METdataio GHA|" \ +sed -e "s|SONAR_PROJECT_KEY|METviewer-GHA|" \ + -e "s|SONAR_PROJECT_NAME|METviewer GHA|" \ -e "s|SONAR_PROJECT_VERSION|$SONAR_PROJECT_VERSION|" \ -e "s|SONAR_HOST_URL|$SONAR_HOST_URL|" \ -e "s|SONAR_TOKEN|$SONAR_TOKEN|" \ From cc3b6016c4bbcac91c9e5a6a7773a9834bbe67e8 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 10:12:41 -0600 Subject: [PATCH 03/23] Per #521, hard-code the Sonar Project key and name in the properties file since we're using the same project for all scans. --- internal/scripts/sonarqube/sonar-project.properties | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/internal/scripts/sonarqube/sonar-project.properties b/internal/scripts/sonarqube/sonar-project.properties index ea7c7a8b..96e107af 100644 --- a/internal/scripts/sonarqube/sonar-project.properties +++ b/internal/scripts/sonarqube/sonar-project.properties @@ -1,6 +1,6 @@ # Project and source code settings -sonar.projectKey=SONAR_PROJECT_KEY -sonar.projectName=SONAR_PROJECT_NAME +sonar.projectKey=METviewer +sonar.projectName=METviewer sonar.projectVersion=SONAR_PROJECT_VERSION sonar.branch.name=SONAR_BRANCH_NAME sonar.sources=. From cfb8b1510183ec548d2842e0a5fa4a28f4654fe1 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 10:33:28 -0600 Subject: [PATCH 04/23] Per #521, setup build_sonar.xml configuration by referencing environment variables. --- .github/jobs/configure_sonarqube.sh | 18 +- internal/scripts/sonarqube/build_sonar.xml | 645 ++++++++++++++++++ .../sonarqube/sonar-project.properties | 11 - 3 files changed, 650 insertions(+), 24 deletions(-) create mode 100644 internal/scripts/sonarqube/build_sonar.xml delete mode 100644 internal/scripts/sonarqube/sonar-project.properties diff --git a/.github/jobs/configure_sonarqube.sh b/.github/jobs/configure_sonarqube.sh index 1be0c137..ab8819e8 100755 --- a/.github/jobs/configure_sonarqube.sh +++ b/.github/jobs/configure_sonarqube.sh @@ -2,7 +2,7 @@ # Constants SONAR_PROPERTIES_DIR=internal/scripts/sonarqube -SONAR_PROPERTIES=sonar-project.properties +SONAR_PROPERTIES=build_sonar.xml # Check that this is being run from the top-level METviewer directory if [ ! -e $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES ]; then @@ -29,7 +29,7 @@ if [ -z ${SONAR_TOKEN+x} ]; then fi # Define the version string -SONAR_PROJECT_VERSION=$(cat docs/version | cut -d'=' -f2 | tr -d '" ') +export SONAR_PROJECT_VERSION=$(cat docs/version | cut -d'=' -f2 | tr -d '" ') # # Define the $SONAR_REFERENCE_BRANCH as the @@ -45,19 +45,11 @@ else export SONAR_REFERENCE_BRANCH=$SOURCE_BRANCH fi -# Configure the sonar-project.properties -[ -e $SONAR_PROPERTIES ] && rm $SONAR_PROPERTIES -sed -e "s|SONAR_PROJECT_KEY|METviewer-GHA|" \ - -e "s|SONAR_PROJECT_NAME|METviewer GHA|" \ - -e "s|SONAR_PROJECT_VERSION|$SONAR_PROJECT_VERSION|" \ - -e "s|SONAR_HOST_URL|$SONAR_HOST_URL|" \ - -e "s|SONAR_TOKEN|$SONAR_TOKEN|" \ - -e "s|SONAR_BRANCH_NAME|$SOURCE_BRANCH|" \ - $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES > $SONAR_PROPERTIES - # Define new code when the source and reference branches differ if [ "$SOURCE_BRANCH" != "$SONAR_REFERENCE_BRANCH" ]; then - echo "sonar.newCode.referenceBranch=${SONAR_REFERENCE_BRANCH}" >> $SONAR_PROPERTIES + export SONAR_REFERENCE_BRANCH_PROPERTY="" +else + export SONAR_REFERENCE_BRANCH_PROPERTY="" fi echo "Contents of the $SONAR_PROPERTIES file:" diff --git a/internal/scripts/sonarqube/build_sonar.xml b/internal/scripts/sonarqube/build_sonar.xml new file mode 100644 index 00000000..d363b574 --- /dev/null +++ b/internal/scripts/sonarqube/build_sonar.xml @@ -0,0 +1,645 @@ + + + METViewer build file + + + + + + + + + + + + + + + + + + ${SONAR_REFERENCE_BRANCH_PROPERTY} + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + You must specify the path to METcalcpy directory + You must specify the path to METplotpy directory + You must specify the path to METdataio directory + You must specify the path to METviewer_py3.6.3 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/internal/scripts/sonarqube/sonar-project.properties b/internal/scripts/sonarqube/sonar-project.properties deleted file mode 100644 index 96e107af..00000000 --- a/internal/scripts/sonarqube/sonar-project.properties +++ /dev/null @@ -1,11 +0,0 @@ -# Project and source code settings -sonar.projectKey=METviewer -sonar.projectName=METviewer -sonar.projectVersion=SONAR_PROJECT_VERSION -sonar.branch.name=SONAR_BRANCH_NAME -sonar.sources=. -sonar.sourceEncoding=UTF-8 - -# SonarQube server -sonar.host.url=SONAR_HOST_URL -sonar.token=SONAR_TOKEN From 78cbb4ba2e92e090742ea265435a717c7c60aed9 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 10:55:47 -0600 Subject: [PATCH 05/23] work in progress --- .../scripts/sonarqube/Dockerfile.sonarqube | 332 ++++++++++++++++++ 1 file changed, 332 insertions(+) create mode 100644 internal/scripts/sonarqube/Dockerfile.sonarqube diff --git a/internal/scripts/sonarqube/Dockerfile.sonarqube b/internal/scripts/sonarqube/Dockerfile.sonarqube new file mode 100644 index 00000000..842d5e35 --- /dev/null +++ b/internal/scripts/sonarqube/Dockerfile.sonarqube @@ -0,0 +1,332 @@ +FROM centos:7 +MAINTAINER John Halley Gotway + +# +# This Dockerfile checks out METviewer from GitHub and runs the +# SonarQube static code analysis on the specified branch or tag. +# https://docs.sonarqube.org/latest/analysis/scan/sonarscanner/ +# + +# +# SonarQube Settings +# +ARG SONAR_SCANNER_VERSION=5.0.1.3006 +ARG SONAR_HOST_URL +ARG SONAR_TOKEN +ARG SOURCE_BRANCH +ARG SONAR_REFERENCE_BRANCH + +# +# SONAR_HOST_URL is required. +# +RUN if [ "x${SONAR_HOST_URL}" = "x" ]; then \ + echo "ERROR: SONAR_HOST_URL undefined! Rebuild with \"--build-arg SONAR_HOST_URL={url}\""; \ + exit 1; \ + fi + +# +# SONAR_TOKEN is required. +# +RUN if [ "x${SONAR_TOKEN}" = "x" ]; then \ + echo "ERROR: SONAR_TOKEN undefined! Rebuild with \"--build-arg SONAR_TOKEN={token}\""; \ + exit 1; \ + fi + +# +# SOURCE_BRANCH is the branch name of the MET source code. +# +RUN if [ "x${SOURCE_BRANCH}" = "x" ]; then \ + echo "ERROR: SOURCE_BRANCH undefined! Rebuild with \"--build-arg SOURCE_BRANCH={branch name}\""; \ + exit 1; \ + else \ + echo "Build Argument SOURCE_BRANCH=${SOURCE_BRANCH}"; \ + fi + +# +# SONAR_REFERENCE_BRANCH defines to the version against which this scan should be compared. +# +RUN if [ "x${SONAR_REFERENCE_BRANCH}" = "x" ]; then \ + echo "ERROR: SONAR_REFERENCE_BRANCH undefined! Rebuild with \"--build-arg SONAR_REFERENCE_BRANCH={branch name}\""; \ + exit 1; \ + else \ + echo "Build Argument SONAR_REFERENCE_BRANCH=${SONAR_REFERENCE_BRANCH}"; \ + fi + +# +# METviewer Settings +# +ENV TOMCAT_MINOR_VERSION 5.61 +ENV TOMCAT_MAJOR_VERSION 8 +ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} +ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer +ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy +ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy +ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio + +# +# METVIEWER_GIT_NAME is set as ${SOURCE_BRANCH}. +# +ENV METVIEWER_GIT_NAME ${SOURCE_BRANCH} + +# +# METCALCPY_GIT_NAME is required. +# +RUN if [ "x${METCALCPY_GIT_NAME}" = "x" ]; then \ + echo "ERROR: METCALCPY_GIT_NAME undefined! Rebuild with \"--build-arg METCALCPY_GIT_NAME={branch, tag, or hash}\""; \ + exit 1; \ + else \ + echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}"; \ + fi + +# +# METPLOTPY_GIT_NAME is required. +# +RUN if [ "x${METPLOTPY_GIT_NAME}" = "x" ]; then \ + echo "ERROR: METPLOTPY_GIT_NAME undefined! Rebuild with \"--build-arg METPLOTPY_GIT_NAME={branch, tag, or hash}\""; \ + exit 1; \ + else \ + echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}"; \ + fi + +# +# METDATAIO_GIT_NAME is required. +# +RUN if [ "x${METDATAIO_GIT_NAME}" = "x" ]; then \ + echo "ERROR: METDATAIO_GIT_NAME undefined! Rebuild with \"--build-arg METDATAIO_GIT_NAME={branch, tag, or hash}\""; \ + exit 1; \ + else \ + echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}"; \ + fi + +# +# Install system updates +# +RUN yum -y update \ + && yum -y install epel-release \ + && yum -y install 'dnf-command(config-manager)' \ + && yum-config-manager --enable PowerTools + +# +# Install required packages +# +RUN yum -y install wget tar git ant java R mysql ksh \ + && rm -rf /var/cache/yum/* \ + && yum clean all + +# +# Install gsl-2.5 on which the R gsl package depends. +# The centos7 gal package is too old (version 1.5). +# +RUN echo "Compiling gsl-2.5" \ + && curl -SL http://gnu.askapache.com/gsl/gsl-2.5.tar.gz | tar zxC /lib \ + && cd /lib/gsl-2.5 \ + && ./configure --prefix=/usr --libdir=/usr/lib64 >& configure.log \ + && make >& make.log \ + && make install >& make_install.log + +# +# Setup default cran repo +# +RUN echo "r <- getOption('repos'); r['CRAN'] <- 'http://cran.us.r-project.org'; options(repos = r);" > ~/.Rprofile + +# +# Install required R packages +# +RUN Rscript -e "install.packages('boot')" \ + && Rscript -e "install.packages('plotrix')" \ + && Rscript -e "install.packages('gsl')" \ + && Rscript -e "install.packages('data.table')" \ + && Rscript -e "install.packages('verification')" + +# +# Install Tomcat +# +ENV CATALINA_HOME /opt/tomcat + +RUN wget https://archive.apache.org/dist/tomcat/tomcat-${TOMCAT_MAJOR_VERSION}/v${TOMCAT_VERSION}/bin/apache-tomcat-${TOMCAT_VERSION}.tar.gz \ + && tar -xvf apache-tomcat-${TOMCAT_VERSION}.tar.gz \ + && rm apache-tomcat*.tar.gz \ + && mv apache-tomcat* ${CATALINA_HOME} \ + && chmod +x ${CATALINA_HOME}/bin/*sh + +EXPOSE 8080 + +# +# Install METplus python components +# +RUN mkdir /METviewer-python \ + && echo "Checking out METcalcpy ${METCALCPY_GIT_NAME} from ${METCALCPY_GIT_URL}" +WORKDIR /METviewer-python/ +RUN git clone --branch ${METCALCPY_GIT_NAME} ${METCALCPY_GIT_URL} + +RUN echo "Checking out METplotpy ${METPLOTPY_GIT_NAME} from ${METPLOTPY_GIT_URL}" +WORKDIR /METviewer-python/ +RUN git clone --branch ${METPLOTPY_GIT_NAME} ${METPLOTPY_GIT_URL} + +RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" \ +WORKDIR /METviewer-python/ +RUN git clone --branch ${METDATAIO_GIT_NAME} ${METDATAIO_GIT_URL} + +# +# Install METviewer +# +RUN echo "Checking out METviewer ${METVIEWER_GIT_NAME} from ${METVIEWER_GIT_URL}" +RUN git clone --branch ${METVIEWER_GIT_NAME} ${METVIEWER_GIT_URL} /METviewer \ + && echo "Configuring and building METviewer" \ + && cd /METviewer \ + && cat webapp/metviewer/WEB-INF/classes/build.properties | \ + sed -r 's%db.host=.*%db.host=mysql_mv%g' | \ + sed -r 's%db.user=.*%db.user=root%g' | \ + sed -r 's%db.password=.*%db.password=mvuser%g' | \ + sed -r 's%db.management.system=.*%db.management.system=mysql%g' | \ + sed -r 's%output.dir=.*%output.dir=/opt/tomcat/webapps/metviewer_output/%g' | \ + sed -r 's%webapps.dir=.*%webapps.dir=/opt/tomcat/webapps/metviewer/%g' | \ + sed -r 's%url.output=.*%url.output=http://localhost:8080/metviewer_output/%g' | \ + sed -r 's%python.env=.*%python.env=/usr/%g' | \ + sed -r 's%metcalcpy.home=.*%metcalcpy.home=/METviewer-python/METcalcpy/%g' | \ + sed -r 's%metplotpy.home=.*%metplotpy.home=/METviewer-python/METplotpy/%g' \ + > build.properties \ + && ant -Dbuild.properties.file=./build.properties \ + -Ddb.management.system=mysql \ + -Dmetcalcpy.path=/METviewer-python/METcalcpy/ \ + -Dmetplotpy.path=/METviewer-python/METplotpy/ \ + -Dpython.env.path=/usr/ war \ + && mv /METviewer/dist/*.war ${CATALINA_HOME}/webapps \ + && echo "Configuring METviewer scripts" \ + && cd /METviewer/bin \ + && cat mv_batch.sh | \ + sed -r 's%JAVA=.*%JAVA=java\nMV_HOME=/METviewer%g' | \ + sed -r 's%PYTHON_ENV=.*%PYTHON_ENV=/usr%g' | \ + sed -r 's%METCALCPY_HOME=.*%METCALCPY_HOME=/METviewer-python/METcalcpy/%g' | \ + sed -r 's%METPLOTPY_HOME=.*%METPLOTPY_HOME=/METviewer-python/METplotpy/%g' \ + > mv_batch.sh-DOCKER \ + && mv mv_batch.sh-DOCKER mv_batch.sh \ + && cat mv_load.sh | \ + sed -r 's%PYTHON_ENV=.*%PYTHON_ENV=/usr%g' | \ + sed -r 's%METDATAIO_HOME=.*%METDATAIO_HOME=/METviewer-python/METdataio/%g' \ + > mv_load.sh-DOCKER \ + && mv mv_load.sh-DOCKER mv_load.sh \ + && cat mv_scorecard.sh | \ + sed -r 's%JAVA=.*%JAVA=java\nMV_HOME=/METviewer%g' | \ + sed -r 's%PYTHON_ENV=.*%PYTHON_ENV=/usr%g' | \ + sed -r 's%METCALCPY_HOME=.*%METCALCPY_HOME=/METviewer-python/METcalcpy/%g' | \ + sed -r 's%METPLOTPY_HOME=.*%METPLOTPY_HOME=/METviewer-python/METplotpy/%g' \ + > mv_scorecard.sh-DOCKER \ + && mv mv_scorecard.sh-DOCKER mv_scorecard.sh \ + && cat mv_prune.sh | \ + sed -r 's%JAVA=.*%JAVA=java\nMV_HOME=/METviewer%g' | \ + sed -r 's%PYTHON_ENV=.*%PYTHON_ENV=/usr%g' | \ + sed -r 's%METCALCPY_HOME=.*%METCALCPY_HOME=/METviewer-python/METcalcpy/%g' | \ + sed -r 's%METPLOTPY_HOME=.*%METPLOTPY_HOME=/METviewer-python/METplotpy/%g' \ + > mv_prune.sh-DOCKER \ + && mv mv_prune.sh-DOCKER mv_prune.sh + +# +# Install Python 3.10.4 +# +RUN yum install gcc openssl11 openssl11-devel libreadline-gplv2-dev libncursesw5-dev libsqlite3-dev tk-dev libgdbm-dev libc6-dev libbz2-dev openssl-devel libssl-dev bzip2-devel libffi-devel zlib-devel libproj-dev proj-data proj-bin libgeos-dev bzip2 -y +RUN mkdir /usr/local/openssl11 +WORKDIR /usr/local/openssl11 +RUN ln -s /usr/lib64/openssl11 lib +RUN ln -s /usr/include/openssl11 include + +RUN curl https://www.python.org/ftp/python/3.10.4/Python-3.10.4.tgz --output /tmp/Python-3.10.4.tgz +WORKDIR /tmp +RUN tar xzf Python-3.10.4.tgz +WORKDIR /tmp/Python-3.10.4 +RUN ./configure --enable-optimizations --with-openssl=/usr/local/openssl11 +RUN yum install make -y +RUN make altinstall +RUN yum install which -y +WORKDIR /tmp +RUN rm -r Python-3.10.4.tgz +RUN yum -y install epel-release +RUN curl -sS https://bootstrap.pypa.io/get-pip.py -o get-pip.py | python3.10 +RUN python3.10 -m pip install --trusted-host pypi.python.org --trusted-host files.pythonhosted.org --trusted-host pypi.org --upgrade pip + +# +# Create a link for python3 +# +RUN ln -sf /usr/local/bin/python3.10 /usr/bin/python3 +RUN ln -sf /usr/bin/python3 /usr/bin/python + +RUN ln -sf /usr/local/bin/pip3.10 /usr/bin/pip3 +RUN ln -sf /usr/bin/pip3 /usr/bin/pip + +# +# install GEOS - needed for cartopy +# +WORKDIR /tmp +RUN wget http://download.osgeo.org/geos/geos-3.7.2.tar.bz2 +RUN tar xjf geos-3.7.2.tar.bz2 +WORKDIR /tmp/geos-3.7.2 +RUN ./configure --enable-php; make clean ; make +RUN make install +RUN ldconfig +WORKDIR /tmp +RUN rm -r geos-3.7.2.tar.bz2 + +# +# Install Python packages +# +RUN pip install cartopy \ + && pip install eofs \ + && pip install imutils==0.5.4 \ + && pip install imageio==2.19.2 \ + && pip install lxml==4.9.1 \ + && pip install matplotlib==3.5.2 \ + && pip install netcdf4==1.6.2 \ + && pip install numpy==1.22.0 \ + && pip install pytest==7.1.2 \ + && pip install metpy==1.3.1 \ + && pip install pyyaml==6.0 \ + && pip install scikit-image==0.19.3 \ + && pip install scikit-learn \ + && pip install scipy==1.11.1 \ + && pip install xarray==2022.3.0 \ + && pip install PyMySQL==1.0.2 \ + && pip install pint==0.19.2 \ + && pip install plotly==5.9.0 \ + && pip install kaleido==0.2.1 \ + && pip install attrs==22.1.0 \ + && pip install exceptiongroup==1.0.4 \ + && pip install iniconfig==1.1.1 \ + && pip install packaging==22.0 \ + && pip install pluggy==1.0.0 \ + && pip install pytz==2022.6 \ + && pip install setuptools==65.5.1 \ + && pip install six==1.16.0 \ + && pip install tomli==2.0.1 \ + && pip install wheel==0.38.1 \ + && pip install python-dateutil==2.8.2 \ + && pip install opencv-python \ + && pip install pandas==1.5.2 +# +# + + + +# +# set env vars +# +ENV PYTHONPATH "${PYTHONPATH}:/METviewer-python/METcalcpy/:/METviewer-python/METplotpy/" +ENV METPLOTPY_BASE "/METviewer-python/METplotpy/" + +# remove unneeded scripts +RUN rm /METviewer/bin/auto_test.sh \ + && rm /METviewer/bin/mv_test.sh \ + && rm /METviewer/bin/nightly_test.sh \ + && rm /METviewer/bin/prep_dist.sh \ + && rm /METviewer/bin/mv_compare.sh \ + && rm -r /METviewer/test + +# change permissions of the scripts +RUN chmod 755 /METviewer/bin/mv_batch.sh \ + && chmod 755 /METviewer/bin/mv_load.sh \ + && chmod 755 /METviewer/bin/mv_prune.sh \ + && chmod 755 /METviewer/bin/mv_scorecard.sh + + +ENTRYPOINT ${CATALINA_HOME}/bin/startup.sh && /bin/bash +CMD ["true"] + From 3bb46796ff22ade1f1ce7fadb8ed84d78d90e17e Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 12:32:49 -0600 Subject: [PATCH 06/23] Per #521, move docker directory into internal/scripts for consistency across METplus repos --- {docker => internal/scripts/docker}/Dockerfile | 0 {docker => internal/scripts/docker}/Dockerfile_for_Singularity | 0 {docker => internal/scripts/docker}/README | 0 {docker => internal/scripts/docker}/check_env.sh | 0 {docker => internal/scripts/docker}/docker-clean | 0 {docker => internal/scripts/docker}/docker-compose.yml | 0 {docker => internal/scripts/docker}/docker-entrypoint.sh | 0 {docker => internal/scripts/docker}/fix-permissions.sh | 0 {docker => internal/scripts/docker}/hooks/build | 0 {docker => internal/scripts/docker}/init_singularity.sh | 0 10 files changed, 0 insertions(+), 0 deletions(-) rename {docker => internal/scripts/docker}/Dockerfile (100%) rename {docker => internal/scripts/docker}/Dockerfile_for_Singularity (100%) rename {docker => internal/scripts/docker}/README (100%) rename {docker => internal/scripts/docker}/check_env.sh (100%) rename {docker => internal/scripts/docker}/docker-clean (100%) rename {docker => internal/scripts/docker}/docker-compose.yml (100%) rename {docker => internal/scripts/docker}/docker-entrypoint.sh (100%) rename {docker => internal/scripts/docker}/fix-permissions.sh (100%) rename {docker => internal/scripts/docker}/hooks/build (100%) rename {docker => internal/scripts/docker}/init_singularity.sh (100%) diff --git a/docker/Dockerfile b/internal/scripts/docker/Dockerfile similarity index 100% rename from docker/Dockerfile rename to internal/scripts/docker/Dockerfile diff --git a/docker/Dockerfile_for_Singularity b/internal/scripts/docker/Dockerfile_for_Singularity similarity index 100% rename from docker/Dockerfile_for_Singularity rename to internal/scripts/docker/Dockerfile_for_Singularity diff --git a/docker/README b/internal/scripts/docker/README similarity index 100% rename from docker/README rename to internal/scripts/docker/README diff --git a/docker/check_env.sh b/internal/scripts/docker/check_env.sh similarity index 100% rename from docker/check_env.sh rename to internal/scripts/docker/check_env.sh diff --git a/docker/docker-clean b/internal/scripts/docker/docker-clean similarity index 100% rename from docker/docker-clean rename to internal/scripts/docker/docker-clean diff --git a/docker/docker-compose.yml b/internal/scripts/docker/docker-compose.yml similarity index 100% rename from docker/docker-compose.yml rename to internal/scripts/docker/docker-compose.yml diff --git a/docker/docker-entrypoint.sh b/internal/scripts/docker/docker-entrypoint.sh similarity index 100% rename from docker/docker-entrypoint.sh rename to internal/scripts/docker/docker-entrypoint.sh diff --git a/docker/fix-permissions.sh b/internal/scripts/docker/fix-permissions.sh similarity index 100% rename from docker/fix-permissions.sh rename to internal/scripts/docker/fix-permissions.sh diff --git a/docker/hooks/build b/internal/scripts/docker/hooks/build similarity index 100% rename from docker/hooks/build rename to internal/scripts/docker/hooks/build diff --git a/docker/init_singularity.sh b/internal/scripts/docker/init_singularity.sh similarity index 100% rename from docker/init_singularity.sh rename to internal/scripts/docker/init_singularity.sh From 2eedf7bd7ec82d821a9304291dc7769cc030797d Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 15:57:26 -0600 Subject: [PATCH 07/23] Per #521, work in progress. --- .github/jobs/build_metviewer_image.sh | 57 +++++++++++++++++++ .github/workflows/sonarqube.yml | 3 + .../Dockerfile.copy} | 10 +++- ...for_Singularity => Dockerfile.singularity} | 0 4 files changed, 67 insertions(+), 3 deletions(-) create mode 100755 .github/jobs/build_metviewer_image.sh rename internal/scripts/{sonarqube/Dockerfile.sonarqube => docker/Dockerfile.copy} (97%) rename internal/scripts/docker/{Dockerfile_for_Singularity => Dockerfile.singularity} (100%) diff --git a/.github/jobs/build_metviewer_image.sh b/.github/jobs/build_metviewer_image.sh new file mode 100755 index 00000000..ab8819e8 --- /dev/null +++ b/.github/jobs/build_metviewer_image.sh @@ -0,0 +1,57 @@ +#!/bin/bash + +# Constants +SONAR_PROPERTIES_DIR=internal/scripts/sonarqube +SONAR_PROPERTIES=build_sonar.xml + +# Check that this is being run from the top-level METviewer directory +if [ ! -e $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES ]; then + echo "ERROR: ${0} -> must be run from the top-level METviewer directory" + exit 1 +fi + +# Check required environment variables +if [ -z ${SOURCE_BRANCH+x} ]; then + echo "ERROR: ${0} -> \$SOURCE_BRANCH not defined!" + exit 1 +fi +if [ -z ${WD_REFERENCE_BRANCH+x} ]; then + echo "ERROR: ${0} -> \$WD_REFERENCE_BRANCH not defined!" + exit 1 +fi +if [ -z ${SONAR_HOST_URL+x} ]; then + echo "ERROR: ${0} -> \$SONAR_HOST_URL not defined!" + exit 1 +fi +if [ -z ${SONAR_TOKEN+x} ]; then + echo "ERROR: ${0} -> \$SONAR_TOKEN not defined!" + exit 1 +fi + +# Define the version string +export SONAR_PROJECT_VERSION=$(cat docs/version | cut -d'=' -f2 | tr -d '" ') + +# +# Define the $SONAR_REFERENCE_BRANCH as the +# - Target of any requests +# - Manual setting for workflow dispatch +# - Source branch for any pushes (e.g. develop) +# +if [ "$GITHUB_EVENT_NAME" == "pull_request" ]; then + export SONAR_REFERENCE_BRANCH=$GITHUB_BASE_REF +elif [ "$GITHUB_EVENT_NAME" == "workflow_dispatch" ]; then + export SONAR_REFERENCE_BRANCH=$WD_REFERENCE_BRANCH +else + export SONAR_REFERENCE_BRANCH=$SOURCE_BRANCH +fi + +# Define new code when the source and reference branches differ +if [ "$SOURCE_BRANCH" != "$SONAR_REFERENCE_BRANCH" ]; then + export SONAR_REFERENCE_BRANCH_PROPERTY="" +else + export SONAR_REFERENCE_BRANCH_PROPERTY="" +fi + +echo "Contents of the $SONAR_PROPERTIES file:" +cat $SONAR_PROPERTIES + diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index d48e1237..58ed56ae 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -52,6 +52,9 @@ jobs: id: get_branch_name run: echo branch_name=${GITHUB_REF#refs/heads/} >> $GITHUB_OUTPUT + - name: Build METviewer Docker Image + run: .github/jobs/build_metviewer_image.sh + - name: Configure SonarQube run: .github/jobs/configure_sonarqube.sh env: diff --git a/internal/scripts/sonarqube/Dockerfile.sonarqube b/internal/scripts/docker/Dockerfile.copy similarity index 97% rename from internal/scripts/sonarqube/Dockerfile.sonarqube rename to internal/scripts/docker/Dockerfile.copy index 842d5e35..061b097d 100644 --- a/internal/scripts/sonarqube/Dockerfile.sonarqube +++ b/internal/scripts/docker/Dockerfile.copy @@ -1,9 +1,13 @@ -FROM centos:7 +ARG MET_BASE_REPO=met-base +ARG MET_BASE_TAG=v3.2 + +FROM dtcenter/${MET_BASE_REPO}:${MET_BASE_TAG} MAINTAINER John Halley Gotway # -# This Dockerfile checks out METviewer from GitHub and runs the -# SonarQube static code analysis on the specified branch or tag. +# This Dockerfile downloads and installs METviewer dependencies +# and builds the local version found in the /metviewer directory. +# It then runs the SonarQube static code analysis on the result. # https://docs.sonarqube.org/latest/analysis/scan/sonarscanner/ # diff --git a/internal/scripts/docker/Dockerfile_for_Singularity b/internal/scripts/docker/Dockerfile.singularity similarity index 100% rename from internal/scripts/docker/Dockerfile_for_Singularity rename to internal/scripts/docker/Dockerfile.singularity From 6470376da0e050b4cb82d0afe418d6c657c08143 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 16:01:33 -0600 Subject: [PATCH 08/23] Per #521, switch to running the sonar-scanner. --- internal/scripts/sonarqube/build_sonar.xml | 645 ------------------ .../sonarqube/sonar-project.properties | 13 + 2 files changed, 13 insertions(+), 645 deletions(-) delete mode 100644 internal/scripts/sonarqube/build_sonar.xml create mode 100644 internal/scripts/sonarqube/sonar-project.properties diff --git a/internal/scripts/sonarqube/build_sonar.xml b/internal/scripts/sonarqube/build_sonar.xml deleted file mode 100644 index d363b574..00000000 --- a/internal/scripts/sonarqube/build_sonar.xml +++ /dev/null @@ -1,645 +0,0 @@ - - - METViewer build file - - - - - - - - - - - - - - - - - - ${SONAR_REFERENCE_BRANCH_PROPERTY} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - You must specify the path to METcalcpy directory - You must specify the path to METplotpy directory - You must specify the path to METdataio directory - You must specify the path to METviewer_py3.6.3 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/internal/scripts/sonarqube/sonar-project.properties b/internal/scripts/sonarqube/sonar-project.properties new file mode 100644 index 00000000..3586fc31 --- /dev/null +++ b/internal/scripts/sonarqube/sonar-project.properties @@ -0,0 +1,13 @@ +# Project and source code settings +sonar.projectKey=METviewer +sonar.projectName=METviewer +sonar.projectVersion=SONAR_PROJECT_VERSION +sonar.branch.name=SONAR_BRANCH_NAME +sonar.sources=java +sonar.java.libraries=dist/lib +sonar.java.binaries=dist/metviewer/WEB-INF/classes +sonar.sourceEncoding=UTF-8 + +# SonarQube server +sonar.host.url=SONAR_HOST_URL +sonar.token=SONAR_TOKEN From f5d806cf632e4204f36be449388ac96389410df9 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Thu, 18 Apr 2024 16:40:37 -0600 Subject: [PATCH 09/23] Per #521, still working on the details --- .github/jobs/bash_functions.sh | 34 +++++++++ .github/jobs/build_docker_image.sh | 24 +++++++ .github/jobs/build_metviewer_image.sh | 57 --------------- .github/jobs/configure_sonarqube.sh | 17 +++-- .github/workflows/sonarqube.yml | 9 ++- internal/scripts/docker/Dockerfile.copy | 93 +++++++++---------------- 6 files changed, 108 insertions(+), 126 deletions(-) create mode 100755 .github/jobs/bash_functions.sh create mode 100755 .github/jobs/build_docker_image.sh delete mode 100755 .github/jobs/build_metviewer_image.sh diff --git a/.github/jobs/bash_functions.sh b/.github/jobs/bash_functions.sh new file mode 100755 index 00000000..05cffc94 --- /dev/null +++ b/.github/jobs/bash_functions.sh @@ -0,0 +1,34 @@ +#! /bin/bash + +# utility function to run command get log the time it took to run +# if CMD_LOGFILE is set, send output to that file and unset var +function time_command { + local start_seconds=$SECONDS + echo "RUNNING: $*" + + local error + # pipe output to log file if set + if [ "x$CMD_LOGFILE" == "x" ]; then + "$@" + error=$? + else + echo "Logging to ${CMD_LOGFILE}" + "$@" &>> $CMD_LOGFILE + error=$? + unset CMD_LOGFILE + fi + + local duration=$(( SECONDS - start_seconds )) + echo "TIMING: Command took `printf '%02d' $(($duration / 60))`:`printf '%02d' $(($duration % 60))` (MM:SS): '$*'" + if [ ${error} -ne 0 ]; then + echo "ERROR: '$*' exited with status = ${error}" + fi + return $error +} + +# utility function to construct the DockerHub tag name to be used, +# replacing slashes with underscores in the branch name + +function get_dockerhub_tag { + echo ${DOCKERHUB_REPO}:$(echo ${SOURCE_BRANCH} | sed 's%/%_%g') +} diff --git a/.github/jobs/build_docker_image.sh b/.github/jobs/build_docker_image.sh new file mode 100755 index 00000000..d8e0e963 --- /dev/null +++ b/.github/jobs/build_docker_image.sh @@ -0,0 +1,24 @@ +#!/bin/bash + +source ${GITHUB_WORKSPACE}/.github/jobs/bash_functions.sh + +DOCKERHUB_TAG=$(get_dockerhub_tag) + +DOCKERFILE_PATH=${GITHUB_WORKSPACE}/internal/scripts/docker/Dockerfile.copy + +CMD_LOGFILE=${GITHUB_WORKSPACE}/docker_build.log + +time_command docker build -t ${DOCKERHUB_TAG} \ + --build-arg SOURCE_BRANCH \ + --build-arg MET_BASE_REPO \ + --build-arg MET_BASE_TAG \ + -f $DOCKERFILE_PATH ${GITHUB_WORKSPACE} +if [ $? != 0 ]; then + cat ${CMD_LOGFILE} + exit 1 +fi + +# Copy the dist directory from the image +id=$(docker create ${DOCKERHUB_TAG}) +time_command docker cp $id:/METviewer/dist dist +docker rm -v $id diff --git a/.github/jobs/build_metviewer_image.sh b/.github/jobs/build_metviewer_image.sh deleted file mode 100755 index ab8819e8..00000000 --- a/.github/jobs/build_metviewer_image.sh +++ /dev/null @@ -1,57 +0,0 @@ -#!/bin/bash - -# Constants -SONAR_PROPERTIES_DIR=internal/scripts/sonarqube -SONAR_PROPERTIES=build_sonar.xml - -# Check that this is being run from the top-level METviewer directory -if [ ! -e $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES ]; then - echo "ERROR: ${0} -> must be run from the top-level METviewer directory" - exit 1 -fi - -# Check required environment variables -if [ -z ${SOURCE_BRANCH+x} ]; then - echo "ERROR: ${0} -> \$SOURCE_BRANCH not defined!" - exit 1 -fi -if [ -z ${WD_REFERENCE_BRANCH+x} ]; then - echo "ERROR: ${0} -> \$WD_REFERENCE_BRANCH not defined!" - exit 1 -fi -if [ -z ${SONAR_HOST_URL+x} ]; then - echo "ERROR: ${0} -> \$SONAR_HOST_URL not defined!" - exit 1 -fi -if [ -z ${SONAR_TOKEN+x} ]; then - echo "ERROR: ${0} -> \$SONAR_TOKEN not defined!" - exit 1 -fi - -# Define the version string -export SONAR_PROJECT_VERSION=$(cat docs/version | cut -d'=' -f2 | tr -d '" ') - -# -# Define the $SONAR_REFERENCE_BRANCH as the -# - Target of any requests -# - Manual setting for workflow dispatch -# - Source branch for any pushes (e.g. develop) -# -if [ "$GITHUB_EVENT_NAME" == "pull_request" ]; then - export SONAR_REFERENCE_BRANCH=$GITHUB_BASE_REF -elif [ "$GITHUB_EVENT_NAME" == "workflow_dispatch" ]; then - export SONAR_REFERENCE_BRANCH=$WD_REFERENCE_BRANCH -else - export SONAR_REFERENCE_BRANCH=$SOURCE_BRANCH -fi - -# Define new code when the source and reference branches differ -if [ "$SOURCE_BRANCH" != "$SONAR_REFERENCE_BRANCH" ]; then - export SONAR_REFERENCE_BRANCH_PROPERTY="" -else - export SONAR_REFERENCE_BRANCH_PROPERTY="" -fi - -echo "Contents of the $SONAR_PROPERTIES file:" -cat $SONAR_PROPERTIES - diff --git a/.github/jobs/configure_sonarqube.sh b/.github/jobs/configure_sonarqube.sh index ab8819e8..8e3d4fa0 100755 --- a/.github/jobs/configure_sonarqube.sh +++ b/.github/jobs/configure_sonarqube.sh @@ -2,7 +2,7 @@ # Constants SONAR_PROPERTIES_DIR=internal/scripts/sonarqube -SONAR_PROPERTIES=build_sonar.xml +SONAR_PROPERTIES=sonar-project.properties # Check that this is being run from the top-level METviewer directory if [ ! -e $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES ]; then @@ -29,7 +29,7 @@ if [ -z ${SONAR_TOKEN+x} ]; then fi # Define the version string -export SONAR_PROJECT_VERSION=$(cat docs/version | cut -d'=' -f2 | tr -d '" ') +export SONAR_PROJECT_VERSION=$(cat docs/version) # # Define the $SONAR_REFERENCE_BRANCH as the @@ -45,13 +45,18 @@ else export SONAR_REFERENCE_BRANCH=$SOURCE_BRANCH fi +# Configure the sonar-project.properties +[ -e $SONAR_PROPERTIES ] && rm $SONAR_PROPERTIES +sed -e "s|SONAR_PROJECT_VERSION|$SONAR_PROJECT_VERSION|" \ + -e "s|SONAR_HOST_URL|$SONAR_HOST_URL|" \ + -e "s|SONAR_TOKEN|$SONAR_TOKEN|" \ + -e "s|SONAR_BRANCH_NAME|$SOURCE_BRANCH|" \ + $SONAR_PROPERTIES_DIR/$SONAR_PROPERTIES > $SONAR_PROPERTIES + # Define new code when the source and reference branches differ if [ "$SOURCE_BRANCH" != "$SONAR_REFERENCE_BRANCH" ]; then - export SONAR_REFERENCE_BRANCH_PROPERTY="" -else - export SONAR_REFERENCE_BRANCH_PROPERTY="" + echo "sonar.newCode.referenceBranch=${SONAR_REFERENCE_BRANCH}" >> $SONAR_PROPERTIES fi echo "Contents of the $SONAR_PROPERTIES file:" cat $SONAR_PROPERTIES - diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index 58ed56ae..8c435aa4 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -53,7 +53,14 @@ jobs: run: echo branch_name=${GITHUB_REF#refs/heads/} >> $GITHUB_OUTPUT - name: Build METviewer Docker Image - run: .github/jobs/build_metviewer_image.sh + run: .github/jobs/build_docker_image.sh + + - name: Copy dist + run: + cd ${GITHUB_WORKSPACE} + id=$(docker create metviewer-gha) + docker cp ${id}:/METviewer/dist . + docker rm -v ${id} - name: Configure SonarQube run: .github/jobs/configure_sonarqube.sh diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index 061b097d..2880496e 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -1,76 +1,36 @@ -ARG MET_BASE_REPO=met-base -ARG MET_BASE_TAG=v3.2 +FROM centos:7 -FROM dtcenter/${MET_BASE_REPO}:${MET_BASE_TAG} -MAINTAINER John Halley Gotway +MAINTAINER Tatiana Burek # -# This Dockerfile downloads and installs METviewer dependencies -# and builds the local version found in the /metviewer directory. -# It then runs the SonarQube static code analysis on the result. -# https://docs.sonarqube.org/latest/analysis/scan/sonarscanner/ +# This Dockerfile checks out the METviewer dependencies from GitHub +# and builds the local version of the METviewer code. # +ENV METVIEWER_GIT_NAME develop +ENV METCALCPY_GIT_NAME develop +ENV METPLOTPY_GIT_NAME develop +ENV METDATAIO_GIT_NAME develop # -# SonarQube Settings -# -ARG SONAR_SCANNER_VERSION=5.0.1.3006 -ARG SONAR_HOST_URL -ARG SONAR_TOKEN -ARG SOURCE_BRANCH -ARG SONAR_REFERENCE_BRANCH - -# -# SONAR_HOST_URL is required. -# -RUN if [ "x${SONAR_HOST_URL}" = "x" ]; then \ - echo "ERROR: SONAR_HOST_URL undefined! Rebuild with \"--build-arg SONAR_HOST_URL={url}\""; \ - exit 1; \ - fi - -# -# SONAR_TOKEN is required. -# -RUN if [ "x${SONAR_TOKEN}" = "x" ]; then \ - echo "ERROR: SONAR_TOKEN undefined! Rebuild with \"--build-arg SONAR_TOKEN={token}\""; \ - exit 1; \ - fi - -# -# SOURCE_BRANCH is the branch name of the MET source code. -# -RUN if [ "x${SOURCE_BRANCH}" = "x" ]; then \ - echo "ERROR: SOURCE_BRANCH undefined! Rebuild with \"--build-arg SOURCE_BRANCH={branch name}\""; \ - exit 1; \ - else \ - echo "Build Argument SOURCE_BRANCH=${SOURCE_BRANCH}"; \ - fi - -# -# SONAR_REFERENCE_BRANCH defines to the version against which this scan should be compared. -# -RUN if [ "x${SONAR_REFERENCE_BRANCH}" = "x" ]; then \ - echo "ERROR: SONAR_REFERENCE_BRANCH undefined! Rebuild with \"--build-arg SONAR_REFERENCE_BRANCH={branch name}\""; \ - exit 1; \ - else \ - echo "Build Argument SONAR_REFERENCE_BRANCH=${SONAR_REFERENCE_BRANCH}"; \ - fi - -# -# METviewer Settings +# Constants # ENV TOMCAT_MINOR_VERSION 5.61 ENV TOMCAT_MAJOR_VERSION 8 ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} -ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer + ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio # -# METVIEWER_GIT_NAME is set as ${SOURCE_BRANCH}. +# METVIEWER_GIT_NAME is required. # -ENV METVIEWER_GIT_NAME ${SOURCE_BRANCH} +RUN if [ "x${METVIEWER_GIT_NAME}" = "x" ]; then \ + echo "ERROR: METVIEWER_GIT_NAME undefined! Rebuild with \"--build-arg METVIEWER_GIT_NAME={branch, tag, or hash}\""; \ + exit 1; \ + else \ + echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}"; \ + fi # # METCALCPY_GIT_NAME is required. @@ -167,16 +127,25 @@ RUN echo "Checking out METplotpy ${METPLOTPY_GIT_NAME} from ${METPLOTPY_GIT_URL} WORKDIR /METviewer-python/ RUN git clone --branch ${METPLOTPY_GIT_NAME} ${METPLOTPY_GIT_URL} -RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" \ +RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" WORKDIR /METviewer-python/ RUN git clone --branch ${METDATAIO_GIT_NAME} ${METDATAIO_GIT_URL} # -# Install METviewer +# Copy in the local version of the METviewer code # -RUN echo "Checking out METviewer ${METVIEWER_GIT_NAME} from ${METVIEWER_GIT_URL}" -RUN git clone --branch ${METVIEWER_GIT_NAME} ${METVIEWER_GIT_URL} /METviewer \ - && echo "Configuring and building METviewer" \ +RUN echo "Copying METviewer into /METviewer" \ +WORKDIR /METviewer + && mkdir -p /METviewer + +COPY . /METviewer + +RUN if [ ! -e "/METviewer/build.xml" ]; then \ + echo "ERROR: docker build must be run from the METviewer directory"; \ + exit 1; \ + fi + +RUN echo "Configuring and building METviewer" \ && cd /METviewer \ && cat webapp/metviewer/WEB-INF/classes/build.properties | \ sed -r 's%db.host=.*%db.host=mysql_mv%g' | \ From 1bb48a464eae8687ba1ad370481a6bfc1252d8d1 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 08:42:52 -0600 Subject: [PATCH 10/23] Whitespace changes --- internal/scripts/docker/Dockerfile.copy | 5 ----- 1 file changed, 5 deletions(-) diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index 2880496e..c2ac11f4 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -274,10 +274,6 @@ RUN pip install cartopy \ && pip install python-dateutil==2.8.2 \ && pip install opencv-python \ && pip install pandas==1.5.2 -# -# - - # # set env vars @@ -299,7 +295,6 @@ RUN chmod 755 /METviewer/bin/mv_batch.sh \ && chmod 755 /METviewer/bin/mv_prune.sh \ && chmod 755 /METviewer/bin/mv_scorecard.sh - ENTRYPOINT ${CATALINA_HOME}/bin/startup.sh && /bin/bash CMD ["true"] From 4ac20f8db14a04a7d88e0f0b9b17c7e2fa34b9de Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 08:50:31 -0600 Subject: [PATCH 11/23] Per #521, try turning on the sonarqube workflow for this feature branch. --- .github/workflows/sonarqube.yml | 10 ++-------- 1 file changed, 2 insertions(+), 8 deletions(-) diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index 8c435aa4..d19aa3c4 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -22,6 +22,7 @@ on: branches: - develop - 'main_v**' + - feature_521_develop_sonarqube_gha paths-ignore: - 'docs/**' - '.github/pull_request_template.md' @@ -52,16 +53,9 @@ jobs: id: get_branch_name run: echo branch_name=${GITHUB_REF#refs/heads/} >> $GITHUB_OUTPUT - - name: Build METviewer Docker Image + - name: Build METviewer in Docker run: .github/jobs/build_docker_image.sh - - name: Copy dist - run: - cd ${GITHUB_WORKSPACE} - id=$(docker create metviewer-gha) - docker cp ${id}:/METviewer/dist . - docker rm -v ${id} - - name: Configure SonarQube run: .github/jobs/configure_sonarqube.sh env: From bab343091114d18305a550e67ce7fbf6e88692a7 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 08:52:40 -0600 Subject: [PATCH 12/23] Per #521, try turning on the sonarqube workflow for this feature branch. --- .github/workflows/sonarqube.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index d19aa3c4..43f691a1 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -9,6 +9,7 @@ on: branches: - develop - 'main_v**' + - feature_521_develop_sonarqube_gha paths-ignore: - 'docs/**' - '.github/pull_request_template.md' From 434f2bca222816e1eb6ef736245f1cba7d749f16 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 09:30:00 -0600 Subject: [PATCH 13/23] Per #521, try to save the logs --- .github/workflows/sonarqube.yml | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index 43f691a1..d34af96a 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -50,6 +50,9 @@ jobs: # Disable shallow clones for better analysis fetch-depth: 0 + - name: Create output directories + run: mkdir -p ${RUNNER_WORKSPACE}/logs + - name: Get branch name id: get_branch_name run: echo branch_name=${GITHUB_REF#refs/heads/} >> $GITHUB_OUTPUT @@ -79,3 +82,15 @@ jobs: env: SONAR_HOST_URL: ${{ secrets.SONAR_HOST_URL }} SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} + + - name: Copy log files into logs directory + if: always() + run: cp ${GITHUB_WORKSPACE}/*.log ${RUNNER_WORKSPACE}/logs/ + + - name: Upload logs as artifact + if: always() + uses: actions/upload-artifact@v4 + with: + name: logs_sonarqube + path: ${{ runner.workspace }}/logs + if-no-files-found: ignore From 7c9f1f82e3108132c38c058be35a3dfc9277d89f Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 12:53:48 -0600 Subject: [PATCH 14/23] Per #521, print the environment for debugging --- .github/jobs/build_docker_image.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/jobs/build_docker_image.sh b/.github/jobs/build_docker_image.sh index d8e0e963..adc65ad4 100755 --- a/.github/jobs/build_docker_image.sh +++ b/.github/jobs/build_docker_image.sh @@ -8,6 +8,9 @@ DOCKERFILE_PATH=${GITHUB_WORKSPACE}/internal/scripts/docker/Dockerfile.copy CMD_LOGFILE=${GITHUB_WORKSPACE}/docker_build.log +echo "CURRENT ENVIRONMENT:" +printenv + time_command docker build -t ${DOCKERHUB_TAG} \ --build-arg SOURCE_BRANCH \ --build-arg MET_BASE_REPO \ From 7dddd4f567cd809a225592d1fbb6a5024bd1723d Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 13:04:48 -0600 Subject: [PATCH 15/23] Per #521, define missing DOCKERHUB_REPO and SOURCE_BRANCH envvars --- .github/jobs/build_docker_image.sh | 3 --- .github/workflows/sonarqube.yml | 5 +++++ 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/.github/jobs/build_docker_image.sh b/.github/jobs/build_docker_image.sh index adc65ad4..d8e0e963 100755 --- a/.github/jobs/build_docker_image.sh +++ b/.github/jobs/build_docker_image.sh @@ -8,9 +8,6 @@ DOCKERFILE_PATH=${GITHUB_WORKSPACE}/internal/scripts/docker/Dockerfile.copy CMD_LOGFILE=${GITHUB_WORKSPACE}/docker_build.log -echo "CURRENT ENVIRONMENT:" -printenv - time_command docker build -t ${DOCKERHUB_TAG} \ --build-arg SOURCE_BRANCH \ --build-arg MET_BASE_REPO \ diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index d34af96a..ab68a04b 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -38,6 +38,9 @@ on: default: develop type: string +env: + DOCKERHUB_REPO: dtcenter/metviewer-dev + jobs: sonarqube: name: SonarQube Scan @@ -59,6 +62,8 @@ jobs: - name: Build METviewer in Docker run: .github/jobs/build_docker_image.sh + env: + SOURCE_BRANCH: ${{ steps.get_branch_name.outputs.branch_name }} - name: Configure SonarQube run: .github/jobs/configure_sonarqube.sh From 36d8db1c49e5fcbb2e43613d781b24caa2174bcb Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 13:29:40 -0600 Subject: [PATCH 16/23] Per #521, working on Dockerfile.copy --- internal/scripts/docker/Dockerfile.copy | 63 ++++++++++--------------- 1 file changed, 26 insertions(+), 37 deletions(-) diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index c2ac11f4..47eca63b 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -6,61 +6,50 @@ MAINTAINER Tatiana Burek # This Dockerfile checks out the METviewer dependencies from GitHub # and builds the local version of the METviewer code. # -ENV METVIEWER_GIT_NAME develop -ENV METCALCPY_GIT_NAME develop -ENV METPLOTPY_GIT_NAME develop -ENV METDATAIO_GIT_NAME develop # -# Constants +# SOURCE_BRANCH is not defined when built via DockerHub. # -ENV TOMCAT_MINOR_VERSION 5.61 -ENV TOMCAT_MAJOR_VERSION 8 -ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} - -ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy -ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy -ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio +ARG SOURCE_BRANCH +RUN if [ "x${SOURCE_BRANCH}" = "x" ]; then \ + echo "ERROR: SOURCE_BRANCH undefined! Rebuild with \"--build-arg SOURCE_BRANCH={branch name}\""; \ + exit 1; \ + else \ + echo "Build Argument SOURCE_BRANCH=${SOURCE_BRANCH}"; \ + fi # # METVIEWER_GIT_NAME is required. # +ARG METVIEWER_GIT_NAME RUN if [ "x${METVIEWER_GIT_NAME}" = "x" ]; then \ echo "ERROR: METVIEWER_GIT_NAME undefined! Rebuild with \"--build-arg METVIEWER_GIT_NAME={branch, tag, or hash}\""; \ exit 1; \ - else \ - echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}"; \ fi # -# METCALCPY_GIT_NAME is required. +# Use the develop branch for METviewer dependencies by default. +# Use "--build-arg" options to override. # -RUN if [ "x${METCALCPY_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METCALCPY_GIT_NAME undefined! Rebuild with \"--build-arg METCALCPY_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}"; \ - fi +ENV METVIEWER_REPO_DIR /METviewer +ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy +ENV METPLOTPY_GIT_NAME develop +ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy +ENV METCALCPY_GIT_NAME develop +ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio +ENV METDATAIO_GIT_NAME develop -# -# METPLOTPY_GIT_NAME is required. -# -RUN if [ "x${METPLOTPY_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METPLOTPY_GIT_NAME undefined! Rebuild with \"--build-arg METPLOTPY_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}"; \ - fi +RUN echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}"; \ + && echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}"; \ + && echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}"; \ + && echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}"; # -# METDATAIO_GIT_NAME is required. +# Constants # -RUN if [ "x${METDATAIO_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METDATAIO_GIT_NAME undefined! Rebuild with \"--build-arg METDATAIO_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}"; \ - fi +ENV TOMCAT_MINOR_VERSION 5.61 +ENV TOMCAT_MAJOR_VERSION 8 +ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} # # Install system updates From dd1c226768fdea6c311f94020a041d2719a0898b Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 13:34:04 -0600 Subject: [PATCH 17/23] Per #521, use hard-coded /METviewer directory instead of to avoid inconsistent use of an environment variable. --- internal/scripts/docker/Dockerfile.copy | 2 -- 1 file changed, 2 deletions(-) diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index 47eca63b..1cb135d2 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -31,7 +31,6 @@ RUN if [ "x${METVIEWER_GIT_NAME}" = "x" ]; then \ # Use the develop branch for METviewer dependencies by default. # Use "--build-arg" options to override. # -ENV METVIEWER_REPO_DIR /METviewer ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy ENV METPLOTPY_GIT_NAME develop ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy @@ -124,7 +123,6 @@ RUN git clone --branch ${METDATAIO_GIT_NAME} ${METDATAIO_GIT_URL} # Copy in the local version of the METviewer code # RUN echo "Copying METviewer into /METviewer" \ -WORKDIR /METviewer && mkdir -p /METviewer COPY . /METviewer From b9986111ac1ab15b7004610a88781d09b4cbc714 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 13:40:58 -0600 Subject: [PATCH 18/23] Per #521, METVIEWER_GIT_NAME is set as SOURCE_BRANCH rather than being a required envvar. --- internal/scripts/docker/Dockerfile.copy | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index 1cb135d2..e0b6d6f5 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -17,15 +17,7 @@ RUN if [ "x${SOURCE_BRANCH}" = "x" ]; then \ else \ echo "Build Argument SOURCE_BRANCH=${SOURCE_BRANCH}"; \ fi - -# -# METVIEWER_GIT_NAME is required. -# -ARG METVIEWER_GIT_NAME -RUN if [ "x${METVIEWER_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METVIEWER_GIT_NAME undefined! Rebuild with \"--build-arg METVIEWER_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - fi +ENV METVIEWER_GIT_NAME ${SOURCE_BRANCH} # # Use the develop branch for METviewer dependencies by default. From 6dd5b7431fd645d788d33a4bf78dc17c5f6ffa64 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 13:44:52 -0600 Subject: [PATCH 19/23] Per #521, syntax --- internal/scripts/docker/Dockerfile.copy | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index e0b6d6f5..68129bb6 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -30,10 +30,10 @@ ENV METCALCPY_GIT_NAME develop ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio ENV METDATAIO_GIT_NAME develop -RUN echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}"; \ - && echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}"; \ - && echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}"; \ - && echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}"; +RUN echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}" \ + && echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}" \ + && echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}" \ + && echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}" # # Constants From 24b998a7931311a60a42c9ca16d2da1a234532d2 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 15:25:47 -0600 Subject: [PATCH 20/23] Per #521, consistency of Dockerfiles. --- internal/scripts/docker/Dockerfile | 100 ++++++---------- internal/scripts/docker/Dockerfile.copy | 63 +++++----- .../scripts/docker/Dockerfile.singularity | 111 ++++++------------ 3 files changed, 110 insertions(+), 164 deletions(-) diff --git a/internal/scripts/docker/Dockerfile b/internal/scripts/docker/Dockerfile index a3f02588..0b57e51b 100644 --- a/internal/scripts/docker/Dockerfile +++ b/internal/scripts/docker/Dockerfile @@ -3,24 +3,14 @@ FROM centos:7 MAINTAINER Tatiana Burek # -# This Dockerfile checks out METviewer from GitHub and builds the specified branch or tag. +# This Dockerfile checks out METviewer and its dependencies from GitHub and builds the specified branch or tag. +# Use the develop branches for dependencies by default but override with "--build-arg". # -ENV METVIEWER_GIT_NAME v6.0.0-beta2 -ENV METCALCPY_GIT_NAME v3.0.0-beta2 -ENV METPLOTPY_GIT_NAME v3.0.0-beta2 -ENV METDATAIO_GIT_NAME v3.0.0-beta2 -# -# Constants -# -ENV TOMCAT_MINOR_VERSION 5.61 -ENV TOMCAT_MAJOR_VERSION 8 -ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} - -ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer -ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy -ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy -ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio +ARG METVIEWER_GIT_NAME +ARG METPLOTPY_GIT_NAME=develop +ARG METCALCPY_GIT_NAME=develop +ARG METDATAIO_GIT_NAME=develop # # METVIEWER_GIT_NAME is required. @@ -28,39 +18,27 @@ ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio RUN if [ "x${METVIEWER_GIT_NAME}" = "x" ]; then \ echo "ERROR: METVIEWER_GIT_NAME undefined! Rebuild with \"--build-arg METVIEWER_GIT_NAME={branch, tag, or hash}\""; \ exit 1; \ - else \ - echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}"; \ - fi + fi -# -# METCALCPY_GIT_NAME is required. -# -RUN if [ "x${METCALCPY_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METCALCPY_GIT_NAME undefined! Rebuild with \"--build-arg METCALCPY_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}"; \ - fi +RUN echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}" \ + && echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}" \ + && echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}" \ + && echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}" # -# METPLOTPY_GIT_NAME is required. +# Repository URLs # -RUN if [ "x${METPLOTPY_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METPLOTPY_GIT_NAME undefined! Rebuild with \"--build-arg METPLOTPY_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}"; \ - fi +ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer +ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy +ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy +ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio # -# METDATAIO_GIT_NAME is required. +# Constants # -RUN if [ "x${METDATAIO_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METDATAIO_GIT_NAME undefined! Rebuild with \"--build-arg METDATAIO_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}"; \ - fi +ENV TOMCAT_MINOR_VERSION 5.61 +ENV TOMCAT_MAJOR_VERSION 8 +ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} # # Install system updates @@ -123,17 +101,14 @@ RUN mkdir /METviewer-python \ WORKDIR /METviewer-python/ RUN git clone --branch ${METCALCPY_GIT_NAME} ${METCALCPY_GIT_URL} - RUN echo "Checking out METplotpy ${METPLOTPY_GIT_NAME} from ${METPLOTPY_GIT_URL}" WORKDIR /METviewer-python/ RUN git clone --branch ${METPLOTPY_GIT_NAME} ${METPLOTPY_GIT_URL} - -RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" \ +RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" WORKDIR /METviewer-python/ RUN git clone --branch ${METDATAIO_GIT_NAME} ${METDATAIO_GIT_URL} - # # Install METviewer # @@ -221,7 +196,7 @@ RUN ln -sf /usr/local/bin/pip3.10 /usr/bin/pip3 RUN ln -sf /usr/bin/pip3 /usr/bin/pip # -# install GEOS - needed for cartopy +# Install GEOS - needed for cartopy # WORKDIR /tmp RUN wget http://download.osgeo.org/geos/geos-3.7.2.tar.bz2 @@ -268,31 +243,30 @@ RUN pip install cartopy \ && pip install python-dateutil==2.8.2 \ && pip install opencv-python \ && pip install pandas==1.5.2 -# -# - - # -# set env vars +# Set env vars # ENV PYTHONPATH "${PYTHONPATH}:/METviewer-python/METcalcpy/:/METviewer-python/METplotpy/" ENV METPLOTPY_BASE "/METviewer-python/METplotpy/" -# remove unneeded scripts +# +# Remove unneeded scripts +# RUN rm /METviewer/bin/auto_test.sh \ - && rm /METviewer/bin/mv_test.sh \ - && rm /METviewer/bin/nightly_test.sh \ - && rm /METviewer/bin/prep_dist.sh \ - && rm /METviewer/bin/mv_compare.sh \ - && rm -r /METviewer/test + && rm /METviewer/bin/mv_test.sh \ + && rm /METviewer/bin/nightly_test.sh \ + && rm /METviewer/bin/prep_dist.sh \ + && rm /METviewer/bin/mv_compare.sh \ + && rm -r /METviewer/test -# change permissions of the scripts +# +# Change permissions of the scripts +# RUN chmod 755 /METviewer/bin/mv_batch.sh \ - && chmod 755 /METviewer/bin/mv_load.sh \ - && chmod 755 /METviewer/bin/mv_prune.sh \ - && chmod 755 /METviewer/bin/mv_scorecard.sh - + && chmod 755 /METviewer/bin/mv_load.sh \ + && chmod 755 /METviewer/bin/mv_prune.sh \ + && chmod 755 /METviewer/bin/mv_scorecard.sh ENTRYPOINT ${CATALINA_HOME}/bin/startup.sh && /bin/bash CMD ["true"] diff --git a/internal/scripts/docker/Dockerfile.copy b/internal/scripts/docker/Dockerfile.copy index 68129bb6..8b73beea 100644 --- a/internal/scripts/docker/Dockerfile.copy +++ b/internal/scripts/docker/Dockerfile.copy @@ -3,14 +3,18 @@ FROM centos:7 MAINTAINER Tatiana Burek # -# This Dockerfile checks out the METviewer dependencies from GitHub -# and builds the local version of the METviewer code. +# This Dockerfile checks out the METviewer dependencies from GitHub and builds the local METviewer repository. +# Use the develop branches for dependencies by default but override with "--build-arg". # +ARG SOURCE_BRANCH +ARG METPLOTPY_GIT_NAME=develop +ARG METCALCPY_GIT_NAME=develop +ARG METDATAIO_GIT_NAME=develop + # -# SOURCE_BRANCH is not defined when built via DockerHub. +# SOURCE_BRANCH is required to define the branch of the local METviewer repository. # -ARG SOURCE_BRANCH RUN if [ "x${SOURCE_BRANCH}" = "x" ]; then \ echo "ERROR: SOURCE_BRANCH undefined! Rebuild with \"--build-arg SOURCE_BRANCH={branch name}\""; \ exit 1; \ @@ -19,22 +23,19 @@ RUN if [ "x${SOURCE_BRANCH}" = "x" ]; then \ fi ENV METVIEWER_GIT_NAME ${SOURCE_BRANCH} -# -# Use the develop branch for METviewer dependencies by default. -# Use "--build-arg" options to override. -# -ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy -ENV METPLOTPY_GIT_NAME develop -ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy -ENV METCALCPY_GIT_NAME develop -ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio -ENV METDATAIO_GIT_NAME develop - RUN echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}" \ && echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}" \ && echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}" \ && echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}" +# +# Repository URLs +# +ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer +ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy +ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy +ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio + # # Constants # @@ -112,7 +113,7 @@ WORKDIR /METviewer-python/ RUN git clone --branch ${METDATAIO_GIT_NAME} ${METDATAIO_GIT_URL} # -# Copy in the local version of the METviewer code +# Copy in the local METviewer repository # RUN echo "Copying METviewer into /METviewer" \ && mkdir -p /METviewer @@ -120,7 +121,7 @@ RUN echo "Copying METviewer into /METviewer" \ COPY . /METviewer RUN if [ ! -e "/METviewer/build.xml" ]; then \ - echo "ERROR: docker build must be run from the METviewer directory"; \ + echo "ERROR: docker build must be run from the top-level METviewer directory"; \ exit 1; \ fi @@ -206,7 +207,7 @@ RUN ln -sf /usr/local/bin/pip3.10 /usr/bin/pip3 RUN ln -sf /usr/bin/pip3 /usr/bin/pip # -# install GEOS - needed for cartopy +# Install GEOS - needed for cartopy # WORKDIR /tmp RUN wget http://download.osgeo.org/geos/geos-3.7.2.tar.bz2 @@ -255,24 +256,28 @@ RUN pip install cartopy \ && pip install pandas==1.5.2 # -# set env vars +# Set env vars # ENV PYTHONPATH "${PYTHONPATH}:/METviewer-python/METcalcpy/:/METviewer-python/METplotpy/" ENV METPLOTPY_BASE "/METviewer-python/METplotpy/" -# remove unneeded scripts +# +# Remove unneeded scripts +# RUN rm /METviewer/bin/auto_test.sh \ - && rm /METviewer/bin/mv_test.sh \ - && rm /METviewer/bin/nightly_test.sh \ - && rm /METviewer/bin/prep_dist.sh \ - && rm /METviewer/bin/mv_compare.sh \ - && rm -r /METviewer/test + && rm /METviewer/bin/mv_test.sh \ + && rm /METviewer/bin/nightly_test.sh \ + && rm /METviewer/bin/prep_dist.sh \ + && rm /METviewer/bin/mv_compare.sh \ + && rm -r /METviewer/test -# change permissions of the scripts +# +# Change permissions of the scripts +# RUN chmod 755 /METviewer/bin/mv_batch.sh \ - && chmod 755 /METviewer/bin/mv_load.sh \ - && chmod 755 /METviewer/bin/mv_prune.sh \ - && chmod 755 /METviewer/bin/mv_scorecard.sh + && chmod 755 /METviewer/bin/mv_load.sh \ + && chmod 755 /METviewer/bin/mv_prune.sh \ + && chmod 755 /METviewer/bin/mv_scorecard.sh ENTRYPOINT ${CATALINA_HOME}/bin/startup.sh && /bin/bash CMD ["true"] diff --git a/internal/scripts/docker/Dockerfile.singularity b/internal/scripts/docker/Dockerfile.singularity index 007ce009..4f18ba12 100644 --- a/internal/scripts/docker/Dockerfile.singularity +++ b/internal/scripts/docker/Dockerfile.singularity @@ -3,27 +3,14 @@ FROM centos:7 MAINTAINER Tatiana Burek # -# This Dockerfile checks out METviewer from GitHub and builds the specified branch or tag. +# This Dockerfile checks out METviewer and its dependencies from GitHub and builds the specified branch or tag. +# Use the develop branches for dependencies by default but override with "--build-arg". # -ARG METVIEWER_GIT_NAME -ARG METCALCPY_GIT_NAME -ARG METPLOTPY_GIT_NAME -ARG METDATAIO_GIT_NAME - -# -# Constants -# -ENV TOMCAT_MINOR_VERSION 5.61 -ENV TOMCAT_MAJOR_VERSION 8 -ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} - -ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer -ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy -ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy -ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio -# this umask is needed for Tomcat -ENV UMASK 002 +ARG METVIEWER_GIT_NAME +ARG METPLOTPY_GIT_NAME=develop +ARG METCALCPY_GIT_NAME=develop +ARG METDATAIO_GIT_NAME=develop # # METVIEWER_GIT_NAME is required. @@ -31,39 +18,27 @@ ENV UMASK 002 RUN if [ "x${METVIEWER_GIT_NAME}" = "x" ]; then \ echo "ERROR: METVIEWER_GIT_NAME undefined! Rebuild with \"--build-arg METVIEWER_GIT_NAME={branch, tag, or hash}\""; \ exit 1; \ - else \ - echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}"; \ fi -# -# METCALCPY_GIT_NAME is required. -# -RUN if [ "x${METCALCPY_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METCALCPY_GIT_NAME undefined! Rebuild with \"--build-arg METCALCPY_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}"; \ - fi +RUN echo "Build Argument METVIEWER_GIT_NAME=${METVIEWER_GIT_NAME}" \ + && echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}" \ + && echo "Build Argument METCALCPY_GIT_NAME=${METCALCPY_GIT_NAME}" \ + && echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}" # -# METPLOTPY_GIT_NAME is required. +# Repository URLs # -RUN if [ "x${METPLOTPY_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METPLOTPY_GIT_NAME undefined! Rebuild with \"--build-arg METPLOTPY_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METPLOTPY_GIT_NAME=${METPLOTPY_GIT_NAME}"; \ - fi +ENV METVIEWER_GIT_URL https://github.com/dtcenter/METviewer +ENV METPLOTPY_GIT_URL https://github.com/dtcenter/METplotpy +ENV METCALCPY_GIT_URL https://github.com/dtcenter/METcalcpy +ENV METDATAIO_GIT_URL https://github.com/dtcenter/METdataio # -# METDATAIO_GIT_NAME is required. +# Constants # -RUN if [ "x${METDATAIO_GIT_NAME}" = "x" ]; then \ - echo "ERROR: METDATAIO_GIT_NAME undefined! Rebuild with \"--build-arg METDATAIO_GIT_NAME={branch, tag, or hash}\""; \ - exit 1; \ - else \ - echo "Build Argument METDATAIO_GIT_NAME=${METDATAIO_GIT_NAME}"; \ - fi +ENV TOMCAT_MINOR_VERSION 5.61 +ENV TOMCAT_MAJOR_VERSION 8 +ENV TOMCAT_VERSION ${TOMCAT_MAJOR_VERSION}.${TOMCAT_MINOR_VERSION} # # Install system updates @@ -89,8 +64,7 @@ RUN yum -y install wget tar git ant R mysql ksh \ && rm -rf /var/cache/yum/* \ && yum clean all -RUN yum install java-1.8.0-openjdk-devel - +RUN yum install java-1.8.0-openjdk-devel # # Install gsl-2.5 on which the R gsl package depends. @@ -138,13 +112,11 @@ RUN mkdir /METviewer-python \ WORKDIR /METviewer-python/ RUN git clone --branch ${METCALCPY_GIT_NAME} ${METCALCPY_GIT_URL} - RUN echo "Checking out METplotpy ${METPLOTPY_GIT_NAME} from ${METPLOTPY_GIT_URL}" WORKDIR /METviewer-python/ RUN git clone --branch ${METPLOTPY_GIT_NAME} ${METPLOTPY_GIT_URL} - -RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" \ +RUN echo "Checking out METdataio ${METDATAIO_GIT_NAME} from ${METDATAIO_GIT_URL}" WORKDIR /METviewer-python/ RUN git clone --branch ${METDATAIO_GIT_NAME} ${METDATAIO_GIT_URL} @@ -202,7 +174,6 @@ RUN git clone --branch ${METVIEWER_GIT_NAME} ${METVIEWER_GIT_URL} /METviewer \ > mv_prune.sh-DOCKER \ && mv mv_prune.sh-DOCKER mv_prune.sh - # # Install Python 3.10.4 # @@ -235,9 +206,8 @@ RUN ln -sf /usr/bin/python3 /usr/bin/python RUN ln -sf /usr/local/bin/pip3.10 /usr/bin/pip3 RUN ln -sf /usr/bin/pip3 /usr/bin/pip - # -# install GEOS - needed for cartopy +# Install GEOS - needed for cartopy # WORKDIR /tmp RUN wget http://download.osgeo.org/geos/geos-3.7.2.tar.bz2 @@ -249,7 +219,6 @@ RUN ldconfig WORKDIR /tmp RUN rm -r geos-3.7.2.tar.bz2 - # # Install Python packages # @@ -286,34 +255,32 @@ RUN pip install cartopy \ && pip install opencv-python \ && pip install pandas==1.5.2 - - # -# set env vars +# Set env vars # ENV PYTHONPATH "${PYTHONPATH}:/METviewer-python/METcalcpy/:/METviewer-python/METplotpy/" ENV METPLOTPY_BASE "/METviewer-python/METplotpy/" - -# remove unneeded scripts +# +# Remove unneeded scripts +# RUN rm /METviewer/bin/auto_test.sh \ - && rm /METviewer/bin/mv_test.sh \ - && rm /METviewer/bin/nightly_test.sh \ - && rm /METviewer/bin/prep_dist.sh \ - && rm /METviewer/bin/mv_compare.sh \ - && rm -r /METviewer/test + && rm /METviewer/bin/mv_test.sh \ + && rm /METviewer/bin/nightly_test.sh \ + && rm /METviewer/bin/prep_dist.sh \ + && rm /METviewer/bin/mv_compare.sh \ + && rm -r /METviewer/test # -# Change permission on exe's +# Change permissions of the scripts # RUN chmod 755 /METviewer/bin/mv_batch.sh \ - && chmod 755 /METviewer/bin/mv_load.sh \ - && chmod 755 /METviewer/bin/mv_prune.sh \ - && chmod 755 /METviewer/bin/mv_scorecard.sh - + && chmod 755 /METviewer/bin/mv_load.sh \ + && chmod 755 /METviewer/bin/mv_prune.sh \ + && chmod 755 /METviewer/bin/mv_scorecard.sh # -# database install +# Database install # # @@ -321,9 +288,9 @@ RUN chmod 755 /METviewer/bin/mv_batch.sh \ # COPY fix-permissions.sh ./ RUN chmod 777 ./fix-permissions.sh -RUN ./fix-permissions.sh /var/lib/mysql/ && \ - ./fix-permissions.sh /var/log/mariadb/ && \ - ./fix-permissions.sh /var/run/ +RUN ./fix-permissions.sh /var/lib/mysql/ \ + && ./fix-permissions.sh /var/log/mariadb/ \ + && ./fix-permissions.sh /var/run/ COPY docker-entrypoint.sh / RUN chmod 777 /docker-entrypoint.sh From 6a67d0e67412ce9d418ff2d866832df2fe8d0374 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 15:31:34 -0600 Subject: [PATCH 21/23] Per #521, remove feature_521_develop_sonarqube_gha branch name from sonarqube.xml I'd added to use for testing. --- .github/workflows/sonarqube.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.github/workflows/sonarqube.yml b/.github/workflows/sonarqube.yml index ab68a04b..3e85000e 100644 --- a/.github/workflows/sonarqube.yml +++ b/.github/workflows/sonarqube.yml @@ -9,7 +9,6 @@ on: branches: - develop - 'main_v**' - - feature_521_develop_sonarqube_gha paths-ignore: - 'docs/**' - '.github/pull_request_template.md' @@ -23,7 +22,6 @@ on: branches: - develop - 'main_v**' - - feature_521_develop_sonarqube_gha paths-ignore: - 'docs/**' - '.github/pull_request_template.md' From 10ff9b13c256c54e3975b9509fa9313725bc2266 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 15:40:14 -0600 Subject: [PATCH 22/23] Per #521, singularity is named apptainer, as of 2021 --- .../docker/{Dockerfile.singularity => Dockerfile.apptainer} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename internal/scripts/docker/{Dockerfile.singularity => Dockerfile.apptainer} (100%) diff --git a/internal/scripts/docker/Dockerfile.singularity b/internal/scripts/docker/Dockerfile.apptainer similarity index 100% rename from internal/scripts/docker/Dockerfile.singularity rename to internal/scripts/docker/Dockerfile.apptainer From 50f55771cc36261ce1a6081178624cb18e604cc9 Mon Sep 17 00:00:00 2001 From: John Halley Gotway Date: Fri, 19 Apr 2024 16:11:22 -0600 Subject: [PATCH 23/23] Per #521, more work is needed in the DockerHub build hook. For now, switch to building against the develop version of the dependencies. --- internal/scripts/docker/hooks/build | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/internal/scripts/docker/hooks/build b/internal/scripts/docker/hooks/build index 631634c8..53917e2b 100644 --- a/internal/scripts/docker/hooks/build +++ b/internal/scripts/docker/hooks/build @@ -1,8 +1,13 @@ #!/bin/bash +# TODO: Add logic for handling dependencies +# - develop or branches from develop should build against develop +# - main_vX.Y or branches from main_vX.Y should build against main_v{X-3}.Y +# - vX.Y.Z tags should build against v{X-3}.Y.? tags + docker build -t $IMAGE_NAME \ ---build-arg METVIEWER_GIT_NAME=v6.0.0-beta1 \ ---build-arg METCALCPY_GIT_NAME=v3.0.0-beta1 \ ---build-arg METDATAIO_GIT_NAME=v3.0.0-beta1 \ ---build-arg METPLOTPY_GIT_NAME=v3.0.0-beta1 . +--build-arg METVIEWER_GIT_NAME=$SOURCE_BRANCH \ +--build-arg METCALCPY_GIT_NAME=develop \ +--build-arg METDATAIO_GIT_NAME=develop \ +--build-arg METPLOTPY_GIT_NAME=develop .