Merge pull request #49656 from deads2k/server-36-admit-error

Automatic merge from submit-queue (batch tested with PRs 49237, 49656, 49980, 49841, 49899)

make admission tolerate object without objectmeta for errors

Not all object have ObjectMeta (see SARs for instance).  Admission should tolerate this condition without giving meaningless errors.

@derekwaynecarr ptal
@php-coder fyi
pull/6/head
Kubernetes Submit Queue 2017-08-02 19:11:11 -07:00 committed by GitHub
commit 093883433b
3 changed files with 72 additions and 2 deletions

View File

@ -13,10 +13,12 @@ go_test(
srcs = [ srcs = [
"chain_test.go", "chain_test.go",
"config_test.go", "config_test.go",
"errors_test.go",
], ],
library = ":go_default_library", library = ":go_default_library",
tags = ["automanaged"], tags = ["automanaged"],
deps = [ deps = [
"//vendor/k8s.io/apimachinery/pkg/runtime:go_default_library",
"//vendor/k8s.io/apimachinery/pkg/runtime/schema:go_default_library", "//vendor/k8s.io/apimachinery/pkg/runtime/schema:go_default_library",
"//vendor/k8s.io/apiserver/pkg/apis/apiserver:go_default_library", "//vendor/k8s.io/apiserver/pkg/apis/apiserver:go_default_library",
], ],

View File

@ -24,13 +24,19 @@ import (
) )
func extractResourceName(a Attributes) (name string, resource schema.GroupResource, err error) { func extractResourceName(a Attributes) (name string, resource schema.GroupResource, err error) {
name = "Unknown"
resource = a.GetResource().GroupResource() resource = a.GetResource().GroupResource()
if len(a.GetName()) > 0 {
return a.GetName(), resource, nil
}
name = "Unknown"
obj := a.GetObject() obj := a.GetObject()
if obj != nil { if obj != nil {
accessor, err := meta.Accessor(obj) accessor, err := meta.Accessor(obj)
if err != nil { if err != nil {
return "", schema.GroupResource{}, err // not all object have ObjectMeta. If we don't, return a name with a slash (always illegal)
return "Unknown/errorGettingName", resource, nil
} }
// this is necessary because name object name generation has not occurred yet // this is necessary because name object name generation has not occurred yet

View File

@ -0,0 +1,62 @@
/*
Copyright 2015 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 admission
import (
"errors"
"testing"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/schema"
)
// makes sure that we never get:
// Internal error occurred: [some error, object does not implement the Object interfaces]
func TestNewForbidden(t *testing.T) {
attributes := NewAttributesRecord(
&fakeObj{},
nil,
schema.GroupVersionKind{Group: "foo", Version: "bar", Kind: "Baz"},
"",
"",
schema.GroupVersionResource{Group: "foo", Version: "bar", Resource: "baz"},
"",
Create,
nil)
err := errors.New("some error")
expectedErr := `baz.foo "Unknown/errorGettingName" is forbidden: some error`
actualErr := NewForbidden(attributes, err)
if actualErr.Error() != expectedErr {
t.Errorf("expected %v, got %v", expectedErr, actualErr)
}
}
type fakeObj struct{}
type fakeObjKind struct{}
func (f *fakeObj) GetObjectKind() schema.ObjectKind {
return &fakeObjKind{}
}
func (f *fakeObj) DeepCopyObject() runtime.Object {
return f
}
func (f *fakeObjKind) SetGroupVersionKind(kind schema.GroupVersionKind) {}
func (f *fakeObjKind) GroupVersionKind() schema.GroupVersionKind {
return schema.GroupVersionKind{Group: "foo", Version: "bar", Kind: "Baz"}
}