From c14ceb9ae5cd177f027b58f6704dd7aa74b163fc Mon Sep 17 00:00:00 2001 From: Kauana dos Santos Date: Mon, 16 Oct 2023 10:04:48 -0700 Subject: [PATCH] add migrator test for single version crds - fakes patch and expect it doesn't happen --- apiextensions/storageversion/migrator_test.go | 50 +++++++++++-------- 1 file changed, 29 insertions(+), 21 deletions(-) diff --git a/apiextensions/storageversion/migrator_test.go b/apiextensions/storageversion/migrator_test.go index a72c079d0f..f6e40bf545 100644 --- a/apiextensions/storageversion/migrator_test.go +++ b/apiextensions/storageversion/migrator_test.go @@ -19,6 +19,7 @@ package storageversion import ( "context" "errors" + "fmt" "testing" "github.com/google/go-cmp/cmp" @@ -63,21 +64,6 @@ var ( }, }, } - - singleVersionFakeCRD = &apix.CustomResourceDefinition{ - ObjectMeta: metav1.ObjectMeta{ - Name: fakeGR.String(), - }, - Spec: apix.CustomResourceDefinitionSpec{ - Group: fakeGK.Group, - Versions: []apix.CustomResourceDefinitionVersion{ - {Name: "v1", Served: true, Storage: true}, - }, - }, - Status: apix.CustomResourceDefinitionStatus{ - StoredVersions: []string{"v1"}, - }, - } ) func TestMigrate(t *testing.T) { @@ -104,19 +90,41 @@ func TestMigrate(t *testing.T) { } func TestMigrate_SingleStoredVersion(t *testing.T) { + singleVersionFakeCRD := &apix.CustomResourceDefinition{ + ObjectMeta: metav1.ObjectMeta{ + Name: fakeGR.String(), + }, + Spec: apix.CustomResourceDefinitionSpec{ + Group: fakeGK.Group, + Versions: []apix.CustomResourceDefinitionVersion{ + {Name: "v1", Served: true, Storage: true}, + }, + }, + Status: apix.CustomResourceDefinitionStatus{ + StoredVersions: []string{"v1"}, + }, + } + // setup dclient := dynamicFake.NewSimpleDynamicClient(runtime.NewScheme()) cclient := apixFake.NewSimpleClientset(singleVersionFakeCRD) - m := NewMigrator(dclient, cclient) + cclient.Fake.PrependReactor("patch", "customresourcedefinitions", func(action k8stesting.Action) (handled bool, ret runtime.Object, err error) { + pa, ok := action.(k8stesting.PatchAction) + if !ok { + return true, nil, fmt.Errorf("not a patch action: %#v", action) + } + + if pa.GetName() == singleVersionFakeCRD.Name { + return true, nil, fmt.Errorf("resource shouldn't have been patched") + } + return false, nil, nil + }) + + m := NewMigrator(dclient, cclient) if err := m.Migrate(context.Background(), fakeGR); err != nil { t.Fatal("Migrate() =", err) } - - assertPatches(t, cclient.Actions(), - // patch resource definition dropping non-storage version - crdStorageVersionPatch(singleVersionFakeCRD.Name, "v1"), - ) } // func TestMigrate_Paging(t *testing.T) {