diff options
author | ᴜɴᴋɴᴡᴏɴ <u@gogs.io> | 2020-03-08 19:09:31 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-08 19:09:31 +0800 |
commit | 6437d0180b97a26319b50c2e22927dac7c94fcdd (patch) | |
tree | 3d0d097e7f498e4b970065096e7500876d365a8b /internal/db/mirror_test.go | |
parent | c65b5b9f84dee21dc362311b299694e8e00f6ac6 (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.go | 107 |
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)) + }) + } } |