aboutsummaryrefslogtreecommitdiff
path: root/models/mirror_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'models/mirror_test.go')
-rw-r--r--models/mirror_test.go46
1 files changed, 46 insertions, 0 deletions
diff --git a/models/mirror_test.go b/models/mirror_test.go
index 6b23df1c..b4af58ba 100644
--- a/models/mirror_test.go
+++ b/models/mirror_test.go
@@ -10,6 +10,52 @@ import (
. "github.com/smartystreets/goconvey/convey"
)
+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{