Merge pull request #1785 from AllenZMC/context_test
add ut for IsControllerEnabled and update configure-controllers.md
This commit is contained in:
commit
bac80da911
|
@ -48,9 +48,9 @@ E.g. Specify a controller list:
|
||||||
--controllers=cluster,clusterStatus,binding,xxx
|
--controllers=cluster,clusterStatus,binding,xxx
|
||||||
```
|
```
|
||||||
|
|
||||||
E.g. Disable some controllers:
|
E.g. Disable some controllers(remember to keep `*` if you want to keep the rest controllers in the default list):
|
||||||
```bash
|
```bash
|
||||||
--controllers=-hpa,-unifiedAuth
|
--controllers=-hpa,-unifiedAuth,*
|
||||||
```
|
```
|
||||||
Use `-foo` to disable the controller named `foo`.
|
Use `-foo` to disable the controller named `foo`.
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,109 @@
|
||||||
|
package context
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"k8s.io/apimachinery/pkg/util/sets"
|
||||||
|
)
|
||||||
|
|
||||||
|
type args struct {
|
||||||
|
controllerName string
|
||||||
|
disabledByDefaultControllers []string
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestContext_IsControllerEnabled(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
opts Options
|
||||||
|
args args
|
||||||
|
expected bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "on by name",
|
||||||
|
args: args{
|
||||||
|
controllerName: "bravo",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"alpha", "bravo", "-charlie"},
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "off by name",
|
||||||
|
args: args{
|
||||||
|
controllerName: "charlie",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"alpha", "bravo", "-charlie"},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "on by default",
|
||||||
|
args: args{
|
||||||
|
controllerName: "alpha",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"*"},
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "off by default",
|
||||||
|
args: args{
|
||||||
|
controllerName: "delta",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"*"},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "on by star, not off by name",
|
||||||
|
args: args{
|
||||||
|
controllerName: "alpha",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"*", "-charlie"},
|
||||||
|
},
|
||||||
|
expected: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "off by name with star",
|
||||||
|
args: args{
|
||||||
|
controllerName: "charlie",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"*", "-charlie"},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "off by default implicit, no star",
|
||||||
|
args: args{
|
||||||
|
controllerName: "foxtrot",
|
||||||
|
disabledByDefaultControllers: []string{"delta", "echo"},
|
||||||
|
},
|
||||||
|
opts: Options{
|
||||||
|
Controllers: []string{"alpha", "bravo", "-charlie"},
|
||||||
|
},
|
||||||
|
expected: false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
c := Context{
|
||||||
|
Opts: tt.opts,
|
||||||
|
}
|
||||||
|
if got := c.IsControllerEnabled(tt.args.controllerName, sets.NewString(tt.args.disabledByDefaultControllers...)); got != tt.expected {
|
||||||
|
t.Errorf("IsControllerEnabled() = %v, want %v", got, tt.expected)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue