mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-01 13:18:41 +00:00
193 lines
5.6 KiB
Go
193 lines
5.6 KiB
Go
|
package coding
|
||
|
|
||
|
import (
|
||
|
"io/ioutil"
|
||
|
"net/http"
|
||
|
"strings"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/drone/drone/model"
|
||
|
"github.com/drone/drone/remote/coding/fixtures"
|
||
|
|
||
|
"github.com/franela/goblin"
|
||
|
)
|
||
|
|
||
|
func Test_hook(t *testing.T) {
|
||
|
|
||
|
g := goblin.Goblin(t)
|
||
|
g.Describe("Coding hook", func() {
|
||
|
|
||
|
g.It("Should parse hook", func() {
|
||
|
|
||
|
reader := ioutil.NopCloser(strings.NewReader(fixtures.PushHook))
|
||
|
r := &http.Request{
|
||
|
Header: map[string][]string{
|
||
|
hookEvent: {hookPush},
|
||
|
},
|
||
|
Body: reader,
|
||
|
}
|
||
|
|
||
|
repo := &model.Repo{
|
||
|
Owner: "demo1",
|
||
|
Name: "test1",
|
||
|
FullName: "demo1/test1",
|
||
|
Link: "https://coding.net/u/demo1/p/test1",
|
||
|
Kind: model.RepoGit,
|
||
|
}
|
||
|
|
||
|
build := &model.Build{
|
||
|
Event: model.EventPush,
|
||
|
Commit: "5b9912a6ff272e9c93a4c44c278fe9b359ed1ab4",
|
||
|
Ref: "refs/heads/master",
|
||
|
Link: "https://coding.net/u/demo1/p/test1/git/commit/5b9912a6ff272e9c93a4c44c278fe9b359ed1ab4",
|
||
|
Branch: "master",
|
||
|
Message: "new file .drone.yml\n",
|
||
|
Email: "demo1@gmail.com",
|
||
|
Avatar: "/static/fruit_avatar/Fruit-20.png",
|
||
|
Author: "demo1",
|
||
|
Remote: "https://git.coding.net/demo1/test1.git",
|
||
|
}
|
||
|
|
||
|
actualRepo, actualBuild, err := parseHook(r)
|
||
|
g.Assert(err == nil).IsTrue()
|
||
|
g.Assert(actualRepo).Equal(repo)
|
||
|
g.Assert(actualBuild).Equal(build)
|
||
|
})
|
||
|
|
||
|
g.It("Should find last commit", func() {
|
||
|
commit1 := &Commit{SHA: "1234567890", Committer: &Committer{}}
|
||
|
commit2 := &Commit{SHA: "abcdef1234", Committer: &Committer{}}
|
||
|
commits := []*Commit{commit1, commit2}
|
||
|
g.Assert(findLastCommit(commits, "abcdef1234")).Equal(commit2)
|
||
|
})
|
||
|
|
||
|
g.It("Should find last commit", func() {
|
||
|
commit1 := &Commit{SHA: "1234567890", Committer: &Committer{}}
|
||
|
commit2 := &Commit{SHA: "abcdef1234", Committer: &Committer{}}
|
||
|
commits := []*Commit{commit1, commit2}
|
||
|
emptyCommit := &Commit{Committer: &Committer{}}
|
||
|
g.Assert(findLastCommit(commits, "00000000000")).Equal(emptyCommit)
|
||
|
})
|
||
|
|
||
|
g.It("Should convert repository", func() {
|
||
|
repository := &Repository{
|
||
|
Name: "test_project",
|
||
|
HttpsURL: "https://git.coding.net/kelvin/test_project.git",
|
||
|
SshURL: "git@git.coding.net:kelvin/test_project.git",
|
||
|
WebURL: "https://coding.net/u/kelvin/p/test_project",
|
||
|
Owner: &User{
|
||
|
GlobalKey: "kelvin",
|
||
|
Avatar: "https://dn-coding-net-production-static.qbox.me/9ed11de3-65e3-4cd8-b6aa-5abe7285ab43.jpeg?imageMogr2/auto-orient/format/jpeg/crop/!209x209a0a0",
|
||
|
},
|
||
|
}
|
||
|
repo := &model.Repo{
|
||
|
Owner: "kelvin",
|
||
|
Name: "test_project",
|
||
|
FullName: "kelvin/test_project",
|
||
|
Link: "https://coding.net/u/kelvin/p/test_project",
|
||
|
Kind: model.RepoGit,
|
||
|
}
|
||
|
actual, err := convertRepository(repository)
|
||
|
g.Assert(err == nil).IsTrue()
|
||
|
g.Assert(actual).Equal(repo)
|
||
|
})
|
||
|
|
||
|
g.It("Should parse push hook", func() {
|
||
|
|
||
|
repo := &model.Repo{
|
||
|
Owner: "demo1",
|
||
|
Name: "test1",
|
||
|
FullName: "demo1/test1",
|
||
|
Link: "https://coding.net/u/demo1/p/test1",
|
||
|
Kind: model.RepoGit,
|
||
|
}
|
||
|
|
||
|
build := &model.Build{
|
||
|
Event: model.EventPush,
|
||
|
Commit: "5b9912a6ff272e9c93a4c44c278fe9b359ed1ab4",
|
||
|
Ref: "refs/heads/master",
|
||
|
Link: "https://coding.net/u/demo1/p/test1/git/commit/5b9912a6ff272e9c93a4c44c278fe9b359ed1ab4",
|
||
|
Branch: "master",
|
||
|
Message: "new file .drone.yml\n",
|
||
|
Email: "demo1@gmail.com",
|
||
|
Avatar: "/static/fruit_avatar/Fruit-20.png",
|
||
|
Author: "demo1",
|
||
|
Remote: "https://git.coding.net/demo1/test1.git",
|
||
|
}
|
||
|
|
||
|
actualRepo, actualBuild, err := parsePushHook([]byte(fixtures.PushHook))
|
||
|
g.Assert(err == nil).IsTrue()
|
||
|
g.Assert(actualRepo).Equal(repo)
|
||
|
g.Assert(actualBuild).Equal(build)
|
||
|
})
|
||
|
|
||
|
g.It("Should parse delete branch push hook", func() {
|
||
|
actualRepo, actualBuild, err := parsePushHook([]byte(fixtures.DeleteBranchPushHook))
|
||
|
g.Assert(err == nil).IsTrue()
|
||
|
g.Assert(actualRepo == nil).IsTrue()
|
||
|
g.Assert(actualBuild == nil).IsTrue()
|
||
|
})
|
||
|
|
||
|
g.It("Should parse pull request hook", func() {
|
||
|
|
||
|
repo := &model.Repo{
|
||
|
Owner: "demo1",
|
||
|
Name: "test2",
|
||
|
FullName: "demo1/test2",
|
||
|
Link: "https://coding.net/u/demo1/p/test2",
|
||
|
Kind: model.RepoGit,
|
||
|
}
|
||
|
|
||
|
build := &model.Build{
|
||
|
Event: model.EventPull,
|
||
|
Commit: "55e77b328b71d3ee4f9e70a5f67231b0acceeadc",
|
||
|
Link: "https://coding.net/u/demo1/p/test2/git/pull/1",
|
||
|
Ref: "refs/pull/1/MERGE",
|
||
|
Branch: "master",
|
||
|
Message: "pr message",
|
||
|
Author: "demo2",
|
||
|
Avatar: "/static/fruit_avatar/Fruit-2.png",
|
||
|
Title: "pr1",
|
||
|
Remote: "https://git.coding.net/demo1/test2.git",
|
||
|
Refspec: "master:master",
|
||
|
}
|
||
|
|
||
|
actualRepo, actualBuild, err := parsePullRequestHook([]byte(fixtures.PullRequestHook))
|
||
|
g.Assert(err == nil).IsTrue()
|
||
|
g.Assert(actualRepo).Equal(repo)
|
||
|
g.Assert(actualBuild).Equal(build)
|
||
|
})
|
||
|
|
||
|
g.It("Should parse merge request hook", func() {
|
||
|
|
||
|
repo := &model.Repo{
|
||
|
Owner: "demo1",
|
||
|
Name: "test1",
|
||
|
FullName: "demo1/test1",
|
||
|
Link: "https://coding.net/u/demo1/p/test1",
|
||
|
Kind: model.RepoGit,
|
||
|
}
|
||
|
|
||
|
build := &model.Build{
|
||
|
Event: model.EventPull,
|
||
|
Commit: "74e6755580c34e9fd81dbcfcbd43ee5f30259436",
|
||
|
Link: "https://coding.net/u/demo1/p/test1/git/merge/1",
|
||
|
Ref: "refs/merge/1/MERGE",
|
||
|
Branch: "master",
|
||
|
Message: "<p>mr message</p>",
|
||
|
Author: "demo1",
|
||
|
Avatar: "/static/fruit_avatar/Fruit-20.png",
|
||
|
Title: "mr1",
|
||
|
Remote: "https://git.coding.net/demo1/test1.git",
|
||
|
Refspec: "branch1:master",
|
||
|
}
|
||
|
|
||
|
actualRepo, actualBuild, err := parseMergeReuqestHook([]byte(fixtures.MergeRequestHook))
|
||
|
g.Assert(err == nil).IsTrue()
|
||
|
g.Assert(actualRepo).Equal(repo)
|
||
|
g.Assert(actualBuild).Equal(build)
|
||
|
})
|
||
|
|
||
|
})
|
||
|
}
|