From c74e86e9d145a7ae1694478ee1db44f5978d7f00 Mon Sep 17 00:00:00 2001 From: Gong Zhang Date: Fri, 13 Oct 2023 17:05:06 +0800 Subject: [PATCH] Remove context from capv customized controller context Remove context from capv customized controller context, also get rid of containedctx exceptions. Signed-off-by: Gong Zhang --- controllers/controllers_suite_test.go | 4 +- .../serviceaccount_controller_intg_test.go | 56 ++++++++++--------- .../servicediscovery_controller_intg_test.go | 22 ++++---- .../vspheredeploymentzone_controller.go | 4 +- ...redeploymentzone_controller_domain_test.go | 2 +- .../vspheredeploymentzone_controller_test.go | 2 +- controllers/vspherevm_controller.go | 2 +- main.go | 6 +- pkg/clustermodule/util.go | 6 +- pkg/clustermodule/util_test.go | 4 +- pkg/context/controller_manager_context.go | 3 - pkg/context/fake/fake_cluster_context.go | 12 ++-- pkg/context/fake/fake_controller_context.go | 10 ++-- .../fake/fake_controller_manager_context.go | 3 - pkg/context/fake/fake_vm_context.go | 16 +++--- pkg/context/vm_context.go | 5 +- pkg/context/vspheredeploymentzone_context.go | 5 +- pkg/manager/manager.go | 1 - .../govmomi/cluster/cluster_suite_test.go | 4 +- pkg/services/govmomi/cluster/rule_test.go | 3 +- pkg/services/govmomi/cluster/service.go | 3 - pkg/services/govmomi/cluster/vmgroup_test.go | 5 +- pkg/services/govmomi/context.go | 4 +- pkg/services/govmomi/create_test.go | 8 +-- pkg/services/govmomi/service.go | 4 +- pkg/services/govmomi/service_test.go | 4 +- pkg/services/govmomi/util.go | 4 +- pkg/services/govmomi/vcenter/clone.go | 2 +- pkg/services/govmomi/vcenter/clone_test.go | 4 +- pkg/services/vimmachine_test.go | 14 ++--- pkg/util/testutil.go | 7 +-- test/helpers/vmware/intg_test_context.go | 6 +- 32 files changed, 111 insertions(+), 124 deletions(-) diff --git a/controllers/controllers_suite_test.go b/controllers/controllers_suite_test.go index c4d8c84e2c..60b52d4790 100644 --- a/controllers/controllers_suite_test.go +++ b/controllers/controllers_suite_test.go @@ -117,7 +117,7 @@ func setup() { go func() { fmt.Println("Starting the manager") - if err := testEnv.StartManager(testEnv.GetContext()); err != nil { + if err := testEnv.StartManager(ctx); err != nil { panic(fmt.Sprintf("failed to start the envtest manager: %v", err)) } }() @@ -132,7 +132,7 @@ func setup() { Name: manager.DefaultPodNamespace, }, } - if err := testEnv.Create(testEnv.GetContext(), ns); err != nil { + if err := testEnv.Create(ctx, ns); err != nil { panic("unable to create controller namespace") } } diff --git a/controllers/serviceaccount_controller_intg_test.go b/controllers/serviceaccount_controller_intg_test.go index a3fea31b03..e596e5b15c 100644 --- a/controllers/serviceaccount_controller_intg_test.go +++ b/controllers/serviceaccount_controller_intg_test.go @@ -17,6 +17,7 @@ limitations under the License. package controllers import ( + "context" "fmt" "os" "reflect" @@ -41,12 +42,13 @@ import ( var _ = Describe("ProviderServiceAccount controller integration tests", func() { var intCtx *helpers.IntegrationTestContext + ctx := context.Background() BeforeEach(func() { intCtx = helpers.NewIntegrationTestContextWithClusters(ctx, testEnv.Manager.GetClient()) testSystemSvcAcctCM := "test-system-svc-acct-cm" cfgMap := getSystemServiceAccountsConfigMap(intCtx.VSphereCluster.Namespace, testSystemSvcAcctCM) - Expect(intCtx.Client.Create(intCtx, cfgMap)).To(Succeed()) + Expect(intCtx.Client.Create(ctx, cfgMap)).To(Succeed()) _ = os.Setenv("SERVICE_ACCOUNTS_CM_NAMESPACE", intCtx.VSphereCluster.Namespace) _ = os.Setenv("SERVICE_ACCOUNTS_CM_NAME", testSystemSvcAcctCM) }) @@ -62,13 +64,13 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { ) BeforeEach(func() { pSvcAccount = getTestProviderServiceAccount(intCtx.Namespace, intCtx.VSphereCluster) - createTestResource(intCtx, intCtx.Client, pSvcAccount) - assertEventuallyExistsInNamespace(intCtx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) + createTestResource(ctx, intCtx.Client, pSvcAccount) + assertEventuallyExistsInNamespace(ctx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) }) AfterEach(func() { // Deleting the provider service account is not strictly required as the context itself // gets teared down but keeping it for clarity. - deleteTestResource(intCtx, intCtx.Client, pSvcAccount) + deleteTestResource(ctx, intCtx.Client, pSvcAccount) }) Context("When serviceaccount secret is created", func() { @@ -77,7 +79,7 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { // to create a secret containing the bearer token, cert etc for a service account. We need to // simulate the job of the token controller by waiting for the service account creation and then updating it // with a prototype secret. - assertServiceAccountAndUpdateSecret(intCtx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName()) + assertServiceAccountAndUpdateSecret(ctx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName()) }) It("should create the role and role binding", func() { @@ -102,7 +104,7 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { It("Should reconcile", func() { By("Creating the target secret in the target namespace") - assertTargetSecret(intCtx, intCtx.GuestClient, pSvcAccount.Spec.TargetNamespace, testTargetSecret) + assertTargetSecret(ctx, intCtx.GuestClient, pSvcAccount.Spec.TargetNamespace, testTargetSecret) }) }) @@ -113,16 +115,16 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { Name: pSvcAccount.Spec.TargetNamespace, }, } - Expect(intCtx.GuestClient.Create(intCtx, targetNSObj)).To(Succeed()) - createTargetSecretWithInvalidToken(intCtx, intCtx.GuestClient, pSvcAccount.Spec.TargetNamespace) - assertServiceAccountAndUpdateSecret(intCtx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName()) + Expect(intCtx.GuestClient.Create(ctx, targetNSObj)).To(Succeed()) + createTargetSecretWithInvalidToken(ctx, intCtx.GuestClient, pSvcAccount.Spec.TargetNamespace) + assertServiceAccountAndUpdateSecret(ctx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName()) }) AfterEach(func() { - deleteTestResource(intCtx, intCtx.GuestClient, targetNSObj) + deleteTestResource(ctx, intCtx.GuestClient, targetNSObj) }) It("Should reconcile", func() { By("Updating the target secret in the target namespace") - assertTargetSecret(intCtx, intCtx.GuestClient, pSvcAccount.Spec.TargetNamespace, testTargetSecret) + assertTargetSecret(ctx, intCtx.GuestClient, pSvcAccount.Spec.TargetNamespace, testTargetSecret) }) }) }) @@ -134,20 +136,20 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { Expect(ok).To(BeTrue()) cluster := &clusterv1.Cluster{} key := client.ObjectKey{Namespace: intCtx.Namespace, Name: clusterName} - Expect(intCtx.Client.Get(intCtx, key, cluster)).To(Succeed()) - Expect(intCtx.Client.Delete(intCtx, cluster)).To(Succeed()) + Expect(intCtx.Client.Get(ctx, key, cluster)).To(Succeed()) + Expect(intCtx.Client.Delete(ctx, cluster)).To(Succeed()) }) By("Creating the ProviderServiceAccount", func() { pSvcAccount := getTestProviderServiceAccount(intCtx.Namespace, intCtx.VSphereCluster) - createTestResource(intCtx, intCtx.Client, pSvcAccount) - assertEventuallyExistsInNamespace(intCtx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) + createTestResource(ctx, intCtx.Client, pSvcAccount) + assertEventuallyExistsInNamespace(ctx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) }) By("ProviderServiceAccountsReady Condition is not set", func() { vsphereCluster := &vmwarev1.VSphereCluster{} key := client.ObjectKey{Namespace: intCtx.Namespace, Name: intCtx.VSphereCluster.GetName()} - Expect(intCtx.Client.Get(intCtx, key, vsphereCluster)).To(Succeed()) + Expect(intCtx.Client.Get(ctx, key, vsphereCluster)).To(Succeed()) Expect(conditions.Has(vsphereCluster, vmwarev1.ProviderServiceAccountsReadyCondition)).To(BeFalse()) }) }) @@ -164,19 +166,19 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { Name: fmt.Sprintf("%s-kubeconfig", clusterName), }, } - Expect(intCtx.Client.Delete(intCtx, secret)).To(Succeed()) + Expect(intCtx.Client.Delete(ctx, secret)).To(Succeed()) }) By("Creating the ProviderServiceAccount", func() { pSvcAccount := getTestProviderServiceAccount(intCtx.Namespace, intCtx.VSphereCluster) - createTestResource(intCtx, intCtx.Client, pSvcAccount) - assertEventuallyExistsInNamespace(intCtx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) + createTestResource(ctx, intCtx.Client, pSvcAccount) + assertEventuallyExistsInNamespace(ctx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) }) By("ProviderServiceAccountsReady Condition is not set", func() { vsphereCluster := &vmwarev1.VSphereCluster{} key := client.ObjectKey{Namespace: intCtx.Namespace, Name: intCtx.VSphereCluster.GetName()} - Expect(intCtx.Client.Get(intCtx, key, vsphereCluster)).To(Succeed()) + Expect(intCtx.Client.Get(ctx, key, vsphereCluster)).To(Succeed()) Expect(conditions.Has(vsphereCluster, vmwarev1.ProviderServiceAccountsReadyCondition)).To(BeFalse()) }) }) @@ -193,7 +195,7 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { pSvcAccount.ObjectMeta.Annotations = map[string]string{ "cluster.x-k8s.io/paused": "true", } - createTestResource(intCtx, intCtx.Client, pSvcAccount) + createTestResource(ctx, intCtx.Client, pSvcAccount) oldOwnerUID := uuid.New().String() role = &rbacv1.Role{ @@ -246,9 +248,9 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { }, } - createTestResource(intCtx, intCtx.Client, role) - createTestResource(intCtx, intCtx.Client, roleBinding) - assertEventuallyExistsInNamespace(intCtx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) + createTestResource(ctx, intCtx.Client, role) + createTestResource(ctx, intCtx.Client, roleBinding) + assertEventuallyExistsInNamespace(ctx, intCtx.Client, intCtx.Namespace, pSvcAccount.GetName(), pSvcAccount) svcAccountPatcher, err := patch.NewHelper(pSvcAccount, intCtx.Client) Expect(err).ToNot(HaveOccurred()) // Unpause the ProviderServiceAccount so we can reconcile @@ -256,9 +258,9 @@ var _ = Describe("ProviderServiceAccount controller integration tests", func() { Expect(svcAccountPatcher.Patch(ctx, pSvcAccount)).To(Succeed()) }) AfterEach(func() { - deleteTestResource(intCtx, intCtx.Client, pSvcAccount) - deleteTestResource(intCtx, intCtx.Client, role) - deleteTestResource(intCtx, intCtx.Client, roleBinding) + deleteTestResource(ctx, intCtx.Client, pSvcAccount) + deleteTestResource(ctx, intCtx.Client, role) + deleteTestResource(ctx, intCtx.Client, roleBinding) }) It("should fully reconciles dependent resources", func() { diff --git a/controllers/servicediscovery_controller_intg_test.go b/controllers/servicediscovery_controller_intg_test.go index fe5c9fb2fc..98b704ff0f 100644 --- a/controllers/servicediscovery_controller_intg_test.go +++ b/controllers/servicediscovery_controller_intg_test.go @@ -42,17 +42,17 @@ var _ = Describe("Service Discovery controller integration tests", func() { initObjects = []client.Object{ newTestSupervisorLBServiceWithIPStatus(), } - createObjects(intCtx, intCtx.Client, initObjects) + createObjects(ctx, intCtx.Client, initObjects) Expect(intCtx.Client.Status().Update(ctx, newTestSupervisorLBServiceWithIPStatus())).To(Succeed()) }) AfterEach(func() { - deleteObjects(intCtx, intCtx.Client, initObjects) + deleteObjects(ctx, intCtx.Client, initObjects) }) It("Should reconcile headless svc", func() { By("creating a service and endpoints using the VIP in the guest cluster") headlessSvc := &corev1.Service{} - assertEventuallyExistsInNamespace(intCtx, intCtx.Client, "kube-system", "kube-apiserver-lb-svc", headlessSvc) - assertHeadlessSvcWithVIPEndpoints(intCtx, intCtx.GuestClient, supervisorHeadlessSvcNamespace, supervisorHeadlessSvcName) + assertEventuallyExistsInNamespace(ctx, intCtx.Client, "kube-system", "kube-apiserver-lb-svc", headlessSvc) + assertHeadlessSvcWithVIPEndpoints(ctx, intCtx.GuestClient, supervisorHeadlessSvcNamespace, supervisorHeadlessSvcName) }) }) @@ -60,33 +60,33 @@ var _ = Describe("Service Discovery controller integration tests", func() { BeforeEach(func() { initObjects = []client.Object{ newTestConfigMapWithHost(testSupervisorAPIServerFIP)} - createObjects(intCtx, intCtx.Client, initObjects) + createObjects(ctx, intCtx.Client, initObjects) }) AfterEach(func() { - deleteObjects(intCtx, intCtx.Client, initObjects) + deleteObjects(ctx, intCtx.Client, initObjects) }) It("Should reconcile headless svc", func() { By("creating a service and endpoints using the FIP in the guest cluster") - assertHeadlessSvcWithFIPEndpoints(intCtx, intCtx.GuestClient, supervisorHeadlessSvcNamespace, supervisorHeadlessSvcName) + assertHeadlessSvcWithFIPEndpoints(ctx, intCtx.GuestClient, supervisorHeadlessSvcNamespace, supervisorHeadlessSvcName) }) }) Context("When headless svc and endpoints already exists", func() { BeforeEach(func() { // Create the svc & endpoint objects in guest cluster - createObjects(intCtx, intCtx.GuestClient, newTestHeadlessSvcEndpoints()) + createObjects(ctx, intCtx.GuestClient, newTestHeadlessSvcEndpoints()) // Init objects in the supervisor cluster initObjects = []client.Object{ newTestSupervisorLBServiceWithIPStatus()} - createObjects(intCtx, intCtx.Client, initObjects) + createObjects(ctx, intCtx.Client, initObjects) Expect(intCtx.Client.Status().Update(ctx, newTestSupervisorLBServiceWithIPStatus())).To(Succeed()) }) AfterEach(func() { - deleteObjects(intCtx, intCtx.Client, initObjects) + deleteObjects(ctx, intCtx.Client, initObjects) // Note: No need to delete guest cluster objects as a new guest cluster testenv endpoint is created for each test. }) It("Should reconcile headless svc", func() { By("updating the service and endpoints using the VIP in the guest cluster") - assertHeadlessSvcWithUpdatedVIPEndpoints(intCtx, intCtx.GuestClient, supervisorHeadlessSvcNamespace, supervisorHeadlessSvcName) + assertHeadlessSvcWithUpdatedVIPEndpoints(ctx, intCtx.GuestClient, supervisorHeadlessSvcNamespace, supervisorHeadlessSvcName) }) }) }) diff --git a/controllers/vspheredeploymentzone_controller.go b/controllers/vspheredeploymentzone_controller.go index 703752b3e9..d1496d8abb 100644 --- a/controllers/vspheredeploymentzone_controller.go +++ b/controllers/vspheredeploymentzone_controller.go @@ -129,7 +129,7 @@ func (r vsphereDeploymentZoneReconciler) Reconcile(ctx context.Context, request PatchHelper: patchHelper, } defer func() { - if err := vsphereDeploymentZoneContext.Patch(); err != nil { + if err := vsphereDeploymentZoneContext.Patch(ctx); err != nil { reterr = kerrors.NewAggregate([]error{reterr, err}) } }() @@ -233,7 +233,7 @@ func (r vsphereDeploymentZoneReconciler) getVCenterSession(ctx context.Context, } logger.Info("using server credentials to create the authenticated session") params = params.WithUserInfo(creds.Username, creds.Password) - return session.GetOrCreate(r.Context, + return session.GetOrCreate(ctx, params) } diff --git a/controllers/vspheredeploymentzone_controller_domain_test.go b/controllers/vspheredeploymentzone_controller_domain_test.go index 6fc93dffa2..9fde52fcf9 100644 --- a/controllers/vspheredeploymentzone_controller_domain_test.go +++ b/controllers/vspheredeploymentzone_controller_domain_test.go @@ -62,7 +62,7 @@ func TestVsphereDeploymentZoneReconciler_Reconcile_VerifyFailureDomain_ComputeCl WithServer(simr.ServerURL().Host). WithUserInfo(simr.Username(), simr.Password()). WithDatacenter("*") - authSession, err := session.GetOrCreate(controllerCtx, params) + authSession, err := session.GetOrCreate(ctx, params) g.Expect(err).NotTo(HaveOccurred()) vsphereFailureDomain := &infrav1.VSphereFailureDomain{ diff --git a/controllers/vspheredeploymentzone_controller_test.go b/controllers/vspheredeploymentzone_controller_test.go index 5a74a72c1b..ee49669497 100644 --- a/controllers/vspheredeploymentzone_controller_test.go +++ b/controllers/vspheredeploymentzone_controller_test.go @@ -617,7 +617,7 @@ func TestVsphereDeploymentZone_Failed_ReconcilePlacementConstraint(t *testing.T) mgmtContext.Password = pass controllerCtx := fake.NewControllerContext(mgmtContext) - Expect(controllerCtx.Client.Create(controllerCtx, &infrav1.VSphereFailureDomain{ + Expect(controllerCtx.Client.Create(ctx, &infrav1.VSphereFailureDomain{ ObjectMeta: metav1.ObjectMeta{ Name: "blah", }, diff --git a/controllers/vspherevm_controller.go b/controllers/vspherevm_controller.go index 216dff5970..0746e2c0a9 100644 --- a/controllers/vspherevm_controller.go +++ b/controllers/vspherevm_controller.go @@ -258,7 +258,7 @@ func (r vmReconciler) Reconcile(ctx context.Context, req ctrl.Request) (_ ctrl.R ) // Patch the VSphereVM resource. - if err := vmContext.Patch(); err != nil { + if err := vmContext.Patch(ctx); err != nil { reterr = kerrors.NewAggregate([]error{reterr, err}) } }() diff --git a/main.go b/main.go index 5ea3182bfd..3aed5c0145 100644 --- a/main.go +++ b/main.go @@ -256,7 +256,7 @@ func main() { // Create a function that adds all the controllers and webhooks to the manager. addToManager := func(ctx context.Context, controllerCtx *capvcontext.ControllerManagerContext, mgr ctrlmgr.Manager) error { - tracker, err := setupRemoteClusterCacheTracker(controllerCtx, mgr) + tracker, err := setupRemoteClusterCacheTracker(ctx, mgr) if err != nil { return perrors.Wrapf(err, "unable to create remote cluster cache tracker") } @@ -422,7 +422,7 @@ func concurrency(c int) controller.Options { return controller.Options{MaxConcurrentReconciles: c} } -func setupRemoteClusterCacheTracker(controllerCtx *capvcontext.ControllerManagerContext, mgr ctrlmgr.Manager) (*remote.ClusterCacheTracker, error) { +func setupRemoteClusterCacheTracker(ctx context.Context, mgr ctrlmgr.Manager) (*remote.ClusterCacheTracker, error) { secretCachingClient, err := client.New(mgr.GetConfig(), client.Options{ HTTPClient: mgr.GetHTTPClient(), Cache: &client.CacheOptions{ @@ -452,7 +452,7 @@ func setupRemoteClusterCacheTracker(controllerCtx *capvcontext.ControllerManager Client: mgr.GetClient(), Tracker: tracker, WatchFilterValue: managerOpts.WatchFilterValue, - }).SetupWithManager(controllerCtx, mgr, concurrency(clusterCacheTrackerConcurrency)); err != nil { + }).SetupWithManager(ctx, mgr, concurrency(clusterCacheTrackerConcurrency)); err != nil { return nil, perrors.Wrapf(err, "unable to create ClusterCacheReconciler controller") } diff --git a/pkg/clustermodule/util.go b/pkg/clustermodule/util.go index a64b9632c5..292a7ac8d5 100644 --- a/pkg/clustermodule/util.go +++ b/pkg/clustermodule/util.go @@ -22,7 +22,7 @@ import ( "github.com/blang/semver" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" ) // Compare returns whether both the cluster module slices are the same. @@ -50,8 +50,8 @@ func Compare(oldMods, newMods []infrav1.ClusterModule) bool { } // IsClusterCompatible checks if the VCenterVersion is compatibly with CAPV. Only version 7 and over are supported. -func IsClusterCompatible(ctx *context.ClusterContext) bool { - version := ctx.VSphereCluster.Status.VCenterVersion +func IsClusterCompatible(clusterCtx *capvcontext.ClusterContext) bool { + version := clusterCtx.VSphereCluster.Status.VCenterVersion if version == "" { return false } diff --git a/pkg/clustermodule/util_test.go b/pkg/clustermodule/util_test.go index 531c5cae93..c2d76cc0b4 100644 --- a/pkg/clustermodule/util_test.go +++ b/pkg/clustermodule/util_test.go @@ -23,7 +23,7 @@ import ( "github.com/onsi/gomega" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" ) func Test_IsCompatible(t *testing.T) { @@ -65,7 +65,7 @@ func Test_IsCompatible(t *testing.T) { } g := gomega.NewWithT(t) - isCompatible := IsClusterCompatible(&context.ClusterContext{ + isCompatible := IsClusterCompatible(&capvcontext.ClusterContext{ VSphereCluster: cluster, }) g.Expect(isCompatible).To(gomega.Equal(tt.isCompatible)) diff --git a/pkg/context/controller_manager_context.go b/pkg/context/controller_manager_context.go index d0576e2c4c..29049cb729 100644 --- a/pkg/context/controller_manager_context.go +++ b/pkg/context/controller_manager_context.go @@ -17,7 +17,6 @@ limitations under the License. package context import ( - "context" "sync" "time" @@ -33,8 +32,6 @@ import ( // ControllerManagerContext is the context of the controller that owns the // controllers. type ControllerManagerContext struct { - context.Context //nolint:containedctx - // Namespace is the namespace in which the resource is located responsible // for running the controller manager. Namespace string diff --git a/pkg/context/fake/fake_cluster_context.go b/pkg/context/fake/fake_cluster_context.go index 9fed683791..cd9c7f7761 100644 --- a/pkg/context/fake/fake_cluster_context.go +++ b/pkg/context/fake/fake_cluster_context.go @@ -17,29 +17,31 @@ limitations under the License. package fake import ( + "context" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" clusterv1 "sigs.k8s.io/cluster-api/api/v1beta1" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" ) // NewClusterContext returns a fake ClusterContext for unit testing // reconcilers with a fake client. -func NewClusterContext(ctx *context.ControllerContext) *context.ClusterContext { +func NewClusterContext(controllerCtx *capvcontext.ControllerContext) *capvcontext.ClusterContext { // Create the cluster resources. cluster := newClusterV1() vsphereCluster := newVSphereCluster(cluster) // Add the cluster resources to the fake cluster client. - if err := ctx.Client.Create(ctx, &cluster); err != nil { + if err := controllerCtx.Client.Create(context.Background(), &cluster); err != nil { panic(err) } - if err := ctx.Client.Create(ctx, &vsphereCluster); err != nil { + if err := controllerCtx.Client.Create(context.Background(), &vsphereCluster); err != nil { panic(err) } - return &context.ClusterContext{ + return &capvcontext.ClusterContext{ Cluster: &cluster, VSphereCluster: &vsphereCluster, } diff --git a/pkg/context/fake/fake_controller_context.go b/pkg/context/fake/fake_controller_context.go index 21971ee8bf..5adf97b449 100644 --- a/pkg/context/fake/fake_controller_context.go +++ b/pkg/context/fake/fake_controller_context.go @@ -19,17 +19,17 @@ package fake import ( clientrecord "k8s.io/client-go/tools/record" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" "sigs.k8s.io/cluster-api-provider-vsphere/pkg/record" ) // NewControllerContext returns a fake ControllerContext for unit testing // reconcilers with a fake client. -func NewControllerContext(ctx *context.ControllerManagerContext) *context.ControllerContext { - return &context.ControllerContext{ - ControllerManagerContext: ctx, +func NewControllerContext(controllerManagerCtx *capvcontext.ControllerManagerContext) *capvcontext.ControllerContext { + return &capvcontext.ControllerContext{ + ControllerManagerContext: controllerManagerCtx, Name: ControllerName, - Logger: ctx.Logger.WithName(ControllerName), + Logger: controllerManagerCtx.Logger.WithName(ControllerName), Recorder: record.New(clientrecord.NewFakeRecorder(1024)), } } diff --git a/pkg/context/fake/fake_controller_manager_context.go b/pkg/context/fake/fake_controller_manager_context.go index b9787880de..ec5bf34a4b 100644 --- a/pkg/context/fake/fake_controller_manager_context.go +++ b/pkg/context/fake/fake_controller_manager_context.go @@ -17,8 +17,6 @@ limitations under the License. package fake import ( - "context" - vmoprv1 "github.com/vmware-tanzu/vm-operator/api/v1alpha1" "k8s.io/apimachinery/pkg/runtime" clientgoscheme "k8s.io/client-go/kubernetes/scheme" @@ -56,7 +54,6 @@ func NewControllerManagerContext(initObjects ...client.Object) *capvcontext.Cont ).WithObjects(initObjects...).Build() return &capvcontext.ControllerManagerContext{ - Context: context.Background(), Client: clientWithObjects, Logger: ctrllog.Log.WithName(ControllerManagerName), Scheme: scheme, diff --git a/pkg/context/fake/fake_vm_context.go b/pkg/context/fake/fake_vm_context.go index 1567580dcc..72aa1be6f5 100644 --- a/pkg/context/fake/fake_vm_context.go +++ b/pkg/context/fake/fake_vm_context.go @@ -17,33 +17,35 @@ limitations under the License. package fake import ( + "context" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "sigs.k8s.io/cluster-api/util/patch" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" ) // NewVMContext returns a fake VMContext for unit testing // reconcilers with a fake client. -func NewVMContext(ctx *context.ControllerContext) *context.VMContext { +func NewVMContext(controllerCtx *capvcontext.ControllerContext) *capvcontext.VMContext { // Create the resources. vsphereVM := newVSphereVM() // Add the resources to the fake client. - if err := ctx.Client.Create(ctx, &vsphereVM); err != nil { + if err := controllerCtx.Client.Create(context.Background(), &vsphereVM); err != nil { panic(err) } - helper, err := patch.NewHelper(&vsphereVM, ctx.Client) + helper, err := patch.NewHelper(&vsphereVM, controllerCtx.Client) if err != nil { panic(err) } - return &context.VMContext{ - ControllerContext: ctx, + return &capvcontext.VMContext{ + ControllerContext: controllerCtx, VSphereVM: &vsphereVM, - Logger: ctx.Logger.WithName(vsphereVM.Name), + Logger: controllerCtx.Logger.WithName(vsphereVM.Name), PatchHelper: helper, } } diff --git a/pkg/context/vm_context.go b/pkg/context/vm_context.go index 6cf34856a8..c384153ad5 100644 --- a/pkg/context/vm_context.go +++ b/pkg/context/vm_context.go @@ -18,6 +18,7 @@ limitations under the License. package context import ( + "context" "fmt" "github.com/go-logr/logr" @@ -44,8 +45,8 @@ func (c *VMContext) String() string { } // Patch updates the object and its status on the API server. -func (c *VMContext) Patch() error { - return c.PatchHelper.Patch(c, c.VSphereVM) +func (c *VMContext) Patch(ctx context.Context) error { + return c.PatchHelper.Patch(ctx, c.VSphereVM) } // GetLogger returns this context's logger. diff --git a/pkg/context/vspheredeploymentzone_context.go b/pkg/context/vspheredeploymentzone_context.go index ca3ec273c9..be78910b18 100644 --- a/pkg/context/vspheredeploymentzone_context.go +++ b/pkg/context/vspheredeploymentzone_context.go @@ -17,6 +17,7 @@ limitations under the License. package context import ( + "context" "fmt" "github.com/go-logr/logr" @@ -37,7 +38,7 @@ type VSphereDeploymentZoneContext struct { } // Patch patches the VSphereDeploymentZone. -func (c *VSphereDeploymentZoneContext) Patch() error { +func (c *VSphereDeploymentZoneContext) Patch(ctx context.Context) error { conditions.SetSummary(c.VSphereDeploymentZone, conditions.WithConditions( infrav1.VCenterAvailableCondition, @@ -45,7 +46,7 @@ func (c *VSphereDeploymentZoneContext) Patch() error { infrav1.PlacementConstraintMetCondition, ), ) - return c.PatchHelper.Patch(c, c.VSphereDeploymentZone) + return c.PatchHelper.Patch(ctx, c.VSphereDeploymentZone) } // String returns a string with the GroupVersionKind and name of the VSphereDeploymentZone. diff --git a/pkg/manager/manager.go b/pkg/manager/manager.go index cf5ea1f695..10e333a61d 100644 --- a/pkg/manager/manager.go +++ b/pkg/manager/manager.go @@ -82,7 +82,6 @@ func New(ctx context.Context, opts Options) (Manager, error) { // Build the controller manager context. controllerManagerContext := &capvcontext.ControllerManagerContext{ - Context: context.Background(), WatchNamespaces: opts.Cache.Namespaces, Namespace: opts.PodNamespace, Name: opts.PodName, diff --git a/pkg/services/govmomi/cluster/cluster_suite_test.go b/pkg/services/govmomi/cluster/cluster_suite_test.go index d872a74c76..5187c9ec57 100644 --- a/pkg/services/govmomi/cluster/cluster_suite_test.go +++ b/pkg/services/govmomi/cluster/cluster_suite_test.go @@ -17,7 +17,6 @@ limitations under the License. package cluster import ( - "context" "testing" . "github.com/onsi/ginkgo/v2" @@ -33,8 +32,7 @@ func TestCluster(t *testing.T) { } type testComputeClusterCtx struct { - context.Context //nolint:containedctx - finder *find.Finder + finder *find.Finder } func (t testComputeClusterCtx) GetSession() *session.Session { diff --git a/pkg/services/govmomi/cluster/rule_test.go b/pkg/services/govmomi/cluster/rule_test.go index 05b14b6bda..1aef90c0e6 100644 --- a/pkg/services/govmomi/cluster/rule_test.go +++ b/pkg/services/govmomi/cluster/rule_test.go @@ -47,8 +47,7 @@ func TestVerifyAffinityRule(t *testing.T) { finder.SetDatacenter(dc) computeClusterCtx := testComputeClusterCtx{ - Context: context.Background(), - finder: finder, + finder: finder, } rule, err := VerifyAffinityRule(ctx, computeClusterCtx, "DC0_C0", "blah-host-group", "blah-vm-group") diff --git a/pkg/services/govmomi/cluster/service.go b/pkg/services/govmomi/cluster/service.go index 5424e724de..8509318319 100644 --- a/pkg/services/govmomi/cluster/service.go +++ b/pkg/services/govmomi/cluster/service.go @@ -27,9 +27,6 @@ import ( ) type computeClusterContext interface { - // TODO(zhanggbj): remove context.Context in this interface after refactoring context for all controllers. - context.Context - GetSession() *session.Session } diff --git a/pkg/services/govmomi/cluster/vmgroup_test.go b/pkg/services/govmomi/cluster/vmgroup_test.go index a61be9e560..d2d8206861 100644 --- a/pkg/services/govmomi/cluster/vmgroup_test.go +++ b/pkg/services/govmomi/cluster/vmgroup_test.go @@ -43,8 +43,7 @@ func Test_VMGroup(t *testing.T) { finder.SetDatacenter(dc) computeClusterCtx := testComputeClusterCtx{ - Context: context.Background(), - finder: finder, + finder: finder, } computeClusterName := "DC0_C0" @@ -62,7 +61,7 @@ func Test_VMGroup(t *testing.T) { g.Expect(err).NotTo(HaveOccurred()) g.Expect(hasVM).To(BeFalse()) - task, err := vmGrp.Add(computeClusterCtx, vmRef) + task, err := vmGrp.Add(ctx, vmRef) g.Expect(err).NotTo(HaveOccurred()) g.Expect(task.Wait(ctx)).To(Succeed()) g.Expect(vmGrp.listVMs()).To(HaveLen(3)) diff --git a/pkg/services/govmomi/context.go b/pkg/services/govmomi/context.go index 798a0a157c..bde225b641 100644 --- a/pkg/services/govmomi/context.go +++ b/pkg/services/govmomi/context.go @@ -21,11 +21,11 @@ import ( "github.com/vmware/govmomi/vim25/types" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" ) type virtualMachineContext struct { - context.VMContext + capvcontext.VMContext Ref types.ManagedObjectReference Obj *object.VirtualMachine State *infrav1.VirtualMachine diff --git a/pkg/services/govmomi/create_test.go b/pkg/services/govmomi/create_test.go index ebf26bd76d..7478d71eb3 100644 --- a/pkg/services/govmomi/create_test.go +++ b/pkg/services/govmomi/create_test.go @@ -43,8 +43,9 @@ func TestCreate(t *testing.T) { vmContext := fake.NewVMContext(fake.NewControllerContext(fake.NewControllerManagerContext())) vmContext.VSphereVM.Spec.Server = simr.ServerURL().Host + ctx := context.Background() authSession, err := session.GetOrCreate( - vmContext.Context, + ctx, session.NewParams(). WithServer(vmContext.VSphereVM.Spec.Server). WithUserInfo(simr.Username(), simr.Password()). @@ -63,7 +64,6 @@ func TestCreate(t *testing.T) { disk := object.VirtualDeviceList(vm.Config.Hardware.Device).SelectByType((*types.VirtualDisk)(nil))[0].(*types.VirtualDisk) disk.CapacityInKB = int64(vmContext.VSphereVM.Spec.DiskGiB) * 1024 * 1024 - ctx := context.Background() if err := createVM(ctx, vmContext, []byte(""), ""); err != nil { t.Fatal(err) @@ -73,12 +73,12 @@ func TestCreate(t *testing.T) { Type: morefTypeTask, Value: vmContext.VSphereVM.Status.TaskRef, } - vimClient, err := vim25.NewClient(vmContext, vmContext.Session.RoundTripper) + vimClient, err := vim25.NewClient(ctx, vmContext.Session.RoundTripper) if err != nil { t.Fatal("could not make vim25 client.") } task := object.NewTask(vimClient, taskRef) - err = task.Wait(vmContext) + err = task.Wait(ctx) if err != nil { t.Fatal("error waiting for task:", err) } diff --git a/pkg/services/govmomi/service.go b/pkg/services/govmomi/service.go index 0c18458fa3..a1df27fc09 100644 --- a/pkg/services/govmomi/service.go +++ b/pkg/services/govmomi/service.go @@ -245,7 +245,7 @@ func (vms *VMService) DestroyVM(ctx context.Context, vmCtx *capvcontext.VMContex } virtualMachineCtx.VSphereVM.Status.TaskRef = task.Reference().Value - if err = virtualMachineCtx.Patch(); err != nil { + if err = virtualMachineCtx.Patch(ctx); err != nil { vmCtx.Logger.Error(err, "patch failed", "vm", virtualMachineCtx.String()) return reconcile.Result{}, vm, err } @@ -351,7 +351,7 @@ func (vms *VMService) reconcilePowerState(ctx context.Context, virtualMachineCtx // Update the VSphereVM.Status.TaskRef to track the power-on task. virtualMachineCtx.VSphereVM.Status.TaskRef = task.Reference().Value - if err = virtualMachineCtx.Patch(); err != nil { + if err = virtualMachineCtx.Patch(ctx); err != nil { virtualMachineCtx.Logger.Error(err, "patch failed", "vm", virtualMachineCtx.String()) return false, err } diff --git a/pkg/services/govmomi/service_test.go b/pkg/services/govmomi/service_test.go index 8be3f404fe..011e6c3427 100644 --- a/pkg/services/govmomi/service_test.go +++ b/pkg/services/govmomi/service_test.go @@ -39,9 +39,7 @@ func emptyVirtualMachineContext() *virtualMachineContext { VMContext: capvcontext.VMContext{ Logger: logr.Discard(), ControllerContext: &capvcontext.ControllerContext{ - ControllerManagerContext: &capvcontext.ControllerManagerContext{ - Context: context.TODO(), - }, + ControllerManagerContext: &capvcontext.ControllerManagerContext{}, }, }, } diff --git a/pkg/services/govmomi/util.go b/pkg/services/govmomi/util.go index f2e6774e70..19f9fcf97a 100644 --- a/pkg/services/govmomi/util.go +++ b/pkg/services/govmomi/util.go @@ -296,7 +296,7 @@ func reconcileVSphereVMOnFuncCompletion(_ context.Context, vmCtx *capvcontext.VM }() } -func reconcileVSphereVMOnChannel(_ context.Context, vmCtx *capvcontext.VMContext, waitFn func() (<-chan []interface{}, <-chan error, error)) { +func reconcileVSphereVMOnChannel(ctx context.Context, vmCtx *capvcontext.VMContext, waitFn func() (<-chan []interface{}, <-chan error, error)) { obj := vmCtx.VSphereVM.DeepCopy() gvk := obj.GetObjectKind().GroupVersionKind() @@ -329,7 +329,7 @@ func reconcileVSphereVMOnChannel(_ context.Context, vmCtx *capvcontext.VMContext vmCtx.Logger.Error(err, "error occurred while waiting to trigger a generic event") } return - case <-vmCtx.Done(): + case <-ctx.Done(): return } } diff --git a/pkg/services/govmomi/vcenter/clone.go b/pkg/services/govmomi/vcenter/clone.go index c6ec864398..16e3bc41d9 100644 --- a/pkg/services/govmomi/vcenter/clone.go +++ b/pkg/services/govmomi/vcenter/clone.go @@ -302,7 +302,7 @@ func Clone(ctx context.Context, vmCtx *capvcontext.VMContext, bootstrapData []by // patch the vsphereVM early to ensure that the task is // reflected in the status right away, this avoid situations // of concurrent clones - if err := vmCtx.Patch(); err != nil { + if err := vmCtx.Patch(ctx); err != nil { vmCtx.Logger.Error(err, "patch failed", "vspherevm", vmCtx.VSphereVM) } return nil diff --git a/pkg/services/govmomi/vcenter/clone_test.go b/pkg/services/govmomi/vcenter/clone_test.go index 67c9385358..292dc00b6a 100644 --- a/pkg/services/govmomi/vcenter/clone_test.go +++ b/pkg/services/govmomi/vcenter/clone_test.go @@ -27,7 +27,7 @@ import ( "github.com/vmware/govmomi/vim25/types" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" "sigs.k8s.io/cluster-api-provider-vsphere/pkg/session" ) @@ -120,7 +120,7 @@ func TestGetDiskSpec(t *testing.T) { VirtualMachineCloneSpec: cloneSpec, }, } - vmContext := &context.VMContext{VSphereVM: vsphereVM} + vmContext := &capvcontext.VMContext{VSphereVM: vsphereVM} devices, err := getDiskSpec(vmContext, tc.disks) if (tc.err != "" && err == nil) || (tc.err == "" && err != nil) || (err != nil && tc.err != err.Error()) { t.Fatalf("Expected to get '%v' error from getDiskSpec, got: '%v'", tc.err, err) diff --git a/pkg/services/vimmachine_test.go b/pkg/services/vimmachine_test.go index 6734af5d73..b43d297bda 100644 --- a/pkg/services/vimmachine_test.go +++ b/pkg/services/vimmachine_test.go @@ -27,7 +27,7 @@ import ( clusterv1 "sigs.k8s.io/cluster-api/api/v1beta1" infrav1 "sigs.k8s.io/cluster-api-provider-vsphere/apis/v1beta1" - "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" + capvcontext "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context" "sigs.k8s.io/cluster-api-provider-vsphere/pkg/context/fake" ) @@ -60,8 +60,8 @@ var _ = Describe("VimMachineService_GenerateOverrideFunc", func() { } } var ( - controllerCtx *context.ControllerContext - machineCtx *context.VIMMachineContext + controllerCtx *capvcontext.ControllerContext + machineCtx *capvcontext.VIMMachineContext vimMachineService *VimMachineService ) @@ -188,8 +188,8 @@ var _ = Describe("VimMachineService_GenerateOverrideFunc", func() { var _ = Describe("VimMachineService_GetHostInfo", func() { var ( - controllerCtx *context.ControllerContext - machineCtx *context.VIMMachineContext + controllerCtx *capvcontext.ControllerContext + machineCtx *capvcontext.VIMMachineContext vimMachineService = &VimMachineService{} hostAddr = "1.2.3.4" ) @@ -242,8 +242,8 @@ var _ = Describe("VimMachineService_GetHostInfo", func() { var _ = Describe("VimMachineService_createOrPatchVSphereVM", func() { var ( - controllerCtx *context.ControllerContext - machineCtx *context.VIMMachineContext + controllerCtx *capvcontext.ControllerContext + machineCtx *capvcontext.VIMMachineContext vimMachineService *VimMachineService hostAddr = "1.2.3.4" fakeLongClusterName = "fake-long-clustername" diff --git a/pkg/util/testutil.go b/pkg/util/testutil.go index e3ab7c7f7e..e889aa0209 100644 --- a/pkg/util/testutil.go +++ b/pkg/util/testutil.go @@ -17,8 +17,6 @@ limitations under the License. package util import ( - "context" - netopv1 "github.com/vmware-tanzu/net-operator-api/api/v1alpha1" vmoprv1 "github.com/vmware-tanzu/vm-operator/api/v1alpha1" ncpv1 "github.com/vmware-tanzu/vm-operator/external/ncp/api/v1alpha1" @@ -152,9 +150,8 @@ func createScheme() *runtime.Scheme { func CreateClusterContext(cluster *clusterv1.Cluster, vsphereCluster *vmwarev1.VSphereCluster) (*vmware.ClusterContext, *capvcontext.ControllerContext) { scheme := createScheme() controllerManagerContext := &capvcontext.ControllerManagerContext{ - Context: context.Background(), - Logger: klog.Background().WithName("controller-manager-logger"), - Scheme: scheme, + Logger: klog.Background().WithName("controller-manager-logger"), + Scheme: scheme, Client: testclient.NewClientBuilder().WithScheme(scheme).WithStatusSubresource( &vmoprv1.VirtualMachineService{}, &vmoprv1.VirtualMachine{}, diff --git a/test/helpers/vmware/intg_test_context.go b/test/helpers/vmware/intg_test_context.go index b19351bcb8..9a77e501c0 100644 --- a/test/helpers/vmware/intg_test_context.go +++ b/test/helpers/vmware/intg_test_context.go @@ -40,7 +40,6 @@ import ( // IntegrationTestContext is used for integration testing // Supervisor controllers. type IntegrationTestContext struct { - context.Context //nolint:containedctx Client client.Client GuestClient client.Client Namespace string @@ -63,7 +62,7 @@ func (ctx *IntegrationTestContext) AfterEach() { }, } By("Destroying integration test namespace") - Expect(ctx.Client.Delete(ctx, namespace)).To(Succeed()) + Expect(ctx.Client.Delete(context.Background(), namespace)).To(Succeed()) if ctx.envTest != nil { By("Shutting down guest cluster control plane") @@ -84,8 +83,7 @@ func (ctx *IntegrationTestContext) AfterEach() { // with the IntegrationTestContext returned by this function. func NewIntegrationTestContextWithClusters(ctx context.Context, integrationTestClient client.Client) *IntegrationTestContext { testCtx := &IntegrationTestContext{ - Context: ctx, - Client: integrationTestClient, + Client: integrationTestClient, } By("Creating a temporary namespace", func() {