Bug 2260598 - Review Request: rust-coreutils - coreutils ~ GNU coreutils reimplementation in Rust
Summary: Review Request: rust-coreutils - coreutils ~ GNU coreutils reimplementation i...
Keywords:
Status: CLOSED ERRATA
Alias: None
Product: Fedora
Classification: Fedora
Component: Package Review
Version: rawhide
Hardware: Unspecified
OS: Unspecified
unspecified
unspecified
Target Milestone: ---
Assignee: Fabio Valentini
QA Contact: Fedora Extras Quality Assurance
URL: https://crates.io/crates/coreutils
Whiteboard:
Depends On:
Blocks:
TreeView+ depends on / blocked
 
Reported: 2024-01-27 02:38 UTC by Michel Lind
Modified: 2024-06-11 01:58 UTC (History)
5 users (show)

Fixed In Version:
Doc Type: If docs needed, set a value
Doc Text:
Clone Of:
Environment:
Last Closed: 2024-05-31 22:53:21 UTC
Type: ---
Embargoed:
decathorpe: fedora-review+


Attachments (Terms of Use)
The .spec file difference from Copr build 6965713 to 6967305 (1.26 KB, patch)
2024-01-27 19:47 UTC, Fedora Review Service
no flags Details | Diff
The .spec file difference from Copr build 6967305 to 7066176 (5.02 KB, patch)
2024-02-27 23:32 UTC, Fedora Review Service
no flags Details | Diff

Description Michel Lind 2024-01-27 02:38:55 UTC
Spec URL: https://salimma.fedorapeople.org/specs/rust-coreutils.spec
SRPM URL: https://salimma.fedorapeople.org/specs/rust-coreutils-0.0.23-1.fc38.src.rpm

Description:
coreutils ~ GNU coreutils (updated); implemented as universal (cross-
platform) utils, written in Rust.

Fedora Account System Username: salimma

Comment 1 Fedora Review Service 2024-01-27 02:42:15 UTC
Copr build:
https://copr.fedorainfracloud.org/coprs/build/6965713
(failed)

Build log:
https://download.copr.fedorainfracloud.org/results/@fedora-review/fedora-review-2260598-rust-coreutils/fedora-rawhide-x86_64/06965713-rust-coreutils/builder-live.log.gz

Please make sure the package builds successfully at least for Fedora Rawhide.

- If the build failed for unrelated reasons (e.g. temporary network
  unavailability), please ignore it.
- If the build failed because of missing BuildRequires, please make sure they
  are listed in the "Depends On" field


---
This comment was created by the fedora-review-service
https://github.com/FrostyX/fedora-review-service

If you want to trigger a new Copr build, add a comment containing new
Spec and SRPM URLs or [fedora-review-service-build] string.

Comment 2 Michel Lind 2024-01-27 15:57:47 UTC
Skipped renaming binary

[fedora-review-service-build]

Comment 3 Fedora Review Service 2024-01-27 19:47:57 UTC
Created attachment 2011032 [details]
The .spec file difference from Copr build 6965713 to 6967305

Comment 4 Fedora Review Service 2024-01-27 19:47:59 UTC
Copr build:
https://copr.fedorainfracloud.org/coprs/build/6967305
(succeeded)

Review template:
https://download.copr.fedorainfracloud.org/results/@fedora-review/fedora-review-2260598-rust-coreutils/fedora-rawhide-x86_64/06967305-rust-coreutils/fedora-review/review.txt

Please take a look if any issues were found.


---
This comment was created by the fedora-review-service
https://github.com/FrostyX/fedora-review-service

If you want to trigger a new Copr build, add a comment containing new
Spec and SRPM URLs or [fedora-review-service-build] string.

Comment 5 Fabio Valentini 2024-01-27 20:54:07 UTC
First-pass review:

1. It looks like the "default" feature set builds only a "minimal" / "core" of tools that are supported everywhere.

Looking at the list of things that are enabled by different features, it would be great if we could build with "unix" and "selinux" features enabled.

The "unix" feature would enable a few more tools and more features for some tools that are already enabled as part of the "default" set. This would pull in a few more dependencies that are currently optional and disabled.

The "selinux" feature would enable SELinux support for tools that are already part of the "default" set like uu_cp, uu_ls (and would not introduce additional dependencies - as far as I can tell by looking).

2. You might not want to build "uudoc" / enable the "uudoc" feature in the package. The feature only gets enabled by rust2rpm because the "uudoc" binary target requires it, but looking at what the "uudoc" binary does, I don't think it makes sense to actually ship that binary with the package (it seems to be a tool to generate some documentation, but that's more for upstream purposes, and not for users in Fedora).

3. It would be great if the man page and shell completions could be included in the package.

4. The list of skipped tests is pretty long, and there's no explanation for what's wrong with them other than "they mostly panic". It would be great if you could do at least *some* amount of investigation into why specific tests are failing - and document whether the failures have something to do with the build environment, or whether they are *actually* indicative of a real failure.

===

It's fine if you want to enable more tools / functionality *later* and get the package into Fedora as-is.

However, it would be great if at least points 2 and 4 above could be addressed. 

As for point 1, I can help with doing package reviews for the missing uu_* tools that are currently disabled, but that is not a blocker for the review.

For point 3, I can submit a PR once the package is imported, or you can add the manpages / shell completions to the package yourself later (building shell completions from the built binary works almost the same way in the "ruff" or "maturin" packages, for example). This would be nice-to-have, but it's not a blocker for the review either.

Comment 6 Michel Lind 2024-02-03 10:58:09 UTC
Will try and address 2, 3, 4 on Monday after FOSDEM, thanks!

Comment 7 Michel Lind 2024-02-27 21:34:37 UTC
Need uu_arch to generate manpages

Comment 8 Michel Lind 2024-02-27 23:04:16 UTC
Spec URL: https://salimma.fedorapeople.org/specs/rust-coreutils.spec
SRPM URL: https://salimma.fedorapeople.org/specs/rust-coreutils-0.0.23-1.fc39.src.rpm

2 - uudoc disabled
3 - the `cargo run` command seems to require a lot of the optional uu crates to even run. I have the manpage generation code in the spec but gated behind `%bcond_with man` for now
4 - done. Patched the seq errors. There are some flaky tests that I might need to add to rust2rpm.toml later, but the spec as is would pass builds most of the time.

Comment 9 Fedora Review Service 2024-02-27 23:32:00 UTC
Created attachment 2019181 [details]
The .spec file difference from Copr build 6967305 to 7066176

Comment 10 Fedora Review Service 2024-02-27 23:32:03 UTC
Copr build:
https://copr.fedorainfracloud.org/coprs/build/7066176
(succeeded)

Review template:
https://download.copr.fedorainfracloud.org/results/@fedora-review/fedora-review-2260598-rust-coreutils/fedora-rawhide-x86_64/07066176-rust-coreutils/fedora-review/review.txt

Please take a look if any issues were found.


---
This comment was created by the fedora-review-service
https://github.com/FrostyX/fedora-review-service

If you want to trigger a new Copr build, add a comment containing new
Spec and SRPM URLs or [fedora-review-service-build] string.

Comment 11 Fabio Valentini 2024-03-04 15:21:51 UTC
I tried running fedora-review here, but the package failed to build due to failing tests:

failures:
---- test_mktemp::test_directory_permissions stdout ----
run: /builddir/build/BUILD/coreutils-0.0.23/target/rpm/coreutils mktemp -d XXX
thread 'test_mktemp::test_directory_permissions' panicked at tests/common/util.rs:1528:37:
called `Result::unwrap()` on an `Err` value: Os { code: 13, kind: PermissionDenied, message: "Permission denied" }
---- test_mktemp::test_missing_short_tmpdir_flag stdout ----
run: /builddir/build/BUILD/coreutils-0.0.23/target/rpm/coreutils mktemp -p
thread 'test_mktemp::test_missing_short_tmpdir_flag' panicked at tests/common/util.rs:1528:37:
called `Result::unwrap()` on an `Err` value: Os { code: 13, kind: PermissionDenied, message: "Permission denied" }
---- test_mktemp::test_missing_xs_tmpdir_template stdout ----
run: /builddir/build/BUILD/coreutils-0.0.23/target/rpm/coreutils mktemp --tmpdir tempX
thread 'test_mktemp::test_missing_xs_tmpdir_template' panicked at tests/common/util.rs:1528:37:
called `Result::unwrap()` on an `Err` value: Os { code: 13, kind: PermissionDenied, message: "Permission denied" }
---- test_tail::test_follow_when_files_are_pointing_to_same_relative_file_and_file_stays_same_size stdout ----
write(default): /tmp/.tmpj9taQk/data
run: /builddir/build/BUILD/coreutils-0.0.23/target/rpm/coreutils tail --follow=descriptor --max-unchanged-stats=1 --sleep-interval=0.1 data /tmp/.tmpj9taQk/data
write(default): /tmp/.tmpj9taQk/data
thread 'test_tail::test_follow_when_files_are_pointing_to_same_relative_file_and_file_stays_same_size' panicked at tests/by-util/test_tail.rs:4463:10:
Expected stderr to be empty, but it's:
tail: /tmp/.tmpj9taQk/data: file truncated
failures:
    test_mktemp::test_directory_permissions
    test_mktemp::test_missing_short_tmpdir_flag
    test_mktemp::test_missing_xs_tmpdir_template
    test_tail::test_follow_when_files_are_pointing_to_same_relative_file_and_file_stays_same_size
test result: FAILED. 2514 passed; 4 failed; 28 ignored; 0 measured; 12 filtered out; finished in 21.02s

Comment 12 Michel Lind 2024-03-04 20:59:51 UTC
Yeah, those are weirdly flaky. I'll disable them and retest

Comment 13 Fabio Valentini 2024-05-06 17:46:21 UTC
Can we get this moving again?

It would be great to have it in Fedora before the next mass-update for uu_* and nu-* rolls around the corner, just to avoid churn here.

Comment 14 Michel Lind 2024-05-30 05:19:16 UTC
After multiple rounds of disabling more and more tests - and it finally passing everywhere but x86_64 - let's just try reenabling tests later with 0.0.26?

Spec URL: https://salimma.fedorapeople.org/specs/rust-coreutils.spec
SRPM URL: https://salimma.fedorapeople.org/specs/rust-coreutils-0.0.23-1.fc41.src.rpm

Koji scratch build: https://koji.fedoraproject.org/koji/taskinfo?taskID=118269079

Comment 15 Fabio Valentini 2024-05-30 18:17:58 UTC
Thanks for the update!
I agree with just disabling tests for now if they are so unreliable.

Last problem I see is that that the binary package ("%package -n %{crate}") conflicts with "coreutils" from the "coreutils" package.
You will need to rename it. Maybe uutils-coreutils to match the name of the name of the renamed binary?

Comment 16 Michel Lind 2024-05-31 03:58:46 UTC
Fixed the binary package name - and thanks for the test-threads 1 tip - as I suspected the ever-shifting permission denied issues is due to some sort of resource exhaustion

Note: one test seems a bit flaky on ppc64le but I can't really repro it

Spec URL: https://salimma.fedorapeople.org/specs/rust-coreutils.spec
SRPM URL: https://salimma.fedorapeople.org/specs/rust-coreutils-0.0.23-1.fc41.src.rpm
Koji scratch build: https://koji.fedoraproject.org/koji/taskinfo?taskID=118319817

Comment 17 Fabio Valentini 2024-05-31 21:11:27 UTC
> %{__cargo} run manpage $utility > data/man/man1/uu_${utility}.1

This is bad in two ways - the __cargo macro is for internal use only (hence two underscores), and the CLI command isn't even right (missing "--" between "run" and "manpage").

When / if you enable this, you can use something like this:

target/rpm/coreutils manpage $utility > data/man/man1/uu_${utility}.1

Please also move the "mkdir -p data/man/man1" into the "with man" conditional.

Both are harmless since the manpages are not built yet, so just suggestions for improvement.

Other than that, package looks good to me now.
Thank you for investigating the test failures! Hopefully we can reduce the number of ignored tests in the future ...

===

Package was generated with rust2rpm, simplifying the review.

✅ package builds and installs without errors on rawhide
🫤 test suite is run and all unit tests pass (some failing tests ignored for now)
🫤 latest version of the crate is packaged (version matches existing uu_* packages)
✅ license matches upstream specification and is acceptable for Fedora
✅ licenses of statically linked dependencies are correctly taken into account
✅ license file is included with %license in %files
✅ package complies with Rust Packaging Guidelines

Package APPROVED.

===

Recommended post-import rust-sig tasks:

- set up package on release-monitoring.org:
  project: $crate
  homepage: https://crates.io/crates/$crate
  backend: crates.io
  version scheme: semantic
  version filter: alpha;beta;rc;pre
  distro: Fedora
  Package: rust-$crate

- add @rust-sig with "commit" access as package co-maintainer
  (should happen automatically)

- set bugzilla assignee overrides to @rust-sig (optional)

- track package in koschei for all built branches
  (should happen automatically once rust-sig is co-maintainer)

Comment 18 Fedora Admin user for bugzilla script actions 2024-05-31 21:49:36 UTC
The Pagure repository was created at https://src.fedoraproject.org/rpms/rust-coreutils

Comment 19 Michel Lind 2024-05-31 21:55:48 UTC
(In reply to Fabio Valentini from comment #17)
> > %{__cargo} run manpage $utility > data/man/man1/uu_${utility}.1
> 
> This is bad in two ways - the __cargo macro is for internal use only (hence
> two underscores), and the CLI command isn't even right (missing "--" between
> "run" and "manpage").
> 
> When / if you enable this, you can use something like this:
> 
> target/rpm/coreutils manpage $utility > data/man/man1/uu_${utility}.1
> 
> Please also move the "mkdir -p data/man/man1" into the "with man"
> conditional.
> 
> Both are harmless since the manpages are not built yet, so just suggestions
> for improvement.
> 
Thanks! Applied now so I don't forget for later.

Comment 20 Fedora Update System 2024-05-31 22:50:26 UTC
FEDORA-2024-b7804bc4f0 (rust-coreutils-0.0.23-1.fc41) has been submitted as an update to Fedora 41.
https://bodhi.fedoraproject.org/updates/FEDORA-2024-b7804bc4f0

Comment 21 Fedora Update System 2024-05-31 22:53:21 UTC
FEDORA-2024-b7804bc4f0 (rust-coreutils-0.0.23-1.fc41) has been pushed to the Fedora 41 stable repository.
If problem still persists, please make note of it in this bug report.

Comment 22 Fedora Update System 2024-06-02 21:12:14 UTC
FEDORA-2024-07c868800b (rust-coreutils-0.0.23-1.fc40) has been submitted as an update to Fedora 40.
https://bodhi.fedoraproject.org/updates/FEDORA-2024-07c868800b

Comment 23 Fedora Update System 2024-06-02 21:12:14 UTC
FEDORA-2024-de2429cf97 (rust-coreutils-0.0.23-1.fc39) has been submitted as an update to Fedora 39.
https://bodhi.fedoraproject.org/updates/FEDORA-2024-de2429cf97

Comment 24 Fedora Update System 2024-06-03 00:54:27 UTC
FEDORA-2024-de2429cf97 has been pushed to the Fedora 39 testing repository.
Soon you'll be able to install the update with the following command:
`sudo dnf install --enablerepo=updates-testing --refresh --advisory=FEDORA-2024-de2429cf97 \*`
You can provide feedback for this update here: https://bodhi.fedoraproject.org/updates/FEDORA-2024-de2429cf97

See also https://fedoraproject.org/wiki/QA:Updates_Testing for more information on how to test updates.

Comment 25 Fedora Update System 2024-06-03 04:15:38 UTC
FEDORA-2024-07c868800b has been pushed to the Fedora 40 testing repository.
Soon you'll be able to install the update with the following command:
`sudo dnf install --enablerepo=updates-testing --refresh --advisory=FEDORA-2024-07c868800b \*`
You can provide feedback for this update here: https://bodhi.fedoraproject.org/updates/FEDORA-2024-07c868800b

See also https://fedoraproject.org/wiki/QA:Updates_Testing for more information on how to test updates.

Comment 26 Fedora Update System 2024-06-11 01:49:56 UTC
FEDORA-2024-07c868800b (rust-coreutils-0.0.23-1.fc40) has been pushed to the Fedora 40 stable repository.
If problem still persists, please make note of it in this bug report.

Comment 27 Fedora Update System 2024-06-11 01:58:54 UTC
FEDORA-2024-de2429cf97 (rust-coreutils-0.0.23-1.fc39) has been pushed to the Fedora 39 stable repository.
If problem still persists, please make note of it in this bug report.


Note You need to log in before you can comment on or make changes to this bug.