Skip to content

A portable test suite for software installations, using ReFrame

License

Notifications You must be signed in to change notification settings

EESSI/test-suite

Repository files navigation

test-suite

A portable test suite for software installations, using ReFrame.

Documentation

For documentation on installing, configuring, and using the EESSI test suite, see https://eessi.io/docs/test-suite/.

Development

If you want to install the EESSI test suite from a branch, you can either install the feature branch with pip, or clone the Github repository and check out the feature branch.

Install from branch with pip

To install from one of the branches of the main repository, use:

pip install git+https://github.com/EESSI/test-suite.git@branchname

Generally, you'll want to do this from a forked repository though, where someone worked on a feature. E.g.

pip install git+https://github.com/<someuser>/test-suite.git@branchname

Check out a feature branch from a fork

We'll assume you already have a local clone of the official test-suite repository, called 'origin'. In that case, executing git remote -v, you should see:

$ git remote -v
origin  [email protected]:EESSI/test-suite.git (fetch)
origin  [email protected]:EESSI/test-suite.git (push)

Option 1: Creating a branch from the PR directly

git fetch origin pull/ID/head:BRANCH_NAME

where ID is the number of the pull request, and BRANCH_NAME is the name of the local branch (you can pick this yourself).

Option 2: Creating a branch tracking the feature branch

You can add a fork to your local clone by adding a new remote. Pick a name for the remote that you find easy to recognize. E.g. to add the fork https://github.com/casparvl/test-suite and give it the (local) name casparvl, run:

git remote add casparvl [email protected]:casparvl/test-suite.git

With git remote -v you should now see the new remote:

$ git remote -v
origin    [email protected]:EESSI/test-suite.git (fetch)
origin    [email protected]:EESSI/test-suite.git (push)
casparvl  [email protected]:casparvl/test-suite.git (fetch)
casparvl  [email protected]:casparvl/test-suite.git (push)

Next, we'll fetch the branches that casparvl has in his fork:

$ git fetch casparvl

We can check the remote branches using

$ git branch --list --remotes
  casparvl/example_branch
  casparvl/main
  origin/HEAD -> origin/main
  origin/main

(remember to re-run git fetch <remote> if new branches don't show up with this command).

Finally, we can create a new local branch (-c) and checkout one of these feature branches (e.g. example_branch from the remote casparvl). Here, we've picked my_own_example_branch as the local branch name:

$ git switch -c my_own_example_branch casparvl/example_branch

While the initial setup is a bit more involved, the advantage of this approach is that it is easy to pull in updates from a feature branch using git pull.

You can also push back changes to the feature branch directly, but note that you are pushing to the Github fork of another Github user, so make sure they are ok with that before doing so!

Release management

When a release of the EESSI test suite is made, the following things must be taken care of:

  • Version bump the fallback_version in pyproject.toml;
  • Version bump the default EESSI_TESTSUITE_BRANCH in CI/run_reframe.sh;
  • Create release notes PR: an easy way to get an overview of PRs since the latest release is using figuring out the date of the latest tag, and check all merged PRs since then (e.g. is:pr is:closed merged:2024-09-25..2025-01-23) (cfr. #231)
  • Merge release notes PR (N.B. the CI test checking the fallback_version against the latest tagged version will fail, this is a chicken-and-egg problem, so we just have to merge anyway)
  • Click 'Draft a new release' on https://github.com/EESSI/test-suite/releases . In the process, create a new tag, and copy the release nodes into the text box. Save as draft, check it, then publish the release.
  • Publishing release to PyPI:
    # example for version 0.5.0
    git clone https://github.com/EESSI/test-suite.git --branch v0.5.0
    python setup.py sdist
    
    Note that it is important that this step is done after the tag is created in the repository, since setuptools_scm uses it to determine the version. Check that the automatically generated version matches with the tag you just created. Then, upload to pypi:
    twine upload dist/eessi_testsuite-0.5.0.tar.gz
    
    Note that for this, you need to have a pipy account, be registered as a maintainer of eessi-testsuite on PyPI (see 'Maintainers' at https://pypi.org/project/eessi-testsuite/). You also need an API token to be created under https://pypi.org/manage/account/ and put it in a .pypirc file (see e.g. https://kynan.github.io/blog/2020/05/23/how-to-upload-your-package-to-the-python-package-index-pypi-test-server for instructions).