From 2c9f02c3290ce7e8bcdc94bea7d96edf92834cd7 Mon Sep 17 00:00:00 2001 From: Shiming Zhang Date: Fri, 9 Apr 2021 13:07:46 +0800 Subject: [PATCH 1/2] Add test Signed-off-by: Shiming Zhang --- .../k8s.io/client-go/testing/fixture_test.go | 87 +++++++++++++++++++ 1 file changed, 87 insertions(+) diff --git a/staging/src/k8s.io/client-go/testing/fixture_test.go b/staging/src/k8s.io/client-go/testing/fixture_test.go index 6e026756a98..5aab05aa6c3 100644 --- a/staging/src/k8s.io/client-go/testing/fixture_test.go +++ b/staging/src/k8s.io/client-go/testing/fixture_test.go @@ -322,3 +322,90 @@ func TestGetWithExactMatch(t *testing.T) { errNotFound = errors.NewNotFound(gvr.GroupResource(), "pod") assert.EqualError(t, err, errNotFound.Error()) } + +func Test_resourceCovers(t *testing.T) { + type args struct { + resource string + action Action + } + tests := []struct { + name string + args args + want bool + }{ + { + args: args{ + resource: "*", + action: ActionImpl{}, + }, + want: true, + }, + { + args: args{ + resource: "serviceaccounts", + action: ActionImpl{}, + }, + want: false, + }, + { + args: args{ + resource: "serviceaccounts", + action: ActionImpl{ + Resource: schema.GroupVersionResource{ + Resource: "serviceaccounts", + }, + }, + }, + want: true, + }, + { + args: args{ + resource: "serviceaccounts/token", + action: ActionImpl{ + Resource: schema.GroupVersionResource{}, + }, + }, + want: false, + }, + { + args: args{ + resource: "serviceaccounts/token", + action: ActionImpl{ + Resource: schema.GroupVersionResource{ + Resource: "serviceaccounts", + }, + }, + }, + want: false, + }, + { + args: args{ + resource: "serviceaccounts/token", + action: ActionImpl{ + Resource: schema.GroupVersionResource{}, + Subresource: "token", + }, + }, + want: false, + }, + { + args: args{ + resource: "serviceaccounts/token", + action: ActionImpl{ + Resource: schema.GroupVersionResource{ + Resource: "serviceaccounts", + }, + Subresource: "token", + }, + }, + want: true, + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + if got := resourceCovers(tt.args.resource, tt.args.action); got != tt.want { + t.Errorf("resourceCovers() = %v, want %v", got, tt.want) + } + }) + } +} From 58833d652d59229d49f001256f6ade4a46ae53ca Mon Sep 17 00:00:00 2001 From: Shiming Zhang Date: Fri, 9 Apr 2021 12:55:57 +0800 Subject: [PATCH 2/2] Support subresource match Signed-off-by: Shiming Zhang --- .../src/k8s.io/client-go/testing/fixture.go | 39 +++++++++++-------- 1 file changed, 22 insertions(+), 17 deletions(-) diff --git a/staging/src/k8s.io/client-go/testing/fixture.go b/staging/src/k8s.io/client-go/testing/fixture.go index d3b937247b2..caa045117ee 100644 --- a/staging/src/k8s.io/client-go/testing/fixture.go +++ b/staging/src/k8s.io/client-go/testing/fixture.go @@ -20,6 +20,7 @@ import ( "fmt" "reflect" "sort" + "strings" "sync" jsonpatch "github.com/evanphx/json-patch" @@ -509,12 +510,8 @@ func (r *SimpleReactor) Handles(action Action) bool { if !verbCovers { return false } - resourceCovers := r.Resource == "*" || r.Resource == action.GetResource().Resource - if !resourceCovers { - return false - } - return true + return resourceCovers(r.Resource, action) } func (r *SimpleReactor) React(action Action) (bool, runtime.Object, error) { @@ -530,12 +527,7 @@ type SimpleWatchReactor struct { } func (r *SimpleWatchReactor) Handles(action Action) bool { - resourceCovers := r.Resource == "*" || r.Resource == action.GetResource().Resource - if !resourceCovers { - return false - } - - return true + return resourceCovers(r.Resource, action) } func (r *SimpleWatchReactor) React(action Action) (bool, watch.Interface, error) { @@ -551,14 +543,27 @@ type SimpleProxyReactor struct { } func (r *SimpleProxyReactor) Handles(action Action) bool { - resourceCovers := r.Resource == "*" || r.Resource == action.GetResource().Resource - if !resourceCovers { - return false - } - - return true + return resourceCovers(r.Resource, action) } func (r *SimpleProxyReactor) React(action Action) (bool, restclient.ResponseWrapper, error) { return r.Reaction(action) } + +func resourceCovers(resource string, action Action) bool { + if resource == "*" { + return true + } + + if resource == action.GetResource().Resource { + return true + } + + if index := strings.Index(resource, "/"); index != -1 && + resource[:index] == action.GetResource().Resource && + resource[index+1:] == action.GetSubresource() { + return true + } + + return false +}