From ee0cde6df98f9c48e8612ffbf336bac6f6b873ae Mon Sep 17 00:00:00 2001 From: John Omotani Date: Wed, 2 Oct 2024 17:39:59 +0100 Subject: [PATCH] On CI server, don't use /tmp/ for output files Putting files in "/tmp/" on the Github Actions CI servers seems to cause occasional failures of the tests. Instead, put the test output files in subdirectories of "runs/", but only when running on the CI server - otherwise still use "/tmp/" as normal. --- .github/workflows/longtest.yml | 2 +- .github/workflows/parallel_test.yml | 8 ++++---- .github/workflows/test.yml | 2 +- moment_kinetics/src/command_line_options.jl | 3 +++ moment_kinetics/test/setup.jl | 8 +++++++- 5 files changed, 16 insertions(+), 7 deletions(-) diff --git a/.github/workflows/longtest.yml b/.github/workflows/longtest.yml index 55daca762..8d4990bb6 100644 --- a/.github/workflows/longtest.yml +++ b/.github/workflows/longtest.yml @@ -30,5 +30,5 @@ jobs: # https://github.com/julia-actions/julia-runtest/blob/master/action.yml # in order to pass customised arguments to `Pkg.test()` - run: | - julia --check-bounds=yes --color=yes --depwarn=yes --project=moment_kinetics/ -e 'import Pkg; Pkg.test(; test_args=["--long", "--force-optional-dependencies"])' + julia --check-bounds=yes --color=yes --depwarn=yes --project=moment_kinetics/ -e 'import Pkg; Pkg.test(; test_args=["--ci", "--long", "--force-optional-dependencies"])' shell: bash diff --git a/.github/workflows/parallel_test.yml b/.github/workflows/parallel_test.yml index df1ccf121..9520c3c72 100644 --- a/.github/workflows/parallel_test.yml +++ b/.github/workflows/parallel_test.yml @@ -26,9 +26,9 @@ jobs: julia --project -O3 --check-bounds=no -e 'import Pkg; Pkg.add(["Random", "SpecialFunctions", "Test"]); Pkg.develop(path="moment_kinetics/")' julia --project -O3 --check-bounds=no -e 'import Pkg; Pkg.precompile()' # Need to use openmpi so that we can use `--oversubscribe` to allow using more MPI ranks than physical cores - ./mpiexecjl -np 3 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --debug 1 - ./mpiexecjl -np 4 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --debug 1 - ./mpiexecjl -np 2 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --debug 1 --long + ./mpiexecjl -np 3 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --ci --debug 1 + ./mpiexecjl -np 4 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --ci --debug 1 + ./mpiexecjl -np 2 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --ci --debug 1 --long # Note: MPI.jl's default implementation is mpich, which has a similar option # `--with-device=ch3:sock`, but that needs to be set when compiling mpich. shell: bash @@ -51,7 +51,7 @@ jobs: julia --project -O3 --check-bounds=no -e 'import Pkg; Pkg.add(["Random", "SpecialFunctions", "Test"]); Pkg.develop(path="moment_kinetics/")' julia --project -O3 --check-bounds=no -e 'import Pkg; Pkg.precompile()' # Need to use openmpi so that we can use `--oversubscribe` to allow using more MPI ranks than physical cores - ./mpiexecjl -np 4 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --debug 1 + ./mpiexecjl -np 4 --oversubscribe julia --project -O3 --check-bounds=no moment_kinetics/test/runtests.jl --ci --debug 1 # Note: MPI.jl's default implementation is mpich, which has a similar option # `--with-device=ch3:sock`, but that needs to be set when compiling mpich. shell: bash diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index e75372944..bb5948b5f 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -29,5 +29,5 @@ jobs: # https://github.com/julia-actions/julia-runtest/blob/master/action.yml # in order to pass customised arguments to `Pkg.test()` - run: | - julia --check-bounds=yes --color=yes --depwarn=yes --project=moment_kinetics/ -e 'import Pkg; Pkg.test(; test_args=["--force-optional-dependencies"])' + julia --check-bounds=yes --color=yes --depwarn=yes --project=moment_kinetics/ -e 'import Pkg; Pkg.test(; test_args=["--ci", "--force-optional-dependencies"])' shell: bash diff --git a/moment_kinetics/src/command_line_options.jl b/moment_kinetics/src/command_line_options.jl index 3586927c4..d7b25272f 100644 --- a/moment_kinetics/src/command_line_options.jl +++ b/moment_kinetics/src/command_line_options.jl @@ -42,6 +42,9 @@ const s = ArgParseSettings() "--verbose", "-v" help = "Print verbose output from tests." action = :store_true + "--ci" + help = "Indicates that tests are running on the CI server." + action = :store_true # Options for performance tests and plotting "--machine-name" help = "Which machine to plot for when using plot_performance.jl?" diff --git a/moment_kinetics/test/setup.jl b/moment_kinetics/test/setup.jl index 7e9ec9cc8..f6afd7aef 100644 --- a/moment_kinetics/test/setup.jl +++ b/moment_kinetics/test/setup.jl @@ -90,7 +90,13 @@ Get a single temporary directory that is the same on all MPI ranks """ function get_MPI_tempdir() if global_rank[] == 0 - test_output_directory = tempname() + if get_options()["ci"] + runs_dir = abspath("runs/") + mkpath(runs_dir) + test_output_directory = tempname(runs_dir) + else + test_output_directory = tempname() + end mkpath(test_output_directory) else test_output_directory = ""