-
Notifications
You must be signed in to change notification settings - Fork 2k
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
docs: include required tools in source tree #4228
base: master
Are you sure you want to change the base?
Conversation
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #4228 +/- ##
=======================================
Coverage 59.51% 59.51%
=======================================
Files 346 346
Lines 29379 29379
=======================================
Hits 17486 17486
Misses 10923 10923
Partials 970 970 |
e926e70
to
bf5f804
Compare
I'm confused why the doc building validation is failing with Go compilation errors:
On my machine, with this patch both |
It needs a temporary But we need to look at this change; I know we split these to separate modules to not add the tool's dependencies as dependencies for the main module / vendor, and because we needed these separate modules for our migration to Hugo for the docs website. ./cc @crazy-max @dvdksn |
I don't think my change had any impact in this respect - it was only moving the doc generation to a subdirectory so it wouldn't confuse Hugo when fetching content files from this repo. The |
Ah. I can add the temporary copying logic for these builds if it's necessary.
Unfortunately that's exactly what I'm trying to revert -- removing this from vendoring means that we cannot build Docker's man pages in openSUSE's OBS (there is no internet access in OBS when building packages). The other alternative would be to include the generated of the man pages in the source tree (verifying they are kept up-to-date in the CI), so distributions can just copy them without needing to use a tool to build them during packaging. |
@thaJeztah I've fixed the |
7f661fa
to
37123bf
Compare
Rebased. @thaJeztah Did you want me to go the route of making the documentation be pre-built and then verified in CI? I think packaging things this way is better for distributions (it Just Works ™️ with the distributed tarballs) and the bloat here is only to the tarballs not the final binary, but if it is an issue I can go the other route. Rebasing this patchset for every Docker patch release is getting a little tiring. 😅 |
37123bf
to
8324502
Compare
Gentle ping @thaJeztah @crazy-max 🙇 (having the script that generates the manpages also be responsible for downloading and building the tools necessary is definitely problematic 😭) |
If we want to avoid having the tools in the "main" package dependencies/vendoring, perhaps we could have a separate |
Ah, yes, I tried doing a rebase, and some updates in #4903 some time ago, but now that the cli-docs-tool also should be able to do the man-page generating (without building an I think @crazy-max is on PTO this week, but maybe @krissetto or @Benehiko (also on PTO this week 🙈) are interested to have a peek. |
I've been rebasing this for the SUSE packages, I can push a new version here if you like. |
8324502
to
c273711
Compare
c273711
to
f006b64
Compare
In order to be able to build the documentation without internet access (as is required by some distribution build systems), all of the source code needed for the build needs to be available in the source tarball. This used to be possible with the docker-cli sources but was accidentally broken with some CI changes that switched to downloading the tools (by modifying go.mod as part of the docs build script). This pattern also maked documentation builds less reproducible since the tool version used was not based on the source code version. Fixes: 7dc35c0 ("validate manpages target") Fixes: a650f4d ("switch to cli-docs-tool for yaml docs generation") Signed-off-by: Aleksa Sarai <[email protected]>
f006b64
to
f0dcb42
Compare
I've rebased it again (this bump was a bit more complicated than previous ones, fwiw). I didn't remove the build of the |
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.
To me this looks fine, I tested it locally on my side and seems all good. I think someone else should also just verify if the changes won't break anything.
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.
IMO this is definitely a big improvement (just one comment on the scripts)
I'm not a maintainer here, though 🙈
function clean { | ||
rm -rf "$buildir" | ||
function clean() { | ||
rm -f go.mod |
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.
Shouldn't these scripts only delete go.mod
if it didn't exist when this script started?
(ie, only if this script running ./scripts/vendor init
is what created it)
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 point; technically, there "shouldn't" be one, but I know I tend to have one present (as a symlink); let me try how it handles that.
@@ -57,6 +57,8 @@ require ( | |||
tags.cncf.io/container-device-interface v0.8.0 | |||
) | |||
|
|||
require github.com/cpuguy83/go-md2man/v2 v2.0.4 |
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 go mod tidy
made a whoopsie here and didn't put it in the require
section above; can you put it there?
function clean { | ||
rm -rf "$buildir" | ||
function clean() { | ||
rm -f go.mod |
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 point; technically, there "shouldn't" be one, but I know I tend to have one present (as a symlink); let me try how it handles that.
Hm.. so @tianon's comment made me try if this works well with an existing
ls -la go.*
lrwxr-xr-x 1 root root 10 Jan 10 21:44 go.mod -> vendor.mod
lrwxr-xr-x 1 root root 10 Jan 10 21:44 go.sum -> vendor.sum With the above symlinks present, I ran make mddocs
scripts/docs/generate-md.sh
go: inconsistent vendoring in /go/src/github.com/docker/cli:
dario.cat/[email protected]: is marked as explicit in vendor/modules.txt, but not explicitly required in go.mod
github.com/Azure/[email protected]: is marked as explicit in vendor/modules.txt, but not explicitly required in go.mod
... After the above, I had modifications in my git, and it looks like it overwrote git status
On branch docs-no-internet
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: vendor.mod diff --git a/vendor.mod b/vendor.mod
index 3badee9b8..a8ea3c017 100644
--- a/vendor.mod
+++ b/vendor.mod
@@ -1,109 +1,3 @@
module github.com/docker/cli
-// 'vendor.mod' enables use of 'go mod vendor' to managed 'vendor/' directory.
-// There is no 'go.mod' file, as that would imply opting in for all the rules
-// around SemVer, which this repo cannot abide by as it uses CalVer.
-
go 1.22.0
-
-require (
- dario.cat/mergo v1.0.1
- github.com/containerd/platforms v0.2.1
- github.com/creack/pty v1.1.21
- github.com/distribution/reference v0.6.0
- github.com/docker/cli-docs-tool v0.8.0 It also removed the ls -la go.*
lrwxr-xr-x 1 root root 10 Jan 10 21:44 go.sum -> vendor.sum Curious if we could use something like the script that's in moby/moby, which seemed to detect the "already have a |
Thanks for updating! ❤️ Overall, this looks good; I tried it in a "standard" situation (no |
In order to be able to build the documentation without internet access
(as is required by some distribution build systems), all of the source
code needed for the build needs to be available in the source tarball.
This used to be possible with the docker-cli sources but was
accidentally broken with some CI changes that switched to downloading
the tools (by modifying go.mod as part of the docs build script).
This pattern also maked documentation builds less reproducible since the
tool version used was not based on the source code version.
Fixes: commit 7dc35c0 ("validate manpages target")
Fixes: commit a650f4d ("switch to cli-docs-tool for yaml docs generation")
Fixes #4212
See #3381
Signed-off-by: Aleksa Sarai [email protected]