-
-
Notifications
You must be signed in to change notification settings - Fork 14.7k
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
Modify buildGoModules to use -mod=vendor instead of the go package cache. #86376
Conversation
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.
👍 good idea.
Do you mind also handling the case where the vendor/
folder already exists in the source? We have a number of upstream sources that already include that folder. At the moment those need to use buildGoPackage with all the complicated source relocating business.
I think goModSha256 = null
should mean that the vendor/ folder already exists and skip the go-modules generation entirely. And change goModSha256 = "impure"
for the heretic case where the go-modules is built as a input derivation instead of fixed derivation.
Some related issues to consider:
Sorry for expanding the scope of the PR. I think there is a potential to handle all these scenarios once and for all. And I am willing to put my time into making this work. |
That person was me. I am working on it. However the PR here should not block this. This feature can be added later. |
This comment has been minimized.
This comment has been minimized.
fe08973
to
79fff38
Compare
Redoing deps is another PR - this is just changing the storage format. |
vendorSha256=null means use the built in vendor folder. If it's not null we won't overwrite that folder if it exists and instead throw an error. If the upstream source is bad, we'll need to drop that folder when packaging in an intermediate derivation between og source and input src. |
44f18d7
to
37d3710
Compare
be4f03d
to
017e8b8
Compare
This broke in #86376 Also, fix some stray trailing whitespaces
We have an |
Maybe this could be done via an github action? |
maybe this discussion belongs to a different issue ^^ but yes, considering some of the weird formatting I've seen around nixpkgs, something like this does sound reasonable. |
@ajs124 Any chance you can add some automation? Both the github checks + nix-review pr didn't notice this. If you give me a specific way to check I can probably add them in to nix-review, but I honestly have no idea how to build the manual. |
You can build the manual through release.nix, e.g. Alternatively, to check more things than just the manual, you can also build a "dummy" nixos system with |
I've opened a draft where we can continue the discussion. #87853 |
Can anybody explain to me what this change does? The added docs say
but I don't understand what the effective difference. When reading the changelog, it just looks like "we renamed something but don't say why". Same with
That somehow suggests that Maybe an example of the shortcomings of |
see #88258 |
So this doesn't address NixOS/nix#2270 right? |
Not yet. However it is now easier with a vendor directory to create a generator that creates separate source derivations than it was before with the go module proxy directory. |
After seeing this in the wild for a while I'm not sure if that's the way to move forward: while the old approaches certainly had their issues, we now seem to push the task of solving messed-up dependency situations in downstream sources to our package-maintainers. Previously I was able to work around this by generating some sort of Also, regenerating huge patches of a I may have missed something, but can someone explain why this is even needed? And, am I wrong with this assumption? Or in other words, shouldn't we keep the original behavior for "problematic" packages? |
I can't make this work with my repo. expression looks like this:
And I don't have a |
@numkem Just noticed this. Can you include a full repro (i.e. with no variable parameters that only depends on nixpkgs) so I could run it? A seperate issue may also help with me responding quickly, but I can keep debugging here if it is easier for you :) My guess is that you're setting vendorSha256=null; which says use the builtin in vendor directory. This is super useful if you have a vendor directory (or your code has no external dependencies). If that's not your intention, I'd set vendorSha256. Another option is you copied the modSha256 hash and just set vendorSha256 to it. You need to modify the hash, so a full rebuild happens, then it will error and provide you the new hash to set. If you're not doing either of those things, then I'll need to be able to pull the code and poke it to figure out what is going on. |
The sad but glorious life of package managers :). I think we mostly are in the same state we used to be with regards to messed up dependencies. There were some regressions around go mod vendor not working will. The other indirect question is "why do this" and the answer was that people (not me) were unhappy about using a binary format as our dependency format, since it was hard to audit and modify. It's actually a strength of the new approach that you can just use plain text patches to fix issues :) However I really just want to get rid of buildGoPackages as much as possible, so I'm doing this to try and get #86282 merged.
I'm confused - buildGoModule never supported deps.nix. If you expand on your issue a bit more I can be more prescriptive, but in general if you're having packaging issues for your own source, run go mod vendor in your directory and set vendorSha256 = null :). Then your code can build entirely from source and you don't have to deal with anything. If you're trying to fix an issue in an upstream vendor, generally just patching go.mod solves your problems pretty well. There is a fun corner case of people using go modules to distribute c code (which is super not recommended by the go team). Making sure each c folder has a go file in it may help, alternatively, cp the c source into the directory after the fetching via a postInstall command. There are a few examples of this in the repor.
Why are you needing huge patches? What are you trying to package that's exploding?
This happened because a lot of people were screaming at me that the go module packaging in nix was bad and we shouldn't use them. Rather than delete buildGoModule and migrate everything to buildGoPackage, I tried to address some of their complaints - one complaint was that the binary files weren't human readable, so now we have vendor directories which are human readable :). Another complaint is that go downloads don't proxy super well (since they're not just raw http fetches). That's the next complaint to fix, either by using deps.nix to generate the vendor folder, or by writing a go module proxy which can be configured via deps.nix. TL;DR I'm just trying to get #86282 merged. |
buildGoModule's modSha256 has been renamed to vendorSha256 in NixOS/nixpkgs#86376. Building the derivation failed with the previous hash, so I replaced it with the expected hash found in the error message.
buildGoModule's modSha256 has been renamed to vendorSha256 in NixOS/nixpkgs#86376. Building the derivation failed with the previous hash, so I replaced it with the expected hash found in the error message.
Motivation for this change
A number of users sound concerned about ensuring we have readable source. Additionally, we have to do a hack to the pkg cache to make it reproducible, where as vendor is by design reproducible.
This is the default behaviour of go 1.14 for packages with a go version of 1.14.
Things done
sandbox
innix.conf
on non-NixOS linux)nix-shell -p nixpkgs-review --run "nixpkgs-review wip"
./result/bin/
)nix path-info -S
before and after)