Skip to content
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

specs-go/v1: unify the descriptor type #620

Merged
merged 1 commit into from
Apr 4, 2017

Conversation

stevvooe
Copy link
Contributor

@stevvooe stevvooe commented Mar 20, 2017

Unifying the descriptor type makes it much easier to handler descriptors
in generic manner. This change ensures that a single deserialization can
be done a descriptor that may be processed in separate contexts.

It is unclear whether or not the specification should be pedantic about
this, as well. As it is written, these fields are only valid when being
referred through a manifest, but this distinction is only required
during validation. It may be possible to lift the platform definition to
the descriptor type, but this isn't strictly necessary.

Signed-off-by: Stephen J Day stephen.day@docker.com

Addresses #588.
Closes #618.

@stevvooe stevvooe added this to the v1.0.0-rc6 milestone Mar 20, 2017
@erikh
Copy link
Contributor

erikh commented Mar 21, 2017

Would it make sense to make this a well-known annotation instead? Seems like a good use for the field. Would require moving the annotations type to map[string]interface{} of course though, which might have consequences I haven't foreseen.

OSFeatures []string `json:"os.features,omitempty"`

// Variant is an optional field specifying a variant of the CPU, for
// example `ppc64le` to specify a little-endian version of a PowerPC CPU.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

PowerPC -> POWER?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This was copy pasted. If you want to change it, please do so in a follow up.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@AkihiroSuda What was the PR that updates this? This all gets moved from index.go to descriptor.go, so we need to make sure it gets rebased appropriately.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

IIUC you question, this comment about ppc64le was introduced in #172 .

@runcom What was the intention to add ppc64le? Is there any implementation using this field (suppose not)?
(related: #632)

@wking
Copy link
Contributor

wking commented Mar 21, 2017

Reposted from an emailed comment, which GitHub seems to have eaten:

On Mon, Mar 20, 2017 at 07:01:12PM -0700, Erik Hollensbe wrote:

Would it make sense to make this a well-known annotation instead?

+1 to this. With platform-ness being just one way to select a given child, and the existing annotation org.opencontainers.image.ref.name being another parallel/complimentary way, I think moving the platform information into annotations makes sense.

@stevvooe, you'd seemed to be on board with platform annotations earlier. Has something changed? We can always continue to inject the old platform properties if we want backwards compatibility with existing Docker manifest-list engines, although we may not be able to only use annotations if we require forward compatibility for existing Docker manifest-list blobs.

Seems like a good use for the field. Would require moving the annotations type to map[string]interface{} of course though, which might have consequences I haven't foreseen.

There's some background on string vs. interface{} values in #44 if that helps orient you.

@stevvooe
Copy link
Contributor Author

Reposted from an emailed comment, which GitHub seems to have eaten

@wking GitHub probably ate this because you are supposed to be blocked. Please do not comment on my pull requests. I have asked you, kindly, more than once.

With platform-ness being just one way to select a given child, and the existing annotation org.opencontainers.image.ref.name being another parallel/complimentary way, I think moving the platform information into annotations makes sense.

Ref name isn't really binding in the way that platform is. Platform is just pulled up from the underlying config and can be validated. Ref name is a hint that shouldn't be trusted and can be ignored. This PR brings them to the same level so they can be used in filtration logic, but that doesn't point to their equivalence.

Would it make sense to make this a well-known annotation instead? Seems like a good use for the field. Would require moving the annotations type to map[string]interface{} of course though, which might have consequences I haven't foreseen.

I don't see any reason to break from the structured approach. Having such a large change before 1.0 would be detrimental to the release and not provide value. Furthermore, annotations are not a dumping ground for stuff; they are meant for non-binding metadata. If we can provide structure for something, we absolutely should.

Note that this PR doesn't change the context under which the platform field can be used. It only unifies the Go type. From the perspective of the specification, the Platform field can only be used with indexes. Moving platform to annotations or allowing platform descriptions outside of this context are outside the scope of this PR. This PR is only present to make the descriptor type easier to work with.

@erikh
Copy link
Contributor

erikh commented Mar 21, 2017 via email

@stevvooe
Copy link
Contributor Author

I hope my query wasn't a bother! I just thought it was a reasonable
question.

No, it is a completely reasonable question. I hope the clarification was helpful.

@qianzhangxa
Copy link
Contributor

I guess we need another PR to update specification accordingly to make it consistent with the changes in this PR.

@vbatts
Copy link
Member

vbatts commented Mar 22, 2017

LGTM

Approved with PullApprove

@zhouhao3
Copy link

If such changes, calls to descriptor will be no errors in the manifest?

Unifying the descriptor type makes it much easier to handler descriptors
in generic manner. This change ensures that a single deserialization can
be done a descriptor that may be processed in separate contexts.

It is unclear whether or not the specification should be pedantic about
this, as well. As it is written, these fields are only valid when being
referred through a manifest, but this distinction is only required
during validation. It may be possible to lift the platform definition to
the descriptor type, but this isn't strictly necessary.

Signed-off-by: Stephen J Day <stephen.day@docker.com>
@stevvooe stevvooe force-pushed the unify-descriptor-type branch from 832f761 to 572e6ae Compare April 3, 2017 20:48
@stevvooe
Copy link
Contributor Author

stevvooe commented Apr 3, 2017

@opencontainers/image-spec-maintainers Rebased after the pointer change in to Platform. PTAL

@vbatts
Copy link
Member

vbatts commented Apr 3, 2017

LGTM

Approved with PullApprove

@jonboulle
Copy link
Contributor

jonboulle commented Apr 4, 2017

lgtm

Approved with PullApprove

@jonboulle jonboulle merged commit 8f27a02 into opencontainers:master Apr 4, 2017
@stevvooe stevvooe deleted the unify-descriptor-type branch April 4, 2017 18:12
@vbatts vbatts mentioned this pull request May 19, 2017
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

8 participants