spack ci: add support for running stand-alone tests (#27877)
This support requires adding the '--tests' option to 'spack ci rebuild'. Packages whose stand-alone tests are broken (in the CI environment) can be configured in gitlab-ci to be skipped by adding them to broken-tests-packages. Highlights include: - Restructured 'spack ci' help to provide better subcommand summaries; - Ensured only one InstallError (i.e., installer's) rather than allowing build_environment to have its own; and - Refactored CI and CDash reporting to keep CDash-related properties and behavior in a separate class. This allows stand-alone tests from `spack ci` to run when the `--tests` option is used. With `--tests`, stand-alone tests are run **after** a **successful** (re)build of the package. Test results are collected and report(able) using CDash. This PR adds the following features: - Adds `-t` and `--tests` to `spack ci rebuild` to run stand-alone tests; - Adds `--fail-fast` to stop stand-alone tests after the first failure; - Ensures a *single* `InstallError` across packages (i.e., removes second class from build environment); - Captures skipping tests for externals and uninstalled packages (for CDash reporting); - Copies test logs and outputs to the CI artifacts directory to facilitate debugging; - Parses stand-alone test results to report outputs from each `run_test` as separate test parts (CDash reporting); - Logs a test completion message to allow capture of timing of the last `run_test` part; - Adds the runner description to the CDash site to better distinguish entries in CDash tables; - Adds `gitlab-ci` `broken-tests-packages` to CI configuration to skip stand-alone testing for packages with known issues; - Changes `spack ci --help` so description of each subcommand is a single line; - Changes `spack ci <subcommand> --help` to provide the full description of each command (versus no description); and - Ensures `junit` test log file ends in an `.xml` extension (versus default where it does not). Tasks: - [x] Include the equivalent of the architecture information, or at least the host target, in the CDash output - [x] Upload stand-alone test results files as `test` artifacts - [x] Confirm tests are run in GitLab - [x] Ensure CDash results are uploaded as artifacts - [x] Resolve issues with CDash build-and test results appearing on same row of the table - [x] Add unit tests as needed - [x] Investigate why some (dependency) packages don't have test results (e.g., related from other pipelines) - [x] Ensure proper parsing and reporting of skipped tests (as `not run`) .. post- #28701 merge - [x] Restore the proper CDash URLand or mirror ONCE out-of-band testing completed
This commit is contained in:
@@ -2,6 +2,9 @@
|
||||
<Site BuildName="{{ buildname }}"
|
||||
BuildStamp="{{ buildstamp }}"
|
||||
Name="{{ site }}"
|
||||
Generator="{{ generator }}"
|
||||
Hostname="{{ hostname }}"
|
||||
OSName="{{ osname }}"
|
||||
OSRelease="{{ osrelease }}"
|
||||
VendorString="{{ target }}"
|
||||
>
|
||||
|
||||
|
44
share/spack/templates/reports/cdash/Testing.xml
Normal file
44
share/spack/templates/reports/cdash/Testing.xml
Normal file
@@ -0,0 +1,44 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<!--
|
||||
This file has been modeled after the examples at this url:
|
||||
|
||||
https://www.paraview.org/Wiki/CDash:XML
|
||||
-->
|
||||
<Site BuildName="{{ buildname }}"
|
||||
BuildStamp="{{ buildstamp }}"
|
||||
Name="{{ site }}"
|
||||
Generator="{{ generator }}"
|
||||
Hostname="{{ hostname }}"
|
||||
OSName="{{ osname }}"
|
||||
OSRelease="{{ osrelease }}"
|
||||
VendorString="{{ target }}"
|
||||
>
|
||||
<Testing>
|
||||
<StartTestTime>{{ testing.starttime }}</StartTestTime>
|
||||
{% for part in testing.parts %}
|
||||
<Test Status="{{ part.status }}">
|
||||
<Name>{{ part.name }}</Name>
|
||||
<FullCommandLine>{{ part.command }}</FullCommandLine>
|
||||
<Results>
|
||||
<NamedMeasurement type="numeric/double" name="Execution Time">
|
||||
<Value>{{ part.elapsed }}</Value>
|
||||
</NamedMeasurement>
|
||||
{% if part.desc %}
|
||||
<NamedMeasurement type="text/string" name="Description">
|
||||
<Value>{{ part.desc }}</Value>
|
||||
</NamedMeasurement>
|
||||
{% endif %}
|
||||
<NamedMeasurement type="text/string" name="Completion Status">
|
||||
<Value>{{ part.completed }}</Value>
|
||||
</NamedMeasurement>
|
||||
{% if part.output %}
|
||||
<Measurement>
|
||||
<Value>{{ part.output }}</Value>
|
||||
</Measurement>
|
||||
{% endif %}
|
||||
</Results>
|
||||
</Test>
|
||||
{% endfor %}
|
||||
<EndTestTime>{{ testing.endtime }}</EndTestTime>
|
||||
</Testing>
|
||||
</Site>
|
Reference in New Issue
Block a user