[clang] [llvm] [ci] New script to generate test reports as Buildkite Annotations (PR #113447)
David Spickett via llvm-commits
llvm-commits at lists.llvm.org
Mon Oct 28 09:50:09 PDT 2024
DavidSpickett wrote:
I tried a few more things, so I will summarise everything up until this point. There are two layers here:
1. Making test reports.
2. Producing the XML test results.
Using the buildkite plugin is not an option (https://github.com/llvm/llvm-project/pull/113290) because we'd need docker or a fork of the plugin. Our own test reporting script is the only way to generate the reports. This decides `#1`, unless we want to leave it as is until the move to GitHub actions.
For `#2` the following ideas don't work:
* `tail ---follow --retry results_file > combined_results_file`, then splitting it up in the reporting script
* Does not work because tail does not print the whole file on truncation. We would miss data.
* `mkfifo` and a listener script to write it out to unique files (https://github.com/llvm/llvm-project/pull/113703)
* Works great on Linux but -
* `mkfifo` fails silently in bash for Windows. There are no plans to fix that any time soon.
* I could try https://learn.microsoft.com/en-us/windows/win32/ipc/named-pipes, but I suspect this would be even more code, and folks are already wary of adding too much to this system as it is.
* Using `ninja check-all`
* Does not allow us to disable testing of a project, but still build it.
* Does not help with runtimes tests that are separate builds.
These could work but have tradeoffs:
* Using the lit feature `--unique-output...` (this PR)
* Built into lit (for now).
* Minimal changes to scripts and pipeline.
* New arguments for LLVM_LIT_ARGS.
* Run the report generator on exit.
* Risk of exposing an option publicly that we no longer need when the pipeline is re-written.
* I could RFC that option and drum up interest in it from other users and external projects, if that would help. I have not done so up to now because it might have looked like I was trying to bias this discussion.
* Changing the build scripts to `ninja target` `mv result_file unique_name` in a loop (https://github.com/llvm/llvm-project/pull/113660)
* The most script changes of any solution.
* No changes to report generator.
* Small bonus - result files are named after their check target (though I wonder if some check targets run lit multiple times, in which case this is actually a bug not a bonus).
* Wrapping lit in a Python script that will catch the output file name argument, run lit, then move the file to a unique name (https://github.com/llvm/llvm-project/pull/113896)
* It works, albeit in a fiddly way because of differences in `.py` or not between Windows and Linux.
* We have to re-wrap lit every time cmake is run (what I have implemented) or -
* We configure in another directory, patch that lit, and configure with `-DLLVM_EXTERNAL_LIT=<path to the other lit>` (which I have yet to test)
* We're not using the actual lit, though the chances of a regression because of that are pretty low. `ninja check-lit` does still work, so though we aren't testing what we ship, it's pretty close.
Are any of these solutions acceptable? Is there anything else I could do to address your concerns with any of these?
If folks think it's just too close to a move to GitHub Actions and full pipeline rewrite (which I fully support doing), then I will shelve all this. However, personally I'd like better test reporting even if it is only for 2/3 months until the new system appears.
https://github.com/llvm/llvm-project/pull/113447
More information about the llvm-commits
mailing list