-
Notifications
You must be signed in to change notification settings - Fork 1.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ZTS: Add archlinux #16816
base: master
Are you sure you want to change the base?
ZTS: Add archlinux #16816
Conversation
you might want to have a read: https://github.com/orgs/archzfs/discussions/555 |
Fedora has pretty new kernels too... what we need is to test these new kernels under load, since that is how many of the problems with them manifest - low memory conditions, a lot of churn generally With that said, I have no objection to adding Arch, agree that the sooner problems are found the better @Kaz205 would you be around to maintain it? I'd guess it could require regular maintenance since it's a fast moving target |
You might want to add |
Aside from newer kernels, arch also has newer tool chains which can help identify logic or binary problems during the build and test steps. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can try enabling builds for Arch. Can you just add ZFS-CI-Type: full
to the commit message as suggested and force update the CI to trigger a full run on all platforms including Arch.
@@ -56,7 +56,8 @@ function linux() { | |||
--prefix=/usr \ | |||
--enable-pyzfs \ | |||
--enable-debug \ | |||
--enable-debuginfo | |||
--enable-debuginfo \ | |||
--sysconfdir=/etc |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why is this needed on Arch but not elsewhere?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks like the configs get installed to /usr/etc/zfs instead of /etc/zfs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks good and should be applied I think.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Untested, but I would suggest:
diff --git a/.github/workflows/scripts/qemu-4-build.sh b/.github/workflows/scripts/qemu-4-build.sh
index 955f605f5..a4335fb63 100755
--- a/.github/workflows/scripts/qemu-4-build.sh
+++ b/.github/workflows/scripts/qemu-4-build.sh
@@ -47,6 +47,7 @@ function freebsd() {
}
function linux() {
+ EXTRA_CONFIG="${1:-}"
echo "##[group]Autogen.sh"
run ./autogen.sh
echo "##[endgroup]"
@@ -56,7 +57,7 @@ function linux() {
--prefix=/usr \
--enable-pyzfs \
--enable-debug \
- --enable-debuginfo
+ --enable-debuginfo $EXTRA_CONFIG
echo "##[endgroup]"
echo "##[group]Build"
@@ -139,6 +140,9 @@ case "$1" in
debian*|ubuntu*)
deb_build_and_install
;;
+ arch*)
+ linux "--sysconfdir=/etc --enable-linux-experimental"
+ ;;
*)
linux
;;
Sorry for the late response.
Maybe add something like "mem=1G" to the kernel cmdline?
How much maintenance would this require? I was planning for this to be a one-off thing.
Done. |
Since we don't officially support Arch, and it's going to have a lot of churn, it would be good to name the runner in such a way so that people don't freak out if it doesn't pass, like:
I'm open to other ways to do this too. |
I guess the primary question is what are you expecting Arch will provide. If it's the ability to use OpenZFS with new kernels reliably, then I think this doesn't do anything to help on that front. If it's to make sure it compiles OK on new kernels, OK, that will work. But if you're after actual reliability, then I'd say we need more help, a kernel param doesn't move the needle either. Those bugs that really hinder uptime because you hit them just enough to be annoying or outright damaging to operations, but not as easy enough to be able to reproduce them easily, those are the worst and those take some effort to debug. The sooner we can uncover those, the better. Knowing on which commit things break without having to bisect for it with tests that take hours is priceless :)) And that is where we could IMO do better. This class of bugs doesn't eat data or corrupt what's on disk, but uptime is a reliability metric too :) Oftentimes that only happens after a certain amount of (meta)data turnover, or you only notice if you run without init_on_alloc/init_on_free, or some other subtly changed kernel config. If it's enough for you to know it compiles and runs the current test suite, OK - it looks like there isn't much to maintain overall, other than the package list, which doesn't seem difficult. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The first two commits look fine. But adding archlinux within the testings seems to much for me.
@@ -56,7 +56,8 @@ function linux() { | |||
--prefix=/usr \ | |||
--enable-pyzfs \ | |||
--enable-debug \ | |||
--enable-debuginfo | |||
--enable-debuginfo \ | |||
--sysconfdir=/etc |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks good and should be applied I think.
.github/workflows/zfs-qemu.yml
Outdated
@@ -22,7 +22,7 @@ jobs: | |||
- name: Generate OS config and CI type | |||
id: os | |||
run: | | |||
FULL_OS='["almalinux8", "almalinux9", "centos-stream9", "debian11", "debian12", "fedora40", "fedora41", "freebsd13-4r", "freebsd14-0r", "freebsd14-1s", "ubuntu20", "ubuntu22", "ubuntu24"]' | |||
FULL_OS='["almalinux8", "almalinux9", "archlinux", "centos-stream9", "debian11", "debian12", "fedora40", "fedora41", "freebsd13-4r", "freebsd14-0r", "freebsd14-1s", "ubuntu20", "ubuntu22", "ubuntu24"]' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Archlinux is most of the time ahead our linux-max version in the META file.
I don't think it's useful for the OpenZFS repository. You can add archlinux
within you own Actions for testings an so on.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can add
archlinux
within you own Actions for testings an so on.
Sounds good to me. Thanks for the review.
@Kaz205 - could you reabse without the last commit? That would be fine. |
Signed-off-by: Kazuki Hashimoto <[email protected]>
On Linux distros like Arch Linux, files that should be in /etc/zfs end up being installed in /usr/etc/zfs. Specifying sysconfdir path fixes it. Signed-off-by: Kazuki Hashimoto <[email protected]>
Done. |
Alternatively, you can make archlinux a |
Yes, this would be fine. |
With #16904 merged it should be fairly straight forward to add |
Motivation and Context
Arch Linux gets newer kernels faster than other distros.
Types of changes
Checklist:
Signed-off-by
.