This document contains the guidelines for which platforms (OS and architectures) to test in the source build CI.
- Prefer testing base distros of families over derivatives.
- Prioritize testing distros that source build .NET.
- Use CentOS Stream instead of Red Hat because it is the free alternative.
- Include a permutation of distros for the supported C standard library implementations (e.g. glibc and musl).
- For each C standard library implementation, include at least one distro that uses the minimum supported version of this library.
- Only test distros that are officially supported by .NET. Community supported distros will not be covered.
- Prefer testing latest LTS version. If LTS is unsupported, use the latest version instead.
- Drop distro versions that will be or are nearing EOL on the .NET release day.
- Stop updating the test matrix in the last 6 months of support for a .NET version as new distro versions are released.
- Amd64
- Arm64
It is not the intent to test every permutation of distro family, distro version, and architecture. Rather, smart decisions should be made to best utilize resources.
The following distro versions will be included in the CI matrix:
- CentOS Stream - Latest version (amd64)
- Fedora - Latest version (amd64)
- Ubuntu - Latest LTS version at the time of the release (amd64/arm64)
- Alpine - Latest and previous versions (amd64)
- AlmaLinux - Oldest version (targets lowest glibc version) (amd64)
When updating the distro versions in the CI matrix as new versions are released and older versions reach EOL:
- Update
main
to the newer version one to two months prior to the GA/EOL date. This is done to flush out any issues and to avoid destabilizing the servicing branches. - At the GA/EOL date, update the servicing branches.