Merge pull request #55052 from hzxuzhonghu/admission-handler

Automatic merge from submit-queue (batch tested with PRs 51401, 54056, 54977, 55017, 55052). If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>.

refactor admission handler and add UT

**What this PR does / why we need it**:

remove Redundant code, and add UT case.

**Which issue(s) this PR fixes** *(optional, in `fixes #<issue number>(, fixes #<issue_number>, ...)` format, will close the issue(s) when PR gets merged)*:
Fixes #

**Special notes for your reviewer**:

**Release note**:

```release-note
NONE

```

Kubernetes-commit: 85a6ec7b610454d046589ed0610209b832188e42
This commit is contained in:
Kubernetes Publisher 2017-11-03 12:08:04 -07:00
commit 656d3dafc2
4 changed files with 288 additions and 236 deletions

458
Godeps/Godeps.json generated

File diff suppressed because it is too large Load Diff

View File

@ -12,6 +12,7 @@ go_test(
"chain_test.go",
"config_test.go",
"errors_test.go",
"handler_test.go",
],
importpath = "k8s.io/apiserver/pkg/admission",
library = ":go_default_library",

View File

@ -66,14 +66,8 @@ func (h *Handler) WaitForReady() bool {
if h.readyFunc == nil {
return true
}
return h.waitForReadyInternal(time.After(timeToWaitForReady))
}
func (h *Handler) waitForReadyInternal(timeout <-chan time.Time) bool {
// there is no configured ready func, so return immediately
if h.readyFunc == nil {
return true
}
timeout := time.After(timeToWaitForReady)
for !h.readyFunc() {
select {
case <-time.After(100 * time.Millisecond):

View File

@ -0,0 +1,57 @@
/*
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 admission
import (
"testing"
"time"
)
func TestWaitForReady(t *testing.T) {
handler := newFakeHandler()
// 1. test no readyFunc
if !handler.WaitForReady() {
t.Errorf("Expect ready for no readyFunc provided.")
}
// 2. readyFunc return ready immediately
readyFunc := func() bool {
return true
}
handler.SetReadyFunc(readyFunc)
if !handler.WaitForReady() {
t.Errorf("Expect ready for readyFunc returns ready immediately.")
}
// 3. readyFunc always return not ready. WaitForReady timeout
readyFunc = func() bool {
return false
}
startTime := time.Now()
handler.SetReadyFunc(readyFunc)
if handler.WaitForReady() {
t.Errorf("Expect not ready for readyFunc returns not ready immediately.")
}
if time.Since(startTime) < timeToWaitForReady {
t.Errorf("Expect WaitForReady timeout.")
}
}
func newFakeHandler() *Handler {
return NewHandler(Create, Update)
}