Skip to content
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

Build debian package with github actions #1441

Open
wants to merge 1 commit into
base: dev
Choose a base branch
from

Conversation

catango
Copy link

@catango catango commented Jan 12, 2025

Build debian package for architectures amd64, armhf and arm64 with github actions. Default build settings are used and linked against libraries of the respective debian version. New github action build-rust-deb-action is used that leverages cargo-deb in a dockerized environment.

@catango
Copy link
Author

catango commented Jan 12, 2025

Some tests fail, as cross build breaks with bindgen 0.71. This is considered in the custom workflow in the pull request that builds with bindgen 0.70.1

Build debian package for architectures amd64, armhf and arm64 with
github actions. Default build settings are used and linked against
libraries of the respective debian version. New github action
build-rust-deb-action is used that leverages cargo-deb in a dockerized
environment.
@kingosticks
Copy link
Contributor

It's a bit weird that we already have workflows to build binaries for various platforms, but rather than use those, this adds another entirely ortholognal way to build. And we already have the first problem with doing it this different way. It would be nicer if we could leverage our existing build stuff and package those up instead. Is there some benefit to doing it this other way that I'm missing?

@photovoltex
Copy link
Member

Is there even a need to upload any artifacts that are built in the ci? I would have thought that our CI was primarily used to test the integrity of the library and not to build usable binaries/packages.

But it might be that I just assumed that.

@kingosticks
Copy link
Contributor

@photovoltex I don't believe there's much value in uploading the results of normal CI builds. If we were just packaging up the results of our existing builds, then it basically comes for free, so we could do that. But if it adds any extra time to the CI loop, or extra effort to maintain, then I don't see the point.

There is value in providing binaries and packages for our releases. Although we'd have to decide exactly which combination of features to provide and document that clearly.

@photovoltex
Copy link
Member

Okay, thanks for the clearup^^

@catango
Copy link
Author

catango commented Jan 14, 2025

I have provided this workflow to build a clean dedicated debian package, build with debian stable. The current test workflow builds on what is currently provided by the Github actions default image (what is currently some Ubuntu). This may change any time. To have a build in a reproducable environment, we may have to build e.g. inside an extra container, running inside the default image - and this is what I have added here (encapsulated into a dedicated Github action for simplicity).
Anyway, if no deb files shall be released, this action obviously does not make much sense.

@roderickvd
Copy link
Member

We had a similar discussion some years ago. A point I remember is that it may trigger more issues when the build artefact would somehow not be 100% compatible with user environments. As a library, there's no binary to speak of; as player, it may be best to have downstream distributions look after that.

@photovoltex
Copy link
Member

You seem to refer to #727? Good hint! But makes sense that the topic was already discussed once, as it seems to make sense to not build the binary manually.

I actually would see no problem in providing binaries for the dev branch with a default release build. That could also reduce build issues if people only want to use the latest dev version without building it manually.

Maybe even having a PR pipe that builds quick with testing and a dev pipe that provides release binaries for easy of use could be considered?


Anyhow I think in general the idea and option is nice to have. But as the PR is currently I would see it as out-of-scope, as building release binaries in a CI for PR's seems not right as these artifacts might not even be relevant.

Maybe letting the action run only on pushs to dev would be an option that we could consider. But then again, I would see it as more preferable to only having the binaries uploaded then a debian package. Or is there any reason in providing debian packages rather then just the release binary?

@roderickvd
Copy link
Member

Yes I think that was the discussion.

Build artifacts I understand for having users easily test fixes. Packages I don't and would leave to the distros. We make it easy enough.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants