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

```
This commit is contained in:
Kubernetes Submit Queue 2017-11-03 12:08:04 -07:00 committed by GitHub
commit 85a6ec7b61
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 59 additions and 7 deletions

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)
}