-
Notifications
You must be signed in to change notification settings - Fork 677
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 org.opencontainers.image.source.subpath
#1062
base: main
Are you sure you want to change the base?
Conversation
(soft) NACK; #1046 (comment) (Soft because I'm still willing to be convinced, but I think we need more spec maintainer opinions to be expressed for this to really move one way or the other) |
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 have three options here depending on what we want to do:
- Decline this and use a tool specific annotation (e.g. something like
io.buildpacks.source.subpath
) if the goal is to have that tool define unique builds. - Change this to
org.opencontainers.image.instance
or some other unique key to dedup multiple builds in the same source repo. The value would be free form, based on the build tooling. E.g. makefiles may specify a target name. And docker builds may include the context, dockerfile, target, platform, build args, and any other inputs. - Leave this proposal as is, but make it generic and remove any expected results since different tooling will use it in ways that do not guarantee it is a unique build within the git repo. With other popular build tools, two different images can be built from the same subpath by altering other inputs.
Note, the DCO is also failing on this and would need to be fixed before we can consider merging.
I'm still partial to Brandon's option 1 (have each tool define their own additional fields for uniqueness if that's a property that they want/need instead of relying on us to somehow be the arbiter of all the possible uniqueness vectors for every build tool). 🙈 ❤️ |
Co-authored-by: Brandon Mitchell <[email protected]> Signed-off-by: Evan Anderson <[email protected]>
Fixes #1046
Defines an additional subpath within the source repository. In combination with the
source
attribute, this functions as a correlation ID for multiple images produces from the same source repository (e.g. the different containers produced by https://github.com/knative/serving, or any other mono-repo type arrangement which builds related artifacts from a common source tree).source.subpath
is explicitly tool-specific; I'd expect that most source repositories use a single tool for building images, or at the very least don't use two tools with the samesubpath
value to produce different images. There's probably at least one awesome counter-example out there... I don't know if I want to see it.