diff options
author | Ethan Koenig <etk39@cornell.edu> | 2017-01-25 05:37:35 -0500 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2017-01-25 18:37:35 +0800 |
commit | 0934d1b1ea4f3cab5af5555116ae13a87c65f34c (patch) | |
tree | 8d05aa5b330f2a33f50313881e5dee0815d43815 /models/webhook_test.go | |
parent | a6832c234d5c73cfa00cb4a926f446e0b14b9732 (diff) | |
download | gitea-0934d1b1ea4f3cab5af5555116ae13a87c65f34c.tar.gz gitea-0934d1b1ea4f3cab5af5555116ae13a87c65f34c.zip |
Bug fixes and unit tests for models/webhook (#751)
Diffstat (limited to 'models/webhook_test.go')
-rw-r--r-- | models/webhook_test.go | 263 |
1 files changed, 263 insertions, 0 deletions
diff --git a/models/webhook_test.go b/models/webhook_test.go new file mode 100644 index 0000000000..3f377eae7a --- /dev/null +++ b/models/webhook_test.go @@ -0,0 +1,263 @@ +// Copyright 2017 The Gitea Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package models + +import ( + "encoding/json" + "testing" + + api "code.gitea.io/sdk/gitea" + + "github.com/stretchr/testify/assert" +) + +func TestHookContentType_Name(t *testing.T) { + assert.Equal(t, "json", ContentTypeJSON.Name()) + assert.Equal(t, "form", ContentTypeForm.Name()) +} + +func TestIsValidHookContentType(t *testing.T) { + assert.True(t, IsValidHookContentType("json")) + assert.True(t, IsValidHookContentType("form")) + assert.False(t, IsValidHookContentType("invalid")) +} + +func TestWebhook_GetSlackHook(t *testing.T) { + w := &Webhook{ + Meta: `{"channel": "foo", "username": "username", "color": "blue"}`, + } + slackHook := w.GetSlackHook() + assert.Equal(t, *slackHook, SlackMeta{ + Channel: "foo", + Username: "username", + Color: "blue", + }) +} + +func TestWebhook_History(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + webhook := AssertExistsAndLoadBean(t, &Webhook{ID: 1}).(*Webhook) + tasks, err := webhook.History(0) + assert.NoError(t, err) + assert.Len(t, tasks, 1) + assert.Equal(t, int64(1), tasks[0].ID) + + webhook = AssertExistsAndLoadBean(t, &Webhook{ID: 2}).(*Webhook) + tasks, err = webhook.History(0) + assert.NoError(t, err) + assert.Len(t, tasks, 0) +} + +func TestWebhook_UpdateEvent(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + webhook := AssertExistsAndLoadBean(t, &Webhook{ID: 1}).(*Webhook) + hookEvent := &HookEvent{ + PushOnly: true, + SendEverything: false, + ChooseEvents: false, + HookEvents: HookEvents{ + Create: false, + Push: true, + PullRequest: false, + }, + } + webhook.HookEvent = hookEvent + assert.NoError(t, webhook.UpdateEvent()) + assert.NotEmpty(t, webhook.Events) + actualHookEvent := &HookEvent{} + assert.NoError(t, json.Unmarshal([]byte(webhook.Events), actualHookEvent)) + assert.Equal(t, *hookEvent, *actualHookEvent) +} + +func TestWebhook_EventsArray(t *testing.T) { + assert.Equal(t, []string{"create", "push", "pull_request"}, + (&Webhook{ + HookEvent: &HookEvent{SendEverything: true}, + }).EventsArray(), + ) + + assert.Equal(t, []string{"push"}, + (&Webhook{ + HookEvent: &HookEvent{PushOnly: true}, + }).EventsArray(), + ) +} + +func TestCreateWebhook(t *testing.T) { + hook := &Webhook{ + RepoID: 3, + URL: "www.example.com/unit_test", + ContentType: ContentTypeJSON, + Events: `{"push_only":false,"send_everything":false,"choose_events":false,"events":{"create":false,"push":true,"pull_request":true}}`, + } + AssertNotExistsBean(t, hook) + assert.NoError(t, CreateWebhook(hook)) + AssertExistsAndLoadBean(t, hook) +} + +func TestGetWebhookByRepoID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hook, err := GetWebhookByRepoID(1, 1) + assert.NoError(t, err) + assert.Equal(t, int64(1), hook.ID) + + _, err = GetWebhookByRepoID(NonexistentID, NonexistentID) + assert.Error(t, err) + assert.True(t, IsErrWebhookNotExist(err)) +} + +func TestGetWebhookByOrgID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hook, err := GetWebhookByOrgID(3, 3) + assert.NoError(t, err) + assert.Equal(t, int64(3), hook.ID) + + _, err = GetWebhookByOrgID(NonexistentID, NonexistentID) + assert.Error(t, err) + assert.True(t, IsErrWebhookNotExist(err)) +} + +func TestGetActiveWebhooksByRepoID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hooks, err := GetActiveWebhooksByRepoID(1) + assert.NoError(t, err) + assert.Len(t, hooks, 1) + assert.Equal(t, int64(1), hooks[0].ID) + assert.True(t, hooks[0].IsActive) +} + +func TestGetWebhooksByRepoID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hooks, err := GetWebhooksByRepoID(1) + assert.NoError(t, err) + assert.Len(t, hooks, 2) + assert.Equal(t, int64(1), hooks[0].ID) + assert.Equal(t, int64(2), hooks[1].ID) +} + +func TestGetActiveWebhooksByOrgID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hooks, err := GetActiveWebhooksByOrgID(3) + assert.NoError(t, err) + assert.Len(t, hooks, 1) + assert.Equal(t, int64(3), hooks[0].ID) + assert.True(t, hooks[0].IsActive) +} + +func TestGetWebhooksByOrgID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hooks, err := GetWebhooksByOrgID(3) + assert.NoError(t, err) + assert.Len(t, hooks, 1) + assert.Equal(t, int64(3), hooks[0].ID) + assert.True(t, hooks[0].IsActive) + +} + +func TestUpdateWebhook(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hook := AssertExistsAndLoadBean(t, &Webhook{ID: 2}).(*Webhook) + hook.IsActive = true + hook.ContentType = ContentTypeForm + AssertNotExistsBean(t, hook) + assert.NoError(t, UpdateWebhook(hook)) + AssertExistsAndLoadBean(t, hook) +} + +func TestDeleteWebhookByRepoID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + AssertExistsAndLoadBean(t, &Webhook{ID: 2, RepoID: 1}) + assert.NoError(t, DeleteWebhookByRepoID(1, 2)) + AssertNotExistsBean(t, &Webhook{ID: 2, RepoID: 1}) + + err := DeleteWebhookByRepoID(NonexistentID, NonexistentID) + assert.Error(t, err) + assert.True(t, IsErrWebhookNotExist(err)) +} + +func TestDeleteWebhookByOrgID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + AssertExistsAndLoadBean(t, &Webhook{ID: 3, OrgID: 3}) + assert.NoError(t, DeleteWebhookByOrgID(3, 3)) + AssertNotExistsBean(t, &Webhook{ID: 3, OrgID: 3}) + + err := DeleteWebhookByOrgID(NonexistentID, NonexistentID) + assert.Error(t, err) + assert.True(t, IsErrWebhookNotExist(err)) +} + +func TestToHookTaskType(t *testing.T) { + assert.Equal(t, GOGS, ToHookTaskType("gogs")) + assert.Equal(t, SLACK, ToHookTaskType("slack")) +} + +func TestHookTaskType_Name(t *testing.T) { + assert.Equal(t, "gogs", GOGS.Name()) + assert.Equal(t, "slack", SLACK.Name()) +} + +func TestIsValidHookTaskType(t *testing.T) { + assert.True(t, IsValidHookTaskType("gogs")) + assert.True(t, IsValidHookTaskType("slack")) + assert.False(t, IsValidHookTaskType("invalid")) +} + +func TestHookTasks(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hookTasks, err := HookTasks(1, 1) + assert.NoError(t, err) + assert.Len(t, hookTasks, 1) + assert.Equal(t, int64(1), hookTasks[0].ID) + + hookTasks, err = HookTasks(NonexistentID, 1) + assert.NoError(t, err) + assert.Len(t, hookTasks, 0) +} + +func TestCreateHookTask(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + hookTask := &HookTask{ + RepoID: 3, + HookID: 3, + Type: GOGS, + URL: "http://www.example.com/unit_test", + Payloader: &api.PushPayload{}, + } + AssertNotExistsBean(t, hookTask) + assert.NoError(t, CreateHookTask(hookTask)) + AssertExistsAndLoadBean(t, hookTask) +} + +func TestUpdateHookTask(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + + hook := AssertExistsAndLoadBean(t, &HookTask{ID: 1}).(*HookTask) + hook.PayloadContent = "new payload content" + hook.DeliveredString = "new delivered string" + hook.IsDelivered = true + AssertNotExistsBean(t, hook) + assert.NoError(t, UpdateHookTask(hook)) + AssertExistsAndLoadBean(t, hook) +} + +func TestPrepareWebhooks(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + + repo := AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository) + hookTasks := []*HookTask{ + {RepoID: repo.ID, HookID: 1, EventType: HookEventPush}, + } + for _, hookTask := range hookTasks { + AssertNotExistsBean(t, hookTask) + } + assert.NoError(t, PrepareWebhooks(repo, HookEventPush, &api.PushPayload{})) + for _, hookTask := range hookTasks { + AssertExistsAndLoadBean(t, hookTask) + } +} + +// TODO TestHookTask_deliver + +// TODO TestDeliverHooks |