Skip to content
This repository has been archived by the owner on Dec 10, 2024. It is now read-only.

Commit

Permalink
Merge pull request #1702 from cloudquery/feat/group_members/email
Browse files Browse the repository at this point in the history
feat: Add `email` field to `GroupMember`
  • Loading branch information
svanharmelen authored Apr 17, 2023
2 parents 195295c + cc52c83 commit 36a0985
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 3 deletions.
3 changes: 2 additions & 1 deletion group_members.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ type GroupMember struct {
CreatedAt *time.Time `json:"created_at"`
ExpiresAt *ISOTime `json:"expires_at"`
AccessLevel AccessLevelValue `json:"access_level"`
Email string `json:"email,omitempty"`
GroupSAMLIdentity *GroupMemberSAMLIdentity `json:"group_saml_identity"`
}

Expand Down Expand Up @@ -168,7 +169,7 @@ type BillableGroupMember struct {
Email string `json:"email"`
LastActivityOn *ISOTime `json:"last_activity_on"`
MembershipType string `json:"membership_type"`
Removeable bool `json:"removeable"`
Removable bool `json:"removable"`
CreatedAt *time.Time `json:"created_at"`
IsLastOwner bool `json:"is_last_owner"`
LastLoginAt *time.Time `json:"last_login_at"`
Expand Down
104 changes: 102 additions & 2 deletions group_members_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ func TestListBillableGroupMembers(t *testing.T) {
"web_url":"http://192.168.1.8:3000/root",
"last_activity_on":"2021-01-27",
"membership_type": "group_member",
"removeable": true,
"removable": true,
"created_at": "2017-10-23T11:41:28.793Z",
"is_last_owner": false,
"last_login_at": "2022-12-12T09:22:51.581Z"
Expand Down Expand Up @@ -71,7 +71,7 @@ func TestListBillableGroupMembers(t *testing.T) {
WebURL: "http://192.168.1.8:3000/root",
LastActivityOn: &lastActivityOnISOTime,
MembershipType: "group_member",
Removeable: true,
Removable: true,
CreatedAt: &createdAt,
IsLastOwner: false,
LastLoginAt: &lastLoginAt,
Expand All @@ -80,6 +80,106 @@ func TestListBillableGroupMembers(t *testing.T) {
assert.Equal(t, want, billableMembers, "Expected returned Groups.ListBillableGroupMembers to equal")
}

func TestListGroupMembersWithoutEmail(t *testing.T) {
mux, client := setup(t)

mux.HandleFunc("/api/v4/groups/1/members",
func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodGet)
fmt.Fprint(w,
`[
{
"id": 1,
"username": "raymond_smith",
"name": "Raymond Smith",
"state": "active",
"avatar_url": "https://www.gravatar.com/avatar/c2525a7f58ae3776070e44c106c48e15?s=80&d=identicon",
"web_url": "http://192.168.1.8:3000/root",
"created_at": "2012-10-21T14:13:35Z",
"expires_at": "2012-10-22",
"access_level": 30,
"group_saml_identity": null
}
]`)
})

members, _, err := client.Groups.ListGroupMembers(1, &ListGroupMembersOptions{})
if err != nil {
t.Errorf("Groups.ListGroupMembers returned error: %v", err)
}

createdAt, _ := time.Parse(time.RFC3339, "2012-10-21T14:13:35Z")
expiresAt, _ := time.Parse(time.RFC3339, "2012-10-22T00:00:00Z")
expiresAtISOTime := ISOTime(expiresAt)
want := []*GroupMember{
{
ID: 1,
Username: "raymond_smith",
Name: "Raymond Smith",
State: "active",
AvatarURL: "https://www.gravatar.com/avatar/c2525a7f58ae3776070e44c106c48e15?s=80&d=identicon",
WebURL: "http://192.168.1.8:3000/root",
CreatedAt: &createdAt,
ExpiresAt: &expiresAtISOTime,
AccessLevel: 30,
},
}
if !reflect.DeepEqual(want, members) {
t.Errorf("Groups.ListBillableGroupMembers returned %+v, want %+v", members[0], want[0])
}
}

func TestListGroupMembersWithEmail(t *testing.T) {
mux, client := setup(t)

mux.HandleFunc("/api/v4/groups/1/members",
func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodGet)
fmt.Fprint(w,
`[
{
"id": 1,
"username": "raymond_smith",
"name": "Raymond Smith",
"state": "active",
"avatar_url": "https://www.gravatar.com/avatar/c2525a7f58ae3776070e44c106c48e15?s=80&d=identicon",
"web_url": "http://192.168.1.8:3000/root",
"created_at": "2012-10-21T14:13:35Z",
"expires_at": "2012-10-22",
"access_level": 30,
"email": "john@example.com",
"group_saml_identity": null
}
]`)
})

members, _, err := client.Groups.ListGroupMembers(1, &ListGroupMembersOptions{})
if err != nil {
t.Errorf("Groups.ListGroupMembers returned error: %v", err)
}

createdAt, _ := time.Parse(time.RFC3339, "2012-10-21T14:13:35Z")
expiresAt, _ := time.Parse(time.RFC3339, "2012-10-22T00:00:00Z")
expiresAtISOTime := ISOTime(expiresAt)
want := []*GroupMember{
{
ID: 1,
Username: "raymond_smith",
Name: "Raymond Smith",
State: "active",
AvatarURL: "https://www.gravatar.com/avatar/c2525a7f58ae3776070e44c106c48e15?s=80&d=identicon",
WebURL: "http://192.168.1.8:3000/root",
CreatedAt: &createdAt,
ExpiresAt: &expiresAtISOTime,
AccessLevel: 30,
Email: "john@example.com",
},
}
if !reflect.DeepEqual(want, members) {
t.Errorf("Groups.ListBillableGroupMembers returned %+v, want %+v", members[0], want[0])
}
}

func TestListGroupMembersWithoutSAML(t *testing.T) {
mux, client := setup(t)

Expand Down

0 comments on commit 36a0985

Please sign in to comment.