-
Notifications
You must be signed in to change notification settings - Fork 117
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Revised some functions and sub-routines in numutils.f90 for improved …
…numerical stability and approaches. Merge branch 'mainline' into mpaiao-pr-quadratic
- Loading branch information
Showing
250 changed files
with
23,059 additions
and
11,666 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,71 +1,51 @@ | ||
name: CI | ||
|
||
on: [push, pull_request] | ||
on: | ||
push: | ||
branches: | ||
- master | ||
- main | ||
|
||
pull_request: | ||
|
||
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v1 | ||
- uses: actions/checkout@v4 | ||
- name: Install dependencies | ||
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev | ||
- name: Install ED2 | ||
run: | | ||
cd ED/build | ||
./install.sh -g -p travisci -k A | ||
- name: Upload compiled ED2 binary | ||
uses: actions/upload-artifact@v1 | ||
uses: actions/upload-artifact@v4 | ||
with: | ||
name: ed2-binary | ||
path: ED/build/ed_2.2-dbg | ||
|
||
test-umbs-bg: | ||
needs: build | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v1 | ||
- name: Retrieve compiled binary | ||
uses: actions/download-artifact@v1 | ||
with: | ||
name: ed2-binary | ||
- name: Install dependencies | ||
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev | ||
- name: Run ED2 | ||
working-directory: ./EDTS/ | ||
run: | | ||
chmod +x "$GITHUB_WORKSPACE"/ed2-binary/ed_2.2-dbg | ||
./run-test.sh umbs.bg "$GITHUB_WORKSPACE/ed2-binary/ed_2.2-dbg" | ||
test-tonzi: | ||
tests: | ||
needs: build | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v1 | ||
- name: Retrieve compiled binary | ||
uses: actions/download-artifact@v1 | ||
with: | ||
name: ed2-binary | ||
- name: Install dependencies | ||
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev | ||
- name: Run ED2 | ||
working-directory: ./EDTS/ | ||
run: | | ||
chmod +x "$GITHUB_WORKSPACE"/ed2-binary/ed_2.2-dbg | ||
./run-test.sh tonzi "$GITHUB_WORKSPACE/ed2-binary/ed_2.2-dbg" | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
name: | ||
- umbs.bg | ||
- tonzi | ||
- tonzi.harvest | ||
|
||
test-tonzi-harvest: | ||
needs: build | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v1 | ||
- uses: actions/checkout@v4 | ||
- name: Retrieve compiled binary | ||
uses: actions/download-artifact@v1 | ||
uses: actions/download-artifact@v4 | ||
with: | ||
name: ed2-binary | ||
- name: Install dependencies | ||
run: sudo apt-get install -y --no-install-recommends gfortran libhdf5-openmpi-dev libopenmpi-dev | ||
- name: Run ED2 | ||
working-directory: ./EDTS/ | ||
run: | | ||
chmod +x "$GITHUB_WORKSPACE"/ed2-binary/ed_2.2-dbg | ||
./run-test.sh tonzi.harvest "$GITHUB_WORKSPACE/ed2-binary/ed_2.2-dbg" | ||
chmod +x "$GITHUB_WORKSPACE"/ed_2.2-dbg | ||
./run-test.sh ${{ matrix.name }} "$GITHUB_WORKSPACE/ed_2.2-dbg" |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,7 @@ | ||
name: Docker | ||
|
||
# This will run when: | ||
# - when new code is pushed to master to push the tags latest. | ||
# - when new code is pushed to master/main to push the tags latest. | ||
# - when a pull request is created and updated to make sure the | ||
# Dockerfile is still valid. | ||
|
||
|
@@ -19,77 +19,189 @@ on: | |
push: | ||
branches: | ||
- master | ||
- main | ||
|
||
release: | ||
types: | ||
- published | ||
|
||
pull_request: | ||
|
||
# Certain actions will only run when this is the master repo. | ||
# Certain actions will only run when this is the master/main repo. | ||
env: | ||
MASTER_REPO: EDModel/ED2 | ||
DOCKERHUB_ORG: pecan | ||
MAIN_REPO: EDmodel/ED2 | ||
DOCKERHUB_ORG: edmodel | ||
|
||
jobs: | ||
docker: | ||
runs-on: ubuntu-latest | ||
permissions: | ||
packages: write | ||
|
||
strategy: | ||
fail-fast: false | ||
matrix: | ||
include: | ||
- name: gnu | ||
PLATFORM: "linux/amd64,linux/arm64" | ||
- name: intel | ||
PLATFORM: "linux/amd64" | ||
|
||
steps: | ||
- uses: actions/checkout@v2 | ||
- uses: actions/checkout@v4 | ||
|
||
# free up space | ||
- name: Free Disk Space (Ubuntu) | ||
uses: jlumbroso/free-disk-space@main | ||
with: | ||
tool-cache: true | ||
android: true | ||
dotnet: true | ||
haskell: true | ||
large-packages: true | ||
docker-images: false | ||
swap-storage: true | ||
|
||
# calculate some variables that are used later | ||
- name: github branch | ||
- name: version information | ||
run: | | ||
BRANCH=${GITHUB_REF##*/} | ||
if [ "$BRANCH" == "master" ]; then | ||
TAGS="latest" | ||
# find out what the BRANCH is, in case of a PR we will use the PR-<number> | ||
if [ "${{ github.event.release.target_commitish }}" != "" ]; then | ||
BRANCH="${{ github.event.release.target_commitish }}" | ||
elif [[ $GITHUB_REF =~ pull ]]; then | ||
BRANCH="$(echo $GITHUB_REF | sed 's#refs/pull/\([0-9]*\)/merge#PR-\1#')" | ||
else | ||
TAGS="$BRANCH" | ||
BRANCH=${GITHUB_REF##*/} | ||
fi | ||
echo "TAGS=${TAGS}" >> $GITHUB_ENV | ||
echo "GITHUB_BRANCH=${BRANCH}" >> $GITHUB_ENV | ||
# build the docker image, this will always run to make sure | ||
# the Dockerfile still works. | ||
- name: Build image | ||
uses: elgohr/[email protected] | ||
env: | ||
BRANCH: ${{ env.GITHUB_BRANCH }} | ||
BUILDNUMBER: ${{ github.run_number }} | ||
GITSHA1: ${{ github.sha }} | ||
# calculate the version and all tags | ||
if [ "$BRANCH" == "main" -o "$BRANCH" == "master" ]; then | ||
VERSION="latest" | ||
tags="${{ matrix.name }}" | ||
if [ "${{ matrix.name }}" == "intel" ]; then | ||
tags="${tags} latest" | ||
fi | ||
else | ||
VERSION="${{ matrix.name }}-$BRANCH" | ||
tags="${{ matrix.name }}-$BRANCH" | ||
fi | ||
# should we push to dockerhub, and is there a README | ||
DOCKERHUB_PUSH="false" | ||
DOCKERHUB_README="false" | ||
if [ "${{ github.repository }}" == "${{ env.MAIN_REPO }}" ]; then | ||
if [ "${{ secrets.DOCKERHUB_USERNAME }}" != "" -a "${{ secrets.DOCKERHUB_PASSWORD }}" != "" ]; then | ||
DOCKERHUB_PUSH="true" | ||
if [ -e "README.md" ]; then | ||
DOCKERHUB_README="true" | ||
fi | ||
fi | ||
fi | ||
# create a list of all images to be pushed | ||
REPO="${{ github.repository_owner }}" | ||
REPO="${REPO,,}" | ||
IMAGE="${{ github.event.repository.name }}" | ||
IMAGE="${IMAGE,,}" | ||
DEV_IMAGES="" | ||
IMAGES="" | ||
for tag in ${tags}; do | ||
if [ "$DOCKERHUB_PUSH" == "true" ]; then | ||
DEV_IMAGES="${DEV_IMAGES}${{ env.DOCKERHUB_ORG }}/${IMAGE}-dev:${tag}," | ||
IMAGES="${IMAGES}${{ env.DOCKERHUB_ORG }}/${IMAGE}:${tag}," | ||
fi | ||
DEV_IMAGES="${DEV_IMAGES}ghcr.io/${REPO}/${IMAGE}-dev:${tag}," | ||
IMAGES="${IMAGES}ghcr.io/${REPO}/${IMAGE}:${tag}," | ||
done | ||
IMAGES="${IMAGES%,*}" | ||
# save the results in env | ||
echo "BRANCH=${BRANCH}" | ||
echo "VERSION=${VERSION}" | ||
echo "DOCKERHUB_README=${DOCKERHUB_README}" | ||
echo "DOCKERHUB_PUSH=${DOCKERHUB_PUSH}" | ||
echo "IMAGES=${IMAGES}" | ||
echo "BRANCH=${BRANCH}" >> $GITHUB_ENV | ||
echo "VERSION=${VERSION}" >> $GITHUB_ENV | ||
echo "DOCKERHUB_README=${DOCKERHUB_README}" >> $GITHUB_ENV | ||
echo "DOCKERHUB_PUSH=${DOCKERHUB_PUSH}" >> $GITHUB_ENV | ||
echo "DEV_IMAGES=${DEV_IMAGES}" >> $GITHUB_ENV | ||
echo "IMAGES=${IMAGES}" >> $GITHUB_ENV | ||
# setup docker build | ||
- name: Set up QEMU | ||
uses: docker/setup-qemu-action@v3 | ||
|
||
- name: Set up Docker Buildx | ||
id: buildx | ||
uses: docker/setup-buildx-action@v3 | ||
|
||
- name: Inspect Builder | ||
run: | | ||
echo "Name: ${{ steps.buildx.outputs.name }}" | ||
echo "Endpoint: ${{ steps.buildx.outputs.endpoint }}" | ||
echo "Status: ${{ steps.buildx.outputs.status }}" | ||
echo "Flags: ${{ steps.buildx.outputs.flags }}" | ||
echo "Platforms: ${{ steps.buildx.outputs.platforms }}" | ||
# login to registries | ||
- name: Login to DockerHub | ||
if: env.DOCKERHUB_PUSH == 'true' | ||
uses: docker/login-action@v3 | ||
with: | ||
username: ${{ secrets.DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.DOCKERHUB_PASSWORD }} | ||
|
||
- name: Login to GitHub Container Registry | ||
uses: docker/login-action@v3 | ||
with: | ||
registry: docker.pkg.github.com | ||
name: ${{ github.repository_owner }}/${{ github.event.repository.name }}/ed | ||
registry: ghcr.io | ||
username: ${{ github.actor }} | ||
password: ${{ secrets.GITHUB_TOKEN }} | ||
tags: "${{ env.TAGS }}" | ||
buildargs: BRANCH,BUILDNUMBER,GITSHA1 | ||
no_push: true | ||
|
||
# this will publish to github container registry | ||
- name: Publish to GitHub | ||
if: github.event_name == 'push' && github.repository == env.MASTER_REPO | ||
uses: elgohr/[email protected] | ||
env: | ||
BRANCH: ${{ env.GITHUB_BRANCH }} | ||
BUILDNUMBER: ${{ github.run_number }} | ||
GITSHA1: ${{ github.sha }} | ||
|
||
- name: DF | ||
run: df -h . | ||
|
||
# build the dev docker images | ||
- name: Build and push docker | ||
uses: docker/build-push-action@v6 | ||
with: | ||
registry: ghcr.io | ||
name: ${{ github.repository_owner }}/ed | ||
username: ${{ secrets.GHCR_USERNAME }} | ||
password: ${{ secrets.GHCR_PASSWORD }} | ||
tags: "${{ env.TAGS }}" | ||
buildargs: BRANCH,BUILDNUMBER,GITSHA1 | ||
|
||
# this will publish to the pecan dockerhub repo | ||
- name: Publish to Docker Hub | ||
if: github.event_name == 'push' && github.repository == env.MASTER_REPO | ||
uses: elgohr/[email protected] | ||
env: | ||
BRANCH: ${{ env.GITHUB_BRANCH }} | ||
BUILDNUMBER: ${{ github.run_number }} | ||
GITSHA1: ${{ github.sha }} | ||
push: true | ||
platforms: ${{ matrix.PLATFORM }} | ||
file: Dockerfile.${{ matrix.name }} | ||
target: build | ||
cache-from: type=gha,scope=ed-${{ matrix.name }}-build | ||
cache-to: type=gha,scope=ed-${{ matrix.name }}-build,mode=max | ||
tags: ${{ env.DEV_IMAGES }} | ||
build-args: | | ||
BRANCH: ${{ env.BRANCH }} | ||
VERSION=${{ env.VERSION }} | ||
BUILDNUMBER=${{ github.run_number }} | ||
GITSHA1=${{ github.sha }} | ||
# build the docker images | ||
- name: Build and push docker | ||
uses: docker/build-push-action@v6 | ||
with: | ||
name: ${{ env.DOCKERHUB_ORG }}/ed | ||
username: ${{ secrets.DOCKERHUB_USERNAME }} | ||
password: ${{ secrets.DOCKERHUB_PASSWORD }} | ||
tags: "${{ env.TAGS }}" | ||
buildargs: BRANCH,BUILDNUMBER,GITSHA1 | ||
push: true | ||
platforms: ${{ matrix.PLATFORM }} | ||
file: Dockerfile.${{ matrix.name }} | ||
cache-from: type=gha,scope=ed-${{ matrix.name }}-build | ||
cache-to: type=gha,scope=ed-${{ matrix.name }}-build,mode=max | ||
tags: ${{ env.IMAGES }} | ||
build-args: | | ||
BRANCH: ${{ env.BRANCH }} | ||
VERSION=${{ env.VERSION }} | ||
BUILDNUMBER=${{ github.run_number }} | ||
GITSHA1=${{ github.sha }} | ||
# this will update the README of the dockerhub repo | ||
- name: Docker Hub Description | ||
if: env.DOCKERHUB_README == 'true' | ||
uses: peter-evans/dockerhub-description@v4 | ||
env: | ||
DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }} | ||
DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_PASSWORD }} | ||
DOCKERHUB_REPOSITORY: ${{ env.DOCKERHUB_ORG }}/${{ github.event.repository.name }} | ||
README_FILEPATH: README.md |
Oops, something went wrong.