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

feat(podman-remote): support kube play build client #24435

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

fixomatic-ctrl
Copy link
Contributor

@fixomatic-ctrl fixomatic-ctrl commented Oct 31, 2024

Fixes #14527
Following #24015

Does this PR introduce a user-facing change?

Add podman play kube --build support for podman remotes

Changes

I can split this PR in smaller chunk if needed.

Yaml Parsing Utility methods

Moving SplitMultiDocYAML, getKubeKind, imageNamePrefix, getBuildFile from pkg/domain/infra/abi/play.go to the utility pkg/util/kube.go to be able to access it from the binding

This is necessary to have a single way of parsing those file between the client and the server, otherwise the client could send contexts that the server may not use.

TarBuilder

The kube play binding will create a tarball and add several folders to a specific place in the tar. The images build have some similar logic, however the nTar function they used (bellow)

func nTar(excludes []string, sources ...string) (io.ReadCloser, error) {

Cannot be used, as it has very particular mechanism for any files/folder added after the first one. Therefore I created a TarBuilder struct, to be able to easily manipulate the creation of the tar.

I was hopeful to have some easy support through the github.com/containers/storage/pkg/archive package, has they have similar method implemented, but they do not expose it. (See discussion i opened on their repo moby/moby#48610)

I had to move pkg/bindings/images/build_*.go to the pkg/bindings/internal/util/build_*.go because importing those from the internal/util was leading to a circular import issue.

Adding Build and ContextDir to types

In pkg/bindings/kube/types.go adding the Build and ContextDir types, to binding can use them.

Testing

  • pkg/bindings/internal/util/tar_builder_test.go ensure the TarBuilder struct works as expected
  • pkg/bindings/kube/kube_test.go ensure client parse properly yaml files
  • tests/e2e/play_build_test.go ensure podman-remote can use --build

You may now use ./bin/podman-remote kube play --build example.yaml :)

Copy link
Contributor

openshift-ci bot commented Oct 31, 2024

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by: fixomatic-ctrl
Once this PR has been reviewed and has the lgtm label, please assign l0rd for approval. For more information see the Kubernetes Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@fixomatic-ctrl
Copy link
Contributor Author

bin/podman-remote grew by 435168 bytes; max allowed is 51200

@fixomatic-ctrl fixomatic-ctrl marked this pull request as draft October 31, 2024 19:47
@openshift-ci openshift-ci bot added the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Oct 31, 2024
@fixomatic-ctrl
Copy link
Contributor Author

Hi @Luap99, I moved this to draft because I think this PR is too big. Before I try to split it, could you tell me what do you think about the direction I took and you opinion ?

Thanks

Copy link
Member

@Luap99 Luap99 left a comment

Choose a reason for hiding this comment

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

I haven't looked closely but I don't mind the the size. As long as everything is one feature (and it is) splitting it does not really make reviewing easier as I would still need to read the same code.

Copy link
Member

@Luap99 Luap99 left a comment

Choose a reason for hiding this comment

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

please add Fixes #14527 as part of the commit message and squash the commits.

One thing I do wonder I would assume we can share much more code with the bindings/build code where we assemble the tar context dir but I haven't looked to closely itno the issue you mentioned

Cannot be used, as it has very particular mechanism for any files/folder added after the first one. Therefore I created a TarBuilder struct, to be able to easily manipulate the creation of the tar.

I was hopeful to have some easy support through the github.com/containers/storage/pkg/archive package, has they have similar method implemented, but they do not expose it. (See discussion i opened on their repo moby/moby#48610)

Note were are using containers/storage not moby so if anything can be added to simplify code here we can most likely make it happen if it is useful there

@mheon
Copy link
Member

mheon commented Nov 4, 2024

Have some minor style nits, overall code LGTM. Adding bloat_approved.

@mheon
Copy link
Member

mheon commented Nov 4, 2024

(We can debate about whether the bloat is good or not, but I do want to see tests run)

@mheon mheon added the bloat_approved Approve a PR in which binary file size grows by over 50k label Nov 4, 2024
@fixomatic-ctrl
Copy link
Contributor Author

please add Fixes #14527 as part of the commit message and squash the commits.

Done 👍

One thing I do wonder I would assume we can share much more code with the bindings/build code where we assemble the tar context dir but I haven't looked to closely itno the issue you mentioned

If we look at the nTar function in the build binding bellow

func nTar(excludes []string, sources ...string) (io.ReadCloser, error) {

is very similar (same logic) from the implementation of containers/storage/pkg/archive#TarWithOptions.

Note were are using containers/storage not moby so if anything can be added to simplify code here we can most likely make it happen if it is useful there

The remark is the same between the repositories docker, and the storage as the same methods are exposed for tar interactions.

After reading in details the implementation of containers/storage/pkg/archive#TarWithOptions we see that they are using a struct tarAppender which is very similar to my TarBuilder. However, the tarAppender alone is not useful as the core logic using it is in TarWithOptions. So just exposing it would not help much, because it is deeply used in the TarWithOptions implementation.

The requirement are to be able to take a mapping string -> string where the key is the source on the filesystem and the value is the target path in the tar. Due to the structure of the tar file of the kube build remote, we need to be able to build with precision the tarball with the right names.

I am not confortable enough with the different repository to be able to conduct such change.

@fixomatic-ctrl fixomatic-ctrl marked this pull request as ready for review November 5, 2024 16:35
@openshift-ci openshift-ci bot removed the do-not-merge/work-in-progress Indicates that a PR should not merge because it is a work in progress. label Nov 5, 2024
@fixomatic-ctrl
Copy link
Contributor Author

fixomatic-ctrl commented Jan 10, 2025

Happy new year!

cc @mheon @Luap99 do you think you might have some time to take a look again?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bloat_approved Approve a PR in which binary file size grows by over 50k release-note
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add podman play kube --build support for podman remotes
3 participants