-
Notifications
You must be signed in to change notification settings - Fork 647
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
base: dev
Are you sure you want to change the base?
Conversation
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.
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? |
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. |
@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. |
Okay, thanks for the clearup^^ |
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). |
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. |
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
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 |
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. |
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.