Skip to content

Commit

Permalink
🌱 Enable integration tests of RuntimeExtensions (kubernetes-sigs#10330)
Browse files Browse the repository at this point in the history
* Export ClusterClass controller Reconcile

* Export BuiltinVariables and variable util funcs

* Export webhooks.Cluster DefaultAndValidateVariables method

Signed-off-by: Stefan Büringer [email protected]

* Export desired state computation

* Export scope for desired state computation

* Add integration test to test extension

* Address review comments

* Regenerate openapi.go

* Move desired/scope to scope

* Address review comments

---------

Signed-off-by: Stefan Büringer [email protected]
  • Loading branch information
sbueringer authored Mar 28, 2024
1 parent 5baca0f commit e4629ab
Show file tree
Hide file tree
Showing 56 changed files with 2,324 additions and 716 deletions.
1 change: 0 additions & 1 deletion cmd/clusterctl/client/cluster/topology.go
Original file line number Diff line number Diff line change
Expand Up @@ -516,7 +516,6 @@ func reconcileClusterClass(ctx context.Context, apiReader client.Reader, class c

clusterClassReconciler := &clusterclasscontroller.Reconciler{
Client: reconcilerClient,
APIReader: reconcilerClient,
UnstructuredCachingClient: reconcilerClient,
}

Expand Down
22 changes: 17 additions & 5 deletions controllers/alias.go
Original file line number Diff line number Diff line change
Expand Up @@ -212,8 +212,11 @@ func (r *MachineSetTopologyReconciler) SetupWithManager(ctx context.Context, mgr

// ClusterClassReconciler reconciles the ClusterClass object.
type ClusterClassReconciler struct {
Client client.Client
APIReader client.Reader
// internalReconciler is used to store the reconciler after SetupWithManager
// so that the Reconcile function can work.
internalReconciler *clusterclasscontroller.Reconciler

Client client.Client

// RuntimeClient is a client for calling runtime extensions.
RuntimeClient runtimeclient.Client
Expand All @@ -227,11 +230,20 @@ type ClusterClassReconciler struct {
}

func (r *ClusterClassReconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, options controller.Options) error {
return (&clusterclasscontroller.Reconciler{
r.internalReconciler = &clusterclasscontroller.Reconciler{
Client: r.Client,
APIReader: r.APIReader,
RuntimeClient: r.RuntimeClient,
UnstructuredCachingClient: r.UnstructuredCachingClient,
WatchFilterValue: r.WatchFilterValue,
}).SetupWithManager(ctx, mgr, options)
}
return r.internalReconciler.SetupWithManager(ctx, mgr, options)
}

// Reconcile can be used to reconcile a ClusterClass.
// Before it can be used, all fields of the ClusterClassReconciler have to be set
// and SetupWithManager has to be called.
// This method can be used when testing the behavior of the desired state computation of
// the Cluster topology controller (because that requires a reconciled ClusterClass).
func (r *ClusterClassReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) {
return r.internalReconciler.Reconcile(ctx, req)
}
188 changes: 188 additions & 0 deletions exp/runtime/hooks/api/v1alpha1/topologymutation_variable_types.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,188 @@
/*
Copyright 2024 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

package v1alpha1

// BuiltinsName is the name of the builtin variable.
const BuiltinsName = "builtin"

// Builtins represents builtin variables exposed through patches.
type Builtins struct {
Cluster *ClusterBuiltins `json:"cluster,omitempty"`
ControlPlane *ControlPlaneBuiltins `json:"controlPlane,omitempty"`
MachineDeployment *MachineDeploymentBuiltins `json:"machineDeployment,omitempty"`
MachinePool *MachinePoolBuiltins `json:"machinePool,omitempty"`
}

// ClusterBuiltins represents builtin cluster variables.
type ClusterBuiltins struct {
// Name is the name of the cluster.
Name string `json:"name,omitempty"`

// Namespace is the namespace of the cluster.
Namespace string `json:"namespace,omitempty"`

// Topology represents the cluster topology variables.
Topology *ClusterTopologyBuiltins `json:"topology,omitempty"`

// Network represents the cluster network variables.
Network *ClusterNetworkBuiltins `json:"network,omitempty"`
}

// ClusterTopologyBuiltins represents builtin cluster topology variables.
type ClusterTopologyBuiltins struct {
// Version is the Kubernetes version of the Cluster.
// NOTE: Please note that this version might temporarily differ from the version
// of the ControlPlane or workers while an upgrade process is being orchestrated.
Version string `json:"version,omitempty"`

// Class is the name of the ClusterClass of the Cluster.
Class string `json:"class,omitempty"`
}

// ClusterNetworkBuiltins represents builtin cluster network variables.
type ClusterNetworkBuiltins struct {
// ServiceDomain is the domain name for services.
ServiceDomain *string `json:"serviceDomain,omitempty"`
// Services is the network ranges from which service VIPs are allocated.
Services []string `json:"services,omitempty"`
// Pods is the network ranges from which Pod networks are allocated.
Pods []string `json:"pods,omitempty"`
// IPFamily is the IPFamily the Cluster is operating in. One of Invalid, IPv4, IPv6, DualStack.
// Note: IPFamily is not a concept in Kubernetes. It was originally introduced in CAPI for CAPD.
// IPFamily may be dropped in a future release. More details at https://github.com/kubernetes-sigs/cluster-api/issues/7521
IPFamily string `json:"ipFamily,omitempty"`
}

// ControlPlaneBuiltins represents builtin ControlPlane variables.
// NOTE: These variables are only set for templates belonging to the ControlPlane object.
type ControlPlaneBuiltins struct {
// Version is the Kubernetes version of the ControlPlane object.
// NOTE: Please note that this version is the version we are currently reconciling towards.
// It can differ from the current version of the ControlPlane while an upgrade process is
// being orchestrated.
Version string `json:"version,omitempty"`

// Name is the name of the ControlPlane,
// to which the current template belongs to.
Name string `json:"name,omitempty"`

// Replicas is the value of the replicas field of the ControlPlane object.
Replicas *int64 `json:"replicas,omitempty"`

// MachineTemplate is the value of the .spec.machineTemplate field of the ControlPlane object.
MachineTemplate *ControlPlaneMachineTemplateBuiltins `json:"machineTemplate,omitempty"`
}

// ControlPlaneMachineTemplateBuiltins is the value of the .spec.machineTemplate field of the ControlPlane object.
type ControlPlaneMachineTemplateBuiltins struct {
// InfrastructureRef is the value of the infrastructureRef field of ControlPlane.spec.machineTemplate.
InfrastructureRef ControlPlaneMachineTemplateInfrastructureRefBuiltins `json:"infrastructureRef,omitempty"`
}

// ControlPlaneMachineTemplateInfrastructureRefBuiltins is the value of the infrastructureRef field of
// ControlPlane.spec.machineTemplate.
type ControlPlaneMachineTemplateInfrastructureRefBuiltins struct {
// Name of the infrastructureRef.
Name string `json:"name,omitempty"`
}

// MachineDeploymentBuiltins represents builtin MachineDeployment variables.
// NOTE: These variables are only set for templates belonging to a MachineDeployment.
type MachineDeploymentBuiltins struct {
// Version is the Kubernetes version of the MachineDeployment,
// to which the current template belongs to.
// NOTE: Please note that this version is the version we are currently reconciling towards.
// It can differ from the current version of the MachineDeployment machines while an upgrade process is
// being orchestrated.
Version string `json:"version,omitempty"`

// Class is the class name of the MachineDeployment,
// to which the current template belongs to.
Class string `json:"class,omitempty"`

// Name is the name of the MachineDeployment,
// to which the current template belongs to.
Name string `json:"name,omitempty"`

// TopologyName is the topology name of the MachineDeployment,
// to which the current template belongs to.
TopologyName string `json:"topologyName,omitempty"`

// Replicas is the value of the replicas field of the MachineDeployment,
// to which the current template belongs to.
Replicas *int64 `json:"replicas,omitempty"`

// Bootstrap is the value of the .spec.template.spec.bootstrap field of the MachineDeployment.
Bootstrap *MachineBootstrapBuiltins `json:"bootstrap,omitempty"`

// InfrastructureRef is the value of the .spec.template.spec.infrastructureRef field of the MachineDeployment.
InfrastructureRef *MachineInfrastructureRefBuiltins `json:"infrastructureRef,omitempty"`
}

// MachinePoolBuiltins represents builtin MachinePool variables.
// NOTE: These variables are only set for templates belonging to a MachinePool.
type MachinePoolBuiltins struct {
// Version is the Kubernetes version of the MachinePool,
// to which the current template belongs to.
// NOTE: Please note that this version is the version we are currently reconciling towards.
// It can differ from the current version of the MachinePool machines while an upgrade process is
// being orchestrated.
Version string `json:"version,omitempty"`

// Class is the class name of the MachinePool,
// to which the current template belongs to.
Class string `json:"class,omitempty"`

// Name is the name of the MachinePool,
// to which the current template belongs to.
Name string `json:"name,omitempty"`

// TopologyName is the topology name of the MachinePool,
// to which the current template belongs to.
TopologyName string `json:"topologyName,omitempty"`

// Replicas is the value of the replicas field of the MachinePool,
// to which the current template belongs to.
Replicas *int64 `json:"replicas,omitempty"`

// Bootstrap is the value of the .spec.template.spec.bootstrap field of the MachinePool.
Bootstrap *MachineBootstrapBuiltins `json:"bootstrap,omitempty"`

// InfrastructureRef is the value of the .spec.template.spec.infrastructureRef field of the MachinePool.
InfrastructureRef *MachineInfrastructureRefBuiltins `json:"infrastructureRef,omitempty"`
}

// MachineBootstrapBuiltins is the value of the .spec.template.spec.bootstrap field
// of the MachineDeployment or MachinePool.
type MachineBootstrapBuiltins struct {
// ConfigRef is the value of the .spec.template.spec.bootstrap.configRef field of the MachineDeployment.
ConfigRef *MachineBootstrapConfigRefBuiltins `json:"configRef,omitempty"`
}

// MachineBootstrapConfigRefBuiltins is the value of the .spec.template.spec.bootstrap.configRef
// field of the MachineDeployment or MachinePool.
type MachineBootstrapConfigRefBuiltins struct {
// Name of the bootstrap.configRef.
Name string `json:"name,omitempty"`
}

// MachineInfrastructureRefBuiltins is the value of the .spec.template.spec.infrastructureRef field
// of the MachineDeployment or MachinePool.
type MachineInfrastructureRefBuiltins struct {
// Name of the infrastructureRef.
Name string `json:"name,omitempty"`
}
Loading

0 comments on commit e4629ab

Please sign in to comment.