123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- /*
- Copyright 2017 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 util
- import (
- "reflect"
- "testing"
- "k8s.io/apimachinery/pkg/util/sets"
- "k8s.io/apiserver/pkg/authorization/authorizer"
- authorizationapi "k8s.io/kubernetes/pkg/apis/authorization"
- )
- func TestResourceAttributesFrom(t *testing.T) {
- knownResourceAttributesNames := sets.NewString(
- // Fields we copy in ResourceAttributesFrom
- "Verb",
- "Namespace",
- "Group",
- "Version",
- "Resource",
- "Subresource",
- "Name",
- // Fields we copy in NonResourceAttributesFrom
- "Path",
- "Verb",
- )
- reflect.TypeOf(authorizationapi.ResourceAttributes{}).FieldByNameFunc(func(name string) bool {
- if !knownResourceAttributesNames.Has(name) {
- t.Errorf("authorizationapi.ResourceAttributes has a new field: %q. Add to ResourceAttributesFrom/NonResourceAttributesFrom as appropriate, then add to knownResourceAttributesNames", name)
- }
- return false
- })
- knownAttributesRecordFieldNames := sets.NewString(
- // Fields we set in ResourceAttributesFrom
- "User",
- "Verb",
- "Namespace",
- "APIGroup",
- "APIVersion",
- "Resource",
- "Subresource",
- "Name",
- "ResourceRequest",
- // Fields we set in NonResourceAttributesFrom
- "User",
- "ResourceRequest",
- "Path",
- "Verb",
- )
- reflect.TypeOf(authorizer.AttributesRecord{}).FieldByNameFunc(func(name string) bool {
- if !knownAttributesRecordFieldNames.Has(name) {
- t.Errorf("authorizer.AttributesRecord has a new field: %q. Add to ResourceAttributesFrom/NonResourceAttributesFrom as appropriate, then add to knownAttributesRecordFieldNames", name)
- }
- return false
- })
- }
|