CompositionRevisionRefence only has Name, so LocalObjectReference
Signed-off-by: Hasan Turken <turkenh@gmail.com>
(cherry picked from commit 70499a4edd)
This commit is contained in:
parent
d6bbef87df
commit
8453f6dfd6
|
|
@ -52,6 +52,7 @@ func (c *typedExternalClientWrapper[managed]) Create(ctx context.Context, mg res
|
|||
}
|
||||
return c.c.Create(ctx, cr)
|
||||
}
|
||||
|
||||
func (c *typedExternalClientWrapper[managed]) Update(ctx context.Context, mg resource.Managed) (ExternalUpdate, error) {
|
||||
cr, ok := mg.(managed)
|
||||
if !ok {
|
||||
|
|
|
|||
|
|
@ -35,7 +35,7 @@ import (
|
|||
"sigs.k8s.io/controller-runtime/pkg/manager"
|
||||
|
||||
xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/claim"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
)
|
||||
|
||||
// Conditioned is a mock that implements Conditioned interface.
|
||||
|
|
@ -50,13 +50,13 @@ func (m *Conditioned) GetCondition(ct xpv1.ConditionType) xpv1.Condition {
|
|||
}
|
||||
|
||||
// ClaimReferencer is a mock that implements ClaimReferencer interface.
|
||||
type ClaimReferencer struct{ Ref *claim.Reference }
|
||||
type ClaimReferencer struct{ Ref *reference.Claim }
|
||||
|
||||
// SetClaimReference sets the ClaimReference.
|
||||
func (m *ClaimReferencer) SetClaimReference(r *claim.Reference) { m.Ref = r }
|
||||
func (m *ClaimReferencer) SetClaimReference(r *reference.Claim) { m.Ref = r }
|
||||
|
||||
// GetClaimReference gets the ClaimReference.
|
||||
func (m *ClaimReferencer) GetClaimReference() *claim.Reference { return m.Ref }
|
||||
func (m *ClaimReferencer) GetClaimReference() *reference.Claim { return m.Ref }
|
||||
|
||||
// ManagedResourceReferencer is a mock that implements ManagedResourceReferencer interface.
|
||||
type ManagedResourceReferencer struct{ Ref *corev1.ObjectReference }
|
||||
|
|
@ -184,15 +184,15 @@ func (m *CompositionSelector) SetCompositionSelector(s *metav1.LabelSelector) {
|
|||
func (m *CompositionSelector) GetCompositionSelector() *metav1.LabelSelector { return m.Sel }
|
||||
|
||||
// CompositionRevisionReferencer is a mock that implements CompositionRevisionReferencer interface.
|
||||
type CompositionRevisionReferencer struct{ Ref *corev1.ObjectReference }
|
||||
type CompositionRevisionReferencer struct{ Ref *corev1.LocalObjectReference }
|
||||
|
||||
// SetCompositionRevisionReference sets the CompositionRevisionReference.
|
||||
func (m *CompositionRevisionReferencer) SetCompositionRevisionReference(r *corev1.ObjectReference) {
|
||||
func (m *CompositionRevisionReferencer) SetCompositionRevisionReference(r *corev1.LocalObjectReference) {
|
||||
m.Ref = r
|
||||
}
|
||||
|
||||
// GetCompositionRevisionReference gets the CompositionRevisionReference.
|
||||
func (m *CompositionRevisionReferencer) GetCompositionRevisionReference() *corev1.ObjectReference {
|
||||
func (m *CompositionRevisionReferencer) GetCompositionRevisionReference() *corev1.LocalObjectReference {
|
||||
return m.Ref
|
||||
}
|
||||
|
||||
|
|
@ -236,13 +236,13 @@ func (m *CompositeResourceDeleter) GetCompositeDeletePolicy() *xpv1.CompositeDel
|
|||
}
|
||||
|
||||
// CompositeResourceReferencer is a mock that implements CompositeResourceReferencer interface.
|
||||
type CompositeResourceReferencer struct{ Ref *corev1.ObjectReference }
|
||||
type CompositeResourceReferencer struct{ Ref *reference.Composite }
|
||||
|
||||
// SetResourceReference sets the composite resource reference.
|
||||
func (m *CompositeResourceReferencer) SetResourceReference(p *corev1.ObjectReference) { m.Ref = p }
|
||||
func (m *CompositeResourceReferencer) SetResourceReference(p *reference.Composite) { m.Ref = p }
|
||||
|
||||
// GetResourceReference gets the composite resource reference.
|
||||
func (m *CompositeResourceReferencer) GetResourceReference() *corev1.ObjectReference { return m.Ref }
|
||||
func (m *CompositeResourceReferencer) GetResourceReference() *reference.Composite { return m.Ref }
|
||||
|
||||
// ComposedResourcesReferencer is a mock that implements ComposedResourcesReferencer interface.
|
||||
type ComposedResourcesReferencer struct{ Refs []corev1.ObjectReference }
|
||||
|
|
|
|||
|
|
@ -18,7 +18,6 @@ package resource
|
|||
|
||||
import (
|
||||
"context"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
|
||||
corev1 "k8s.io/api/core/v1"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
|
|
@ -26,6 +25,7 @@ import (
|
|||
"sigs.k8s.io/controller-runtime/pkg/client"
|
||||
|
||||
xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
)
|
||||
|
||||
// A Conditioned may have conditions set or retrieved. Conditions are typically
|
||||
|
|
@ -120,8 +120,8 @@ type CompositionReferencer interface {
|
|||
// A CompositionRevisionReferencer may reference a specific revision of a
|
||||
// composition of resources.
|
||||
type CompositionRevisionReferencer interface {
|
||||
SetCompositionRevisionReference(ref *corev1.ObjectReference)
|
||||
GetCompositionRevisionReference() *corev1.ObjectReference
|
||||
SetCompositionRevisionReference(ref *corev1.LocalObjectReference)
|
||||
GetCompositionRevisionReference() *corev1.LocalObjectReference
|
||||
}
|
||||
|
||||
// A CompositionRevisionSelector may reference a set of
|
||||
|
|
@ -153,8 +153,8 @@ type ComposedResourcesReferencer interface {
|
|||
|
||||
// A CompositeResourceReferencer can reference a composite resource.
|
||||
type CompositeResourceReferencer interface {
|
||||
SetResourceReference(r *corev1.ObjectReference)
|
||||
GetResourceReference() *corev1.ObjectReference
|
||||
SetResourceReference(r *reference.Composite)
|
||||
GetResourceReference() *reference.Composite
|
||||
}
|
||||
|
||||
// An EnvironmentConfigReferencer references a list of EnvironmentConfigs.
|
||||
|
|
|
|||
|
|
@ -18,7 +18,6 @@ limitations under the License.
|
|||
package claim
|
||||
|
||||
import (
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
corev1 "k8s.io/api/core/v1"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
|
||||
|
|
@ -26,6 +25,7 @@ import (
|
|||
|
||||
xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/fieldpath"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
)
|
||||
|
||||
// An Option modifies an unstructured composite resource claim.
|
||||
|
|
@ -98,8 +98,8 @@ func (c *Unstructured) SetCompositionReference(ref *corev1.ObjectReference) {
|
|||
}
|
||||
|
||||
// GetCompositionRevisionReference of this resource claim.
|
||||
func (c *Unstructured) GetCompositionRevisionReference() *corev1.ObjectReference {
|
||||
out := &corev1.ObjectReference{}
|
||||
func (c *Unstructured) GetCompositionRevisionReference() *corev1.LocalObjectReference {
|
||||
out := &corev1.LocalObjectReference{}
|
||||
if err := fieldpath.Pave(c.Object).GetValueInto("spec.compositionRevisionRef", out); err != nil {
|
||||
return nil
|
||||
}
|
||||
|
|
@ -107,7 +107,7 @@ func (c *Unstructured) GetCompositionRevisionReference() *corev1.ObjectReference
|
|||
}
|
||||
|
||||
// SetCompositionRevisionReference of this resource claim.
|
||||
func (c *Unstructured) SetCompositionRevisionReference(ref *corev1.ObjectReference) {
|
||||
func (c *Unstructured) SetCompositionRevisionReference(ref *corev1.LocalObjectReference) {
|
||||
_ = fieldpath.Pave(c.Object).SetValue("spec.compositionRevisionRef", ref)
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -29,6 +29,7 @@ import (
|
|||
"sigs.k8s.io/controller-runtime/pkg/client"
|
||||
|
||||
xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
)
|
||||
|
||||
var _ client.Object = &Unstructured{}
|
||||
|
|
@ -172,11 +173,11 @@ func TestCompositionReference(t *testing.T) {
|
|||
}
|
||||
|
||||
func TestCompositionRevisionReference(t *testing.T) {
|
||||
ref := &corev1.ObjectReference{Namespace: "ns", Name: "cool"}
|
||||
ref := &corev1.LocalObjectReference{Name: "cool"}
|
||||
cases := map[string]struct {
|
||||
u *Unstructured
|
||||
set *corev1.ObjectReference
|
||||
want *corev1.ObjectReference
|
||||
set *corev1.LocalObjectReference
|
||||
want *corev1.LocalObjectReference
|
||||
}{
|
||||
"NewRef": {
|
||||
u: New(),
|
||||
|
|
@ -272,11 +273,11 @@ func TestCompositeDeletePolicy(t *testing.T) {
|
|||
}
|
||||
|
||||
func TestResourceReference(t *testing.T) {
|
||||
ref := &corev1.ObjectReference{Namespace: "ns", Name: "cool"}
|
||||
ref := &reference.Composite{Name: "cool"}
|
||||
cases := map[string]struct {
|
||||
u *Unstructured
|
||||
set *corev1.ObjectReference
|
||||
want *corev1.ObjectReference
|
||||
set *reference.Composite
|
||||
want *reference.Composite
|
||||
}{
|
||||
"NewRef": {
|
||||
u: New(),
|
||||
|
|
@ -297,7 +298,7 @@ func TestResourceReference(t *testing.T) {
|
|||
}
|
||||
|
||||
func TestClaimReference(t *testing.T) {
|
||||
ref := &Reference{Namespace: "ns", Name: "cool", APIVersion: "foo.com/v1", Kind: "Foo"}
|
||||
ref := &reference.Claim{Namespace: "ns", Name: "cool", APIVersion: "foo.com/v1", Kind: "Foo"}
|
||||
u := &Unstructured{}
|
||||
u.SetName(ref.Name)
|
||||
u.SetNamespace(ref.Namespace)
|
||||
|
|
|
|||
|
|
@ -18,7 +18,6 @@ limitations under the License.
|
|||
package composite
|
||||
|
||||
import (
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
corev1 "k8s.io/api/core/v1"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
|
||||
|
|
@ -27,6 +26,7 @@ import (
|
|||
xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/errors"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/fieldpath"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
)
|
||||
|
||||
// An Option modifies an unstructured composite resource.
|
||||
|
|
@ -99,8 +99,8 @@ func (c *Unstructured) SetCompositionReference(ref *corev1.ObjectReference) {
|
|||
}
|
||||
|
||||
// GetCompositionRevisionReference of this Composite resource.
|
||||
func (c *Unstructured) GetCompositionRevisionReference() *corev1.ObjectReference {
|
||||
out := &corev1.ObjectReference{}
|
||||
func (c *Unstructured) GetCompositionRevisionReference() *corev1.LocalObjectReference {
|
||||
out := &corev1.LocalObjectReference{}
|
||||
if err := fieldpath.Pave(c.Object).GetValueInto("spec.compositionRevisionRef", out); err != nil {
|
||||
return nil
|
||||
}
|
||||
|
|
@ -108,7 +108,7 @@ func (c *Unstructured) GetCompositionRevisionReference() *corev1.ObjectReference
|
|||
}
|
||||
|
||||
// SetCompositionRevisionReference of this Composite resource.
|
||||
func (c *Unstructured) SetCompositionRevisionReference(ref *corev1.ObjectReference) {
|
||||
func (c *Unstructured) SetCompositionRevisionReference(ref *corev1.LocalObjectReference) {
|
||||
_ = fieldpath.Pave(c.Object).SetValue("spec.compositionRevisionRef", ref)
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -30,7 +30,7 @@ import (
|
|||
"sigs.k8s.io/controller-runtime/pkg/client"
|
||||
|
||||
xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/claim"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/resource/unstructured/reference"
|
||||
"github.com/crossplane/crossplane-runtime/pkg/test"
|
||||
)
|
||||
|
||||
|
|
@ -259,11 +259,11 @@ func TestCompositionReference(t *testing.T) {
|
|||
}
|
||||
|
||||
func TestCompositionRevisionReference(t *testing.T) {
|
||||
ref := &corev1.ObjectReference{Namespace: "ns", Name: "cool"}
|
||||
ref := &corev1.LocalObjectReference{Name: "cool"}
|
||||
cases := map[string]struct {
|
||||
u *Unstructured
|
||||
set *corev1.ObjectReference
|
||||
want *corev1.ObjectReference
|
||||
set *corev1.LocalObjectReference
|
||||
want *corev1.LocalObjectReference
|
||||
}{
|
||||
"NewRef": {
|
||||
u: New(),
|
||||
|
|
@ -334,11 +334,11 @@ func TestCompositionUpdatePolicy(t *testing.T) {
|
|||
}
|
||||
|
||||
func TestClaimReference(t *testing.T) {
|
||||
ref := &claim.Reference{Namespace: "ns", Name: "cool", APIVersion: "acme.com/v1", Kind: "Foo"}
|
||||
ref := &reference.Claim{Namespace: "ns", Name: "cool", APIVersion: "acme.com/v1", Kind: "Foo"}
|
||||
cases := map[string]struct {
|
||||
u *Unstructured
|
||||
set *claim.Reference
|
||||
want *claim.Reference
|
||||
set *reference.Claim
|
||||
want *reference.Claim
|
||||
}{
|
||||
"NewRef": {
|
||||
u: New(),
|
||||
|
|
|
|||
|
|
@ -1,5 +1,26 @@
|
|||
/*
|
||||
Copyright 2024 The Crossplane 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 reference contains references to resources.
|
||||
package reference
|
||||
|
||||
import (
|
||||
"k8s.io/apimachinery/pkg/runtime/schema"
|
||||
)
|
||||
|
||||
// A Claim is a reference to a claim.
|
||||
type Claim struct {
|
||||
// APIVersion of the referenced claim.
|
||||
|
|
@ -26,3 +47,13 @@ type Composite struct {
|
|||
// Name of the referenced composite.
|
||||
Name string `json:"name"`
|
||||
}
|
||||
|
||||
// GroupVersionKind returns the GroupVersionKind of the claim reference.
|
||||
func (c *Claim) GroupVersionKind() schema.GroupVersionKind {
|
||||
return schema.FromAPIVersionAndKind(c.APIVersion, c.Kind)
|
||||
}
|
||||
|
||||
// GroupVersionKind returns the GroupVersionKind of the composite reference.
|
||||
func (c *Composite) GroupVersionKind() schema.GroupVersionKind {
|
||||
return schema.FromAPIVersionAndKind(c.APIVersion, c.Kind)
|
||||
}
|
||||
|
|
|
|||
Loading…
Reference in New Issue