Merge pull request #35 from ribaptista/master

Webhook decoding
This commit is contained in:
George Fleury 2019-11-03 15:17:55 +01:00 committed by GitHub
commit b0145373d4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 97 additions and 0 deletions

View File

@ -274,6 +274,19 @@ type Content struct {
Revision string `json:"revision"`
}
type WebhookConfiguration struct {
Secret string `json:"secret"`
}
type Webhook struct {
ID int `json:"id"`
Name string `json:"name"`
Events []string `json:"events"`
Url string `json:"url"`
Active bool `json:"active"`
Configuration WebhookConfiguration `json:"configuration"`
}
func (k *SSHKey) String() string {
parts := make([]string, 1, 2)
parts[0] = strings.TrimSpace(k.Text)
@ -343,6 +356,13 @@ func GetContentResponse(r *APIResponse) (Content, error) {
return c, err
}
// GetWebhooksResponse cast Webhooks into structure
func GetWebhooksResponse(r *APIResponse) ([]Webhook, error) {
var h []Webhook
err := mapstructure.Decode(r.Values["values"], &h)
return h, err
}
// NewAPIResponse create new APIResponse from http.Response
func NewAPIResponse(r *http.Response) *APIResponse {

View File

@ -219,6 +219,83 @@ func TestGetSSHKeysResponse(t *testing.T) {
}
}
func TestGetWebhooksResponse(t *testing.T) {
type args struct {
r *APIResponse
}
tests := []struct {
name string
args args
want []Webhook
wantErr bool
}{
{
name: "Empty list",
args: args{
r: &APIResponse{
Values: map[string]interface{}{ "values": []interface{}{} },
},
},
want: []Webhook{},
wantErr: false,
},
{
name: "Single webhook",
args: args{
r: &APIResponse{
Values: map[string]interface{}{
"values": []interface{}{map[string]interface{}{
"id": 1,
"name": "foo",
"url": "http://bitbucket.localhost/hook",
"active": false,
"events": []string{ "repo:modified" },
"configuration": map[string]interface{}{
"secret": "password",
},
}},
},
},
},
want: []Webhook{
Webhook{
ID: 1,
Name: "foo",
Url: "http://bitbucket.localhost/hook",
Active: false,
Events: []string{ "repo:modified" },
Configuration: WebhookConfiguration{
Secret: "password",
},
},
},
wantErr: false,
},
{
name: "Bad response",
args: args{
r: &APIResponse{
Values: map[string]interface{}{ "values": "not an array" },
},
},
want: nil,
wantErr: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, err := GetWebhooksResponse(tt.args.r)
if (err != nil) != tt.wantErr {
t.Errorf("GetWebhooksResponse() error = %v, wantErr %v", err, tt.wantErr)
return
}
if !reflect.DeepEqual(got, tt.want) {
t.Errorf("GetWebhooksResponse() = %v, want %v", got, tt.want)
}
})
}
}
func TestNewAPIResponse(t *testing.T) {
type args struct {
r *http.Response