Merge pull request #1785 from AllenZMC/context_test

add ut for IsControllerEnabled and update configure-controllers.md
This commit is contained in:
karmada-bot 2022-05-13 15:24:43 +08:00 committed by GitHub
commit bac80da911
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 111 additions and 2 deletions

View File

@ -48,9 +48,9 @@ E.g. Specify a controller list:
--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
--controllers=-hpa,-unifiedAuth
--controllers=-hpa,-unifiedAuth,*
```
Use `-foo` to disable the controller named `foo`.

View File

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