Skip to content
This repository has been archived by the owner on Dec 16, 2024. It is now read-only.

Fix gateway controller deploy target #674

Merged

Conversation

mikenairn
Copy link
Member

@mikenairn mikenairn commented Nov 15, 2023

make deploy-gateway-controller deploys both the gateway and policy controller but was only updating the image for the gateway controller to the locally built version. This change updates the make targets to ensure that both the gateway and policy controller images are updated when testing the combined gateway/policy controller installation (e2e tests).

When deploying the controller using a local image loaded into kind, we also need to change the imagePullPolicy to Never or it will never start.

Verification

make local-setup OCM_SINGLE=true
make docker-build-gateway-controller kind-load-gateway-controller docker-build-policy-controller kind-load-policy-controller deploy-gateway-controller

Check the gateway and policy deployments are both using the local image

kubectl get deployments/mgc-policy-controller -n multicluster-gateway-controller-system -o json| jq .spec.template.spec.containers[0].image
"policy-controller:latest"
kubectl get deployments/mgc-controller-manager -n multicluster-gateway-controller-system -o json| jq .spec.template.spec.containers[0].image
"controller:latest"

@mikenairn
Copy link
Member Author

@maleck13 @laurafitzgerald @sergioifg94 The e2e tests are currently not testing what we think they are testing (policy controller is always using the published quay.io main image). If one of you has a minute to review, would be good to get this merged ASAP.

Copy link
Contributor

@laurafitzgerald laurafitzgerald left a comment

Choose a reason for hiding this comment

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

@mikenairn left a couple of questions inline. none are blockers for merging this.

I've completed the verification steps and the expected images are running in cluster.

.gitignore Show resolved Hide resolved
@@ -0,0 +1,10 @@
# Local deployment overlay.
Copy link
Contributor

Choose a reason for hiding this comment

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

This could be a nit:
And not essential for this change.

For a number of things I'd suggest some naming updates.
For example the

  • config/deploy is referring to gateway-controller
  • config/policy-controller is referring to policy-controller
    Also
  • mgc-controller-manager is used for deployment/pod naming for gateway-controller
  • mgc-policy-controller is used for deployment/pod naming for policy-controller

technically mgc-policy-controller could be expanded to multicluster-gateway-controller-policy-controller which could cause some confusion. maybe the prefix isn't appropriate anymore.

Copy link
Member Author

Choose a reason for hiding this comment

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

This could be a nit: And not essential for this change.

For a number of things I'd suggest some naming updates. For example the

* config/deploy is referring to gateway-controller

* config/policy-controller is referring to policy-controller

If it was intending to stay this way I'd agree, something like config/policy-controller and config/gateway-controller would make more sense, but moving the policy config was a first step and will hopefully soon be moved out of this repo entirely.

The policy-controller will eventually be it's own repo, and the current contents of config/policy-controller should end up being the contents of config in that repo and removed entirely from here.

  Also

* mgc-controller-manager is used for deployment/pod naming for gateway-controller

* mgc-policy-controller is used for deployment/pod naming for policy-controller

I agree there were some naming inconsistencies brought in during the last couple of PRs (#644, #648, #667) that need resolved. Not really my intention to try and fix all of that here though.

technically mgc-policy-controller could be expanded to multicluster-gateway-controller-policy-controller which could cause some confusion. maybe the prefix isn't appropriate anymore.

I'm not sure what this should end up being, but it should have a prefix i think that is added to all resources created as part of this deployment. Currently that is mgc.

Copy link
Contributor

Choose a reason for hiding this comment

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

This could be a nit: And not essential for this change.
For a number of things I'd suggest some naming updates. For example the

* config/deploy is referring to gateway-controller

* config/policy-controller is referring to policy-controller

If it was intending to stay this way I'd agree, something like config/policy-controller and config/gateway-controller would make more sense, but moving the policy config was a first step and will hopefully soon be moved out of this repo entirely.

The policy-controller will eventually be it's own repo, and the current contents of config/policy-controller should end up being the contents of config in that repo and removed entirely from here.

cool. no need for this change then.

  Also

* mgc-controller-manager is used for deployment/pod naming for gateway-controller

* mgc-policy-controller is used for deployment/pod naming for policy-controller

I agree there were some naming inconsistencies brought in during the last couple of PRs (#644, #648, #667) that need resolved. Not really my intention to try and fix all of that here though.

yeah that's fair. I think it would be good to address them. And it's not essential to fix them here. We could create a follow on issue about it?

technically mgc-policy-controller could be expanded to multicluster-gateway-controller-policy-controller which could cause some confusion. maybe the prefix isn't appropriate anymore.

I'm not sure what this should end up being, but it should have a prefix i think that is added to all resources created as part of this deployment. Currently that is mgc.

`make deploy-gateway-controller` deploys both the gateway and policy
controller but was only updating the image for the gateway controller to
the locally built version. This chnage updates the make targets to
ensure that both the gateway and policy controller images are updated
when testing the combined gateway/policy controller installation (e2e
tests).
@mikenairn mikenairn force-pushed the fix_gateway_deploy_make_target branch from 6ce9ea6 to 667b02c Compare November 16, 2023 10:58
Copy link
Contributor

openshift-ci bot commented Nov 20, 2023

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: maleck13, mikenairn

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

The pull request process is described 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

@maleck13
Copy link
Contributor

/lgtm

@openshift-ci openshift-ci bot added the lgtm label Nov 20, 2023
@openshift-merge-bot openshift-merge-bot bot merged commit 43df878 into Kuadrant:main Nov 20, 2023
9 checks passed
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants