Description
For context, we recently made a policy on platform support. The gist of that is that a platform is Tier 1 if we have CI for it. I listed Redox there as a Tier 2 platform, because we don't have CI for it.
We want to support Redox OS, because it's an awesome project. uutils is also the default implementation of coreutils on Redox (at least it was when I last checked). However, we have probably accidentally broken support for Redox since #2550. For example in #5064, but there are probably many more failing tests to find. This is due to no fault of the authors of the PRs that broke the support, because it is simply impractical for us to keep compatibility without a Redox CI job. The longer we wait with setting this up, the harder it will be to fix.
I think the way to support this is as follows:
- Investigate how bad the damage is, by building and testing the utils on Redox.
- Fix some issues that break the entire build for all utils (e.g. the
terminal_size
issue mentioned below) - Figure out which subset of utils that already compiles and adapt this feature set accordingly:
Lines 239 to 245 in 1f081f3
- Create a CI job to build, test and lint on Redox
- Update our platform support page to make the support "official" :)
- Open an issue to keep track of all the utils that should work but don't.
- Then we can start accepting fixes to enable more utils.
I'm not sure what the best way is to add a CI job for Redox. We probably need to to set up a VM (similar to how we do FreeBSD).
Some things to explore:
- Are there examples of projects that already have Redox tests in their CI?
- What subset of utils make sense to support on Redox?
@jackpot51, hope you don't mind me pinging you here. I've tried to follow up on the outstanding issues from #2550:
filetime
seems to have made a release in the meantime here: Bump to 0.2.15 alexcrichton/filetime#72termsize
has been removed from our dependency tree and replaced withterminal_size
(deps: changetermsize
dependency toterminal_size
#3864). However,terminal_size
makes no mention of Redox, so I suspect it won't work. We depend on this directly inls
and thecoreutils
multi-call binary, but also viaclap
(because we enabledwrap_help
feature). So maybe we should first askterminal_size
to support redox. Otherwise we'll have to think about workarounds.- Do you have any advice for a CI setup that works well in your opinion? Or any opinions/ideas/advice about this effort in general?
cc @sylvestre @cakebaker any opinions on this? Anything I missed?