-
Notifications
You must be signed in to change notification settings - Fork 501
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
Add buildx history command #2891
Conversation
ef6b9ce
to
14a1153
Compare
"golang.org/x/sync/errgroup" | ||
) | ||
|
||
func buildName(fattrs map[string]string, ls *localstate.State) string { |
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 are using the same logic in Docker Desktop. Could we make this one public and use it in DD?
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 isn't directly the same because the types are different, so I think it can be figured out in follow-up.
if c.format.IsTable() { | ||
if c.isTerm { | ||
return desktop.ANSIHyperlink(url, "Open") | ||
} | ||
return "" | ||
} |
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.
Was going to comment about the table that could be quite huge with the link but with this hyperlink this looks great.
1f03cd2
to
dfdd89d
Compare
commands/history/open.go
Outdated
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.
There's now also a docker desktop
CLI plugin. I think it would make more sense to put this feature in there, e.g. docker desktop open build <id>
. WDYT?
lsHeaderDuration = "DURATION" | ||
lsHeaderLink = "" | ||
|
||
lsDefaultTableFormat = "table {{.Ref}}\t{{.Name}}\t{{.Status}}\t{{.CreatedAt}}\t{{.Duration}}\t{{.Link}}" |
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.
Could we have a builder column? At first sight I'm not sure what builder is used:
$ docker buildx history ls
BUILD ID NAME STATUS CREATED AT DURATION
6kfisaus77v2lng6uh013mqsg buildx (binaries) Completed About a minute ago 47.9s Open
i2bwu6bu90hsgrcwt8ino4pdv ..ckerfiles/docs.Dockerfile (update) Completed 5 hours ago 1m 1s Open
l75hmymzlopcthlmp1onrko60 buildx (binaries) Completed 5 hours ago 1m 0s Open
2dujhidv8awc8b931fx27ok0l ..ckerfiles/docs.Dockerfile (update) Completed 5 hours ago 38.4s Open
ohcjje6ufqa2q1y025yroxs45 ..ckerfiles/docs.Dockerfile (update) Error 5 hours ago 47.3s Open
2cd0dp6aez14aort5yqv0qt0s ..ckerfiles/docs.Dockerfile (update) Completed 5 hours ago 1m 0s Open
sbdkqcz8pnpgk5o8hpep7efml buildx (binaries) Completed 5 hours ago 56.4s Open
1383761vlyc7v5zpvnu04x969 buildx (binaries) Completed 5 hours ago 58.2s Open
usjztin7bie33n53748tme8uw buildx (binaries) Completed 6 hours ago 1m 17s Open
w6eq2yd1fp000sgcstdwb5kq2 ..ckerfiles/docs.Dockerfile (update) Completed 8 hours ago 53.8s Open
tn6je06lbx11w5446qk2mijil ..ckerfiles/docs.Dockerfile (update) Error 8 hours ago 46.7s Open
zlzmiimgbujyoxrexg193j5mm buildx (binaries) Completed 29 hours ago 1m 12s Open
lapq0qhot3rt889b9zgfz6p3b buildx (binaries) Error 29 hours ago 53.4s Open
e65kwe3vw61fhzruia0qqd6vw ..ion/dev.Dockerfile (format-update) Completed 30 hours ago 25.9s Open
w6kji8z2tutykbad1dykdvo4j ..tion/dev.Dockerfile (build-update) Completed 30 hours ago 34.2s Open
39p6gvyf0bt1l3lnpr1wmicsl ..ion/dev.Dockerfile (vendor-update) Completed 30 hours ago 22.4s Open
qbgt47jlt98e34in2skv88d1m ..ion/dev.Dockerfile (format-update) Completed 30 hours ago 25.2s Open
0pxk73dru42im1cc6seee9k5o ..ion/dev.Dockerfile (vendor-update) Completed 30 hours ago 20.4s Open
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.
But they all have the same builder
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.
True but I was thinking of smth similar to what we have done when building #1177 to have a hint of what builder it's coming from
if _, ok := attrs["context"]; !ok { | ||
if src, ok := attrs["vcs:source"]; ok { | ||
fmt.Fprintf(tw, "VCS Repository:\t%s\n", src) | ||
} | ||
if rev, ok := attrs["vcs:revision"]; ok { | ||
fmt.Fprintf(tw, "VCS Revision:\t%s\n", rev) | ||
} | ||
} |
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.
I think we could keep the well-known git context format like:
VCS: https://github.com/tonistiigi/buildx#dfdd89d50e60af52129a88b47792c9784470f708
instead of:
VCS Repository: https://github.com/tonistiigi/buildx
VCS Revision: dfdd89d50e60af52129a88b47792c9784470f708
dfdd89d
to
12180f2
Compare
Updated with completion of |
12180f2
to
6489c8f
Compare
if len(attachments) > 0 { | ||
fmt.Fprintf(tw, "Attachments:\n") | ||
tw = tabwriter.NewWriter(dockerCli.Out(), 1, 8, 1, '\t', 0) | ||
fmt.Fprintf(tw, "DIGEST\tPLATFORM\tTYPE\n") | ||
for _, a := range attachments { | ||
p := "" | ||
if a.platform != nil { | ||
p = platforms.FormatAll(*a.platform) | ||
} | ||
fmt.Fprintf(tw, "%s\t%s\t%s\n", a.descr.Digest, p, descrType(a.descr)) | ||
} | ||
tw.Flush() | ||
fmt.Fprintln(dockerCli.Out()) | ||
} |
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.
Nice this is what I was looking for on my side
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.
LGTM for this first iteration
As follow-up:
inspect
format with JSON output so we can use this command for build summmary in GHA and get rid ofexport-build
container.- Or I could use
ls
JSON output but needs the build error: https://github.com/docker/actions-toolkit/blob/54bdcf6c08a9b43d37df4156506648c978b372fe/src/github.ts#L283-L299
- Or I could use
- make
buildName
public - integration tests
- print build error
- WDYT about Add buildx history command #2891 (comment)?
|
These commands allow working with build records of completed and running builds. Signed-off-by: Tonis Tiigi <[email protected]>
Signed-off-by: Tonis Tiigi <[email protected]>
Signed-off-by: Tonis Tiigi <[email protected]>
Signed-off-by: Tonis Tiigi <[email protected]>
6489c8f
to
6220e0a
Compare
rebased to fix conflict in |
Signed-off-by: CrazyMax <[email protected]>
0ffba24
to
b035a04
Compare
implements #2711
These commands allow working with build records
of completed and running builds.
Currently supports: