Skip to content

Commit 8a1c453

Browse files
author
Roland.Ma
committed
refine group e2e test
Signed-off-by: Roland.Ma <[email protected]>
1 parent eaf937b commit 8a1c453

File tree

15 files changed

+536
-29
lines changed

15 files changed

+536
-29
lines changed

go.mod

+1-1
Original file line numberDiff line numberDiff line change
@@ -72,7 +72,7 @@ require (
7272
github.com/stretchr/testify v1.6.1
7373
github.com/xanzy/ssh-agent v0.2.1 // indirect
7474
golang.org/x/crypto v0.0.0-20200728195943-123391ffb6de
75-
golang.org/x/net v0.0.0-20200707034311-ab3426394381
75+
golang.org/x/net v0.0.0-20201224014010-6772e930b67b
7676
golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d
7777
google.golang.org/grpc v1.30.0
7878
gopkg.in/asn1-ber.v1 v1.0.0-20181015200546-f715ec2f112d // indirect

go.sum

+2
Original file line numberDiff line numberDiff line change
@@ -289,6 +289,8 @@ github.com/go-playground/locales v0.12.1/go.mod h1:IUMDtCfWo/w/mtMfIE/IG2K+Ey3yg
289289
github.com/go-playground/universal-translator v0.0.0-20170327191703-71201497bace/go.mod h1:1AnU7NaIRDWWzGEKwgtJRd2xk99HeFyHw3yid4rvQIY=
290290
github.com/go-redis/redis v6.15.2+incompatible h1:9SpNVG76gr6InJGxoZ6IuuxaCOQwDAhzyXg+Bs+0Sb4=
291291
github.com/go-redis/redis v6.15.2+incompatible/go.mod h1:NAIEuMOZ/fxfXJIrKDQDz8wamY7mA7PouImQ2Jvg6kA=
292+
github.com/go-resty/resty/v2 v2.5.0 h1:WFb5bD49/85PO7WgAjZ+/TJQ+Ty1XOcWEfD1zIFCM1c=
293+
github.com/go-resty/resty/v2 v2.5.0/go.mod h1:B88+xCTEwvfD94NOuE6GS1wMlnoKNY8eEiNizfNwOwA=
292294
github.com/go-sql-driver/mysql v1.5.0 h1:ozyZYNQW3x3HtqT1jira07DN2PArx2v7/mN66gGcHOs=
293295
github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
294296
github.com/go-stack/stack v1.8.0 h1:5SgMzNM5HxrEjV0ww2lTmX6E2Izsfxas4+YHWRs3Lsk=

staging/src/kubesphere.io/client-go/go.mod

+1
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@ module kubesphere.io/client-go
77
go 1.13
88

99
require (
10+
github.com/go-resty/resty/v2 v2.5.0
1011
k8s.io/apimachinery v0.18.6
1112
k8s.io/client-go v0.18.6
1213
sigs.k8s.io/controller-runtime v0.6.4

staging/src/kubesphere.io/client-go/go.sum

+7
Original file line numberDiff line numberDiff line change
@@ -117,6 +117,8 @@ github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh
117117
github.com/go-openapi/validate v0.18.0/go.mod h1:Uh4HdOzKt19xGIGm1qHf/ofbX1YQ4Y+MYsct2VUrAJ4=
118118
github.com/go-openapi/validate v0.19.2/go.mod h1:1tRCw7m3jtI8eNWEEliiAqUIcBztB2KDnRCRMUi7GTA=
119119
github.com/go-openapi/validate v0.19.5/go.mod h1:8DJv2CVJQ6kGNpFW6eV9N3JviE1C85nY1c2z52x1Gk4=
120+
github.com/go-resty/resty/v2 v2.5.0 h1:WFb5bD49/85PO7WgAjZ+/TJQ+Ty1XOcWEfD1zIFCM1c=
121+
github.com/go-resty/resty/v2 v2.5.0/go.mod h1:B88+xCTEwvfD94NOuE6GS1wMlnoKNY8eEiNizfNwOwA=
120122
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
121123
github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
122124
github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4=
@@ -324,6 +326,8 @@ golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLL
324326
golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
325327
golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7 h1:AeiKBIuRw3UomYXSbLy0Mc2dDLfdtbT/IVn4keq83P0=
326328
golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A=
329+
golang.org/x/net v0.0.0-20201224014010-6772e930b67b h1:iFwSg7t5GZmB/Q5TjiEAsdoLDrdJRC1RiF2WhuV29Qw=
330+
golang.org/x/net v0.0.0-20201224014010-6772e930b67b/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg=
327331
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
328332
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
329333
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45 h1:SVwTIAaPC2U/AvvLNZ2a7OVsmBpC8L5BlwK1whH3hm0=
@@ -355,6 +359,9 @@ golang.org/x/sys v0.0.0-20191120155948-bd437916bb0e/go.mod h1:h1NjWce9XRLGQEsW7w
355359
golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
356360
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd h1:xhmwyvizuTgC2qz7ZlMluP20uW+C3Rm0FD/WLDX8884=
357361
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
362+
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68 h1:nxC68pudNYkKU6jWhgrqdreuFiOQWj1Fs7T3VrH4Pjw=
363+
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
364+
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
358365
golang.org/x/text v0.0.0-20160726164857-2910a502d2bf/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
359366
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
360367
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
/*
2+
Copyright 2021 The KubeSphere Authors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package restclient
18+
19+
import (
20+
rest "k8s.io/client-go/rest"
21+
iamv1alpha2 "kubesphere.io/client-go/restclient/versioned/iam/v1alpha2"
22+
)
23+
24+
// NewForConfig returns a new Client using the provided config and Options.
25+
func NewForConfig(c *rest.Config) (*RestClient, error) {
26+
var rc RestClient
27+
var err error
28+
rc.iamV1alpha2, err = iamv1alpha2.NewForConfig(c)
29+
if err != nil {
30+
return nil, err
31+
}
32+
return &rc, nil
33+
}
34+
35+
// RestClient is a set of restful API clients that doesn't compatible with
36+
// Kube API machinery.
37+
type RestClient struct {
38+
iamV1alpha2 *iamv1alpha2.IamV1alpha2Client
39+
}
40+
41+
// IamV1alpha2 retrieves the IamV1alpha2Client
42+
func (c *RestClient) IamV1alpha2() iamv1alpha2.IamV1alpha2Interface {
43+
return c.iamV1alpha2
44+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,65 @@
1+
/*
2+
Copyright 2021 The KubeSphere Authors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package v1alpha2
18+
19+
import (
20+
"context"
21+
22+
resty "github.com/go-resty/resty/v2"
23+
)
24+
25+
type GroupsGetter interface {
26+
Groups() GroupInterface
27+
}
28+
29+
type GroupInterface interface {
30+
CreateBinding(ctx context.Context, workspace, group, user string) (string, error)
31+
}
32+
33+
type groups struct {
34+
client *resty.Client
35+
}
36+
37+
func newGroups(c *IamV1alpha2Client) *groups {
38+
return &groups{
39+
client: c.client,
40+
}
41+
}
42+
43+
//TODO: to be remoted once we move kubesphere.io/apis out of kubesphere package
44+
type groupMember struct {
45+
UserName string `json:"userName"`
46+
GroupName string `json:"groupName"`
47+
}
48+
49+
// Create takes the representation of a group and creates it. Returns the server's representation of the group, and an error, if there is any.
50+
func (c *groups) CreateBinding(ctx context.Context, workspace, group, user string) (result string, err error) {
51+
52+
members := []groupMember{{
53+
UserName: user,
54+
GroupName: group,
55+
}}
56+
57+
resp, err := c.client.R().
58+
SetHeader("Content-Type", "application/json").
59+
SetBody(members).
60+
SetPathParams(map[string]string{
61+
"workspace": workspace,
62+
}).
63+
Post("/kapis/iam.kubesphere.io/v1alpha2/workspaces/{workspace}/groupbindings")
64+
return resp.String(), err
65+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
/*
2+
Copyright 2020 The KubeSphere Authors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package v1alpha2
18+
19+
import (
20+
resty "github.com/go-resty/resty/v2"
21+
rest "k8s.io/client-go/rest"
22+
)
23+
24+
type IamV1alpha2Interface interface {
25+
GroupsGetter
26+
RoleBindingsGetter
27+
}
28+
type IamV1alpha2Client struct {
29+
client *resty.Client
30+
}
31+
32+
func (c *IamV1alpha2Client) Groups() GroupInterface {
33+
return newGroups(c)
34+
}
35+
36+
func (c *IamV1alpha2Client) RoleBindings() RoleBindingInterface {
37+
return newRoleBindings(c)
38+
}
39+
40+
// NewForConfig creates a new IamV1alpha2Client for the given config.
41+
func NewForConfig(c *rest.Config) (*IamV1alpha2Client, error) {
42+
43+
client := resty.New()
44+
45+
client.SetHostURL(c.Host)
46+
if c.BearerToken != "" {
47+
client.SetAuthToken(c.BearerToken)
48+
}
49+
50+
if c.Username != "" {
51+
client.SetBasicAuth(c.Username, c.Password)
52+
}
53+
54+
return &IamV1alpha2Client{client}, nil
55+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,98 @@
1+
/*
2+
Copyright 2020 The KubeSphere Authors.
3+
4+
Licensed under the Apache License, Version 2.0 (the "License");
5+
you may not use this file except in compliance with the License.
6+
You may obtain a copy of the License at
7+
8+
http://www.apache.org/licenses/LICENSE-2.0
9+
10+
Unless required by applicable law or agreed to in writing, software
11+
distributed under the License is distributed on an "AS IS" BASIS,
12+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
See the License for the specific language governing permissions and
14+
limitations under the License.
15+
*/
16+
17+
package v1alpha2
18+
19+
import (
20+
"context"
21+
22+
resty "github.com/go-resty/resty/v2"
23+
)
24+
25+
type RoleBindingsGetter interface {
26+
RoleBindings() RoleBindingInterface
27+
}
28+
29+
type RoleBindingInterface interface {
30+
CreateRoleBinding(ctx context.Context, namespace, role, group string) (string, error)
31+
CreateWorkspaceRoleBinding(ctx context.Context, namespace, role, group string) (string, error)
32+
}
33+
34+
type rolebindings struct {
35+
client *resty.Client
36+
}
37+
38+
func newRoleBindings(c *IamV1alpha2Client) *rolebindings {
39+
return &rolebindings{
40+
client: c.client,
41+
}
42+
}
43+
44+
// CreateRoleBinding assembling of a rolebinding object and creates it. Returns the server's response and an error, if there is any.
45+
func (c *rolebindings) CreateRoleBinding(ctx context.Context, namespace, role, group string) (result string, err error) {
46+
47+
roles := []map[string]interface{}{{
48+
"subjects": []map[string]interface{}{
49+
{
50+
"kind": "Group",
51+
"apiGroup": "rbac.authorization.k8s.io",
52+
"name": group,
53+
},
54+
},
55+
"roleRef": map[string]interface{}{
56+
"apiGroup": "rbac.authorization.k8s.io",
57+
"kind": "Role",
58+
"name": role,
59+
},
60+
}}
61+
62+
resp, err := c.client.R().
63+
SetHeader("Content-Type", "application/json").
64+
SetBody(roles).
65+
SetPathParams(map[string]string{
66+
"namespace": namespace,
67+
}).
68+
Post("/kapis/iam.kubesphere.io/v1alpha2/namespaces/{namespace}/rolebindings")
69+
return resp.String(), err
70+
}
71+
72+
// CreateWorkspaceRoleBinding assembling of a workspacerolebinding object and creates it. Returns the server's response, and an error, if there is any.
73+
func (c *rolebindings) CreateWorkspaceRoleBinding(ctx context.Context, workspace, role, group string) (result string, err error) {
74+
75+
roles := []map[string]interface{}{{
76+
"subjects": []map[string]interface{}{
77+
{
78+
"kind": "Group",
79+
"apiGroup": "rbac.authorization.k8s.io",
80+
"name": group,
81+
},
82+
},
83+
"roleRef": map[string]interface{}{
84+
"apiGroup": "iam.kubesphere.io/v1alpha2",
85+
"kind": "WorkspaceRoleBinding",
86+
"name": role,
87+
},
88+
}}
89+
90+
resp, err := c.client.R().
91+
SetHeader("Content-Type", "application/json").
92+
SetBody(roles).
93+
SetPathParams(map[string]string{
94+
"workspace": workspace,
95+
}).
96+
Post("/kapis/iam.kubesphere.io/v1alpha2/workspaces/{workspace}/workspacerolebindings/")
97+
return resp.String(), err
98+
}

test/e2e/constants.go test/e2e/constant/constants.go

+4-1
Original file line numberDiff line numberDiff line change
@@ -14,8 +14,11 @@ See the License for the specific language governing permissions and
1414
limitations under the License.
1515
*/
1616

17-
package e2e
17+
package constant
1818

1919
const (
2020
DefaultWorkspaceRoleAdmin = "%v-admin"
21+
DefaultAdminUser = "admin"
22+
DefaultPassword = "P@88w0rd"
23+
LocalAPIServer = "http://127.0.0.1:9090"
2124
)

0 commit comments

Comments
 (0)