aboutsummaryrefslogtreecommitdiff
path: root/internal/db/mirror_test.go
diff options
context:
space:
mode:
authorᴜɴᴋɴᴡᴏɴ <u@gogs.io>2020-03-08 19:09:31 +0800
committerGitHub <noreply@github.com>2020-03-08 19:09:31 +0800
commit6437d0180b97a26319b50c2e22927dac7c94fcdd (patch)
tree3d0d097e7f498e4b970065096e7500876d365a8b /internal/db/mirror_test.go
parentc65b5b9f84dee21dc362311b299694e8e00f6ac6 (diff)
git: migrate to github.com/gogs/git-module@v1.0.0 (#5958)
* WIP * Finish `internal/db/git_diff.go` * FInish internal/db/mirror.go * Finish internal/db/pull.go * Finish internal/db/release.go * Finish internal/db/repo.go * Finish internal/db/repo_branch.go * Finish internal/db/repo_editor.go * Finish internal/db/update.go * Save my work * Add license header * Compile! * Merge master * Finish internal/cmd/hook.go * Finish internal/conf/static.go * Finish internal/context/repo.go * Finish internal/db/action.go * Finish internal/db/git_diff.go * Fix submodule URL inferring * Finish internal/db/mirror.go * Updat to beta.4 * css: update fonts * Finish internal/db/pull.go * Finish internal/db/release.go * Finish internal/db/repo_branch.go * Finish internal/db/wiki.go * gitutil: enhance infer submodule UR * Finish internal/route/api/v1/repo/commits.go * mirror: only collect branch commits after sync * mirror: fix tag support * Finish internal/db/repo.go * Finish internal/db/repo_editor.go * Finish internal/db/update.go * Finish internal/gitutil/pull_request.go * Make it compile * Finish internal/route/repo/setting.go * Finish internal/route/repo/branch.go * Finish internal/route/api/v1/repo/file.go * Finish internal/route/repo/download.go * Finish internal/route/repo/editor.go * Use helper * Finish internal/route/repo/issue.go * Finish internal/route/repo/pull.go * Finish internal/route/repo/release.go * Finish internal/route/repo/repo.go * Finish internal/route/repo/wiki.go * Finish internal/route/repo/commit.go * Finish internal/route/repo/view.go * Finish internal/gitutil/tag.go * go.sum
Diffstat (limited to 'internal/db/mirror_test.go')
-rw-r--r--internal/db/mirror_test.go107
1 files changed, 18 insertions, 89 deletions
diff --git a/internal/db/mirror_test.go b/internal/db/mirror_test.go
index cc85546a..74f1d936 100644
--- a/internal/db/mirror_test.go
+++ b/internal/db/mirror_test.go
@@ -7,102 +7,31 @@ package db
import (
"testing"
- . "github.com/smartystreets/goconvey/convey"
+ "github.com/stretchr/testify/assert"
)
func Test_parseRemoteUpdateOutput(t *testing.T) {
- Convey("Parse mirror remote update output", t, func() {
- testCases := []struct {
- output string
- results []*mirrorSyncResult
- }{
- {
- `
+ tests := []struct {
+ output string
+ expResults []*mirrorSyncResult
+ }{
+ {
+ `
From https://try.gogs.io/unknwon/upsteam
* [new branch] develop -> develop
b0bb24f..1d85a4f master -> master
- [deleted] (none) -> bugfix
`,
- []*mirrorSyncResult{
- {"develop", GIT_SHORT_EMPTY_SHA, ""},
- {"master", "b0bb24f", "1d85a4f"},
- {"bugfix", "", GIT_SHORT_EMPTY_SHA},
- },
+ []*mirrorSyncResult{
+ {"develop", gitShortEmptyID, ""},
+ {"master", "b0bb24f", "1d85a4f"},
+ {"bugfix", "", gitShortEmptyID},
},
- }
-
- for _, tc := range testCases {
- results := parseRemoteUpdateOutput(tc.output)
- So(len(results), ShouldEqual, len(tc.results))
-
- for i := range tc.results {
- So(tc.results[i].refName, ShouldEqual, results[i].refName)
- So(tc.results[i].oldCommitID, ShouldEqual, results[i].oldCommitID)
- So(tc.results[i].newCommitID, ShouldEqual, results[i].newCommitID)
- }
- }
- })
-}
-
-func Test_findPasswordInMirrorAddress(t *testing.T) {
- Convey("Find password portion in mirror address", t, func() {
- testCases := []struct {
- addr string
- start, end int
- found bool
- password string
- }{
- {"http://localhost:3000/user/repo.git", -1, -1, false, ""},
- {"http://user@localhost:3000/user/repo.git", -1, -1, false, ""},
- {"http://user:@localhost:3000/user/repo.git", -1, -1, false, ""},
- {"http://user:password@localhost:3000/user/repo.git", 12, 20, true, "password"},
- {"http://username:my%3Asecure%3Bpassword@localhost:3000/user/repo.git", 16, 38, true, "my%3Asecure%3Bpassword"},
- {"http://username:my%40secure%23password@localhost:3000/user/repo.git", 16, 38, true, "my%40secure%23password"},
- {"http://username:@@localhost:3000/user/repo.git", 16, 17, true, "@"},
- }
-
- for _, tc := range testCases {
- start, end, found := findPasswordInMirrorAddress(tc.addr)
- So(start, ShouldEqual, tc.start)
- So(end, ShouldEqual, tc.end)
- So(found, ShouldEqual, tc.found)
- if found {
- So(tc.addr[start:end], ShouldEqual, tc.password)
- }
- }
- })
-}
-
-func Test_unescapeMirrorCredentials(t *testing.T) {
- Convey("Escape credentials in mirror address", t, func() {
- testCases := []string{
- "http://localhost:3000/user/repo.git", "http://localhost:3000/user/repo.git",
- "http://user@localhost:3000/user/repo.git", "http://user@localhost:3000/user/repo.git",
- "http://user:@localhost:3000/user/repo.git", "http://user:@localhost:3000/user/repo.git",
- "http://user:password@localhost:3000/user/repo.git", "http://user:password@localhost:3000/user/repo.git",
- "http://user:my%3Asecure%3Bpassword@localhost:3000/user/repo.git", "http://user:my:secure;password@localhost:3000/user/repo.git",
- "http://user:my%40secure%23password@localhost:3000/user/repo.git", "http://user:my@secure#password@localhost:3000/user/repo.git",
- }
-
- for i := 0; i < len(testCases); i += 2 {
- So(unescapeMirrorCredentials(testCases[i]), ShouldEqual, testCases[i+1])
- }
- })
-}
-
-func Test_escapeMirrorCredentials(t *testing.T) {
- Convey("Escape credentials in mirror address", t, func() {
- testCases := []string{
- "http://localhost:3000/user/repo.git", "http://localhost:3000/user/repo.git",
- "http://user@localhost:3000/user/repo.git", "http://user@localhost:3000/user/repo.git",
- "http://user:@localhost:3000/user/repo.git", "http://user:@localhost:3000/user/repo.git",
- "http://user:password@localhost:3000/user/repo.git", "http://user:password@localhost:3000/user/repo.git",
- "http://user:my:secure;password@localhost:3000/user/repo.git", "http://user:my%3Asecure%3Bpassword@localhost:3000/user/repo.git",
- "http://user:my@secure#password@localhost:3000/user/repo.git", "http://user:my%40secure%23password@localhost:3000/user/repo.git",
- }
-
- for i := 0; i < len(testCases); i += 2 {
- So(escapeMirrorCredentials(testCases[i]), ShouldEqual, testCases[i+1])
- }
- })
+ },
+ }
+ for _, test := range tests {
+ t.Run("", func(t *testing.T) {
+ assert.Equal(t, test.expResults, parseRemoteUpdateOutput(test.output))
+ })
+ }
}