replace zxq.co/ripple/hanayo
This commit is contained in:
		
							
								
								
									
										146
									
								
								vendor/github.com/gin-gonic/gin/auth_test.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								vendor/github.com/gin-gonic/gin/auth_test.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| // Copyright 2014 Manu Martinez-Almeida.  All rights reserved. | ||||
| // Use of this source code is governed by a MIT style | ||||
| // license that can be found in the LICENSE file. | ||||
|  | ||||
| package gin | ||||
|  | ||||
| import ( | ||||
| 	"encoding/base64" | ||||
| 	"net/http" | ||||
| 	"net/http/httptest" | ||||
| 	"testing" | ||||
|  | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
|  | ||||
| func TestBasicAuth(t *testing.T) { | ||||
| 	pairs := processAccounts(Accounts{ | ||||
| 		"admin": "password", | ||||
| 		"foo":   "bar", | ||||
| 		"bar":   "foo", | ||||
| 	}) | ||||
|  | ||||
| 	assert.Len(t, pairs, 3) | ||||
| 	assert.Contains(t, pairs, authPair{ | ||||
| 		User:  "bar", | ||||
| 		Value: "Basic YmFyOmZvbw==", | ||||
| 	}) | ||||
| 	assert.Contains(t, pairs, authPair{ | ||||
| 		User:  "foo", | ||||
| 		Value: "Basic Zm9vOmJhcg==", | ||||
| 	}) | ||||
| 	assert.Contains(t, pairs, authPair{ | ||||
| 		User:  "admin", | ||||
| 		Value: "Basic YWRtaW46cGFzc3dvcmQ=", | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func TestBasicAuthFails(t *testing.T) { | ||||
| 	assert.Panics(t, func() { processAccounts(nil) }) | ||||
| 	assert.Panics(t, func() { | ||||
| 		processAccounts(Accounts{ | ||||
| 			"":    "password", | ||||
| 			"foo": "bar", | ||||
| 		}) | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| func TestBasicAuthSearchCredential(t *testing.T) { | ||||
| 	pairs := processAccounts(Accounts{ | ||||
| 		"admin": "password", | ||||
| 		"foo":   "bar", | ||||
| 		"bar":   "foo", | ||||
| 	}) | ||||
|  | ||||
| 	user, found := pairs.searchCredential(authorizationHeader("admin", "password")) | ||||
| 	assert.Equal(t, user, "admin") | ||||
| 	assert.True(t, found) | ||||
|  | ||||
| 	user, found = pairs.searchCredential(authorizationHeader("foo", "bar")) | ||||
| 	assert.Equal(t, user, "foo") | ||||
| 	assert.True(t, found) | ||||
|  | ||||
| 	user, found = pairs.searchCredential(authorizationHeader("bar", "foo")) | ||||
| 	assert.Equal(t, user, "bar") | ||||
| 	assert.True(t, found) | ||||
|  | ||||
| 	user, found = pairs.searchCredential(authorizationHeader("admins", "password")) | ||||
| 	assert.Empty(t, user) | ||||
| 	assert.False(t, found) | ||||
|  | ||||
| 	user, found = pairs.searchCredential(authorizationHeader("foo", "bar ")) | ||||
| 	assert.Empty(t, user) | ||||
| 	assert.False(t, found) | ||||
|  | ||||
| 	user, found = pairs.searchCredential("") | ||||
| 	assert.Empty(t, user) | ||||
| 	assert.False(t, found) | ||||
| } | ||||
|  | ||||
| func TestBasicAuthAuthorizationHeader(t *testing.T) { | ||||
| 	assert.Equal(t, authorizationHeader("admin", "password"), "Basic YWRtaW46cGFzc3dvcmQ=") | ||||
| } | ||||
|  | ||||
| func TestBasicAuthSecureCompare(t *testing.T) { | ||||
| 	assert.True(t, secureCompare("1234567890", "1234567890")) | ||||
| 	assert.False(t, secureCompare("123456789", "1234567890")) | ||||
| 	assert.False(t, secureCompare("12345678900", "1234567890")) | ||||
| 	assert.False(t, secureCompare("1234567891", "1234567890")) | ||||
| } | ||||
|  | ||||
| func TestBasicAuthSucceed(t *testing.T) { | ||||
| 	accounts := Accounts{"admin": "password"} | ||||
| 	router := New() | ||||
| 	router.Use(BasicAuth(accounts)) | ||||
| 	router.GET("/login", func(c *Context) { | ||||
| 		c.String(200, c.MustGet(AuthUserKey).(string)) | ||||
| 	}) | ||||
|  | ||||
| 	w := httptest.NewRecorder() | ||||
| 	req, _ := http.NewRequest("GET", "/login", nil) | ||||
| 	req.Header.Set("Authorization", authorizationHeader("admin", "password")) | ||||
| 	router.ServeHTTP(w, req) | ||||
|  | ||||
| 	assert.Equal(t, w.Code, 200) | ||||
| 	assert.Equal(t, w.Body.String(), "admin") | ||||
| } | ||||
|  | ||||
| func TestBasicAuth401(t *testing.T) { | ||||
| 	called := false | ||||
| 	accounts := Accounts{"foo": "bar"} | ||||
| 	router := New() | ||||
| 	router.Use(BasicAuth(accounts)) | ||||
| 	router.GET("/login", func(c *Context) { | ||||
| 		called = true | ||||
| 		c.String(200, c.MustGet(AuthUserKey).(string)) | ||||
| 	}) | ||||
|  | ||||
| 	w := httptest.NewRecorder() | ||||
| 	req, _ := http.NewRequest("GET", "/login", nil) | ||||
| 	req.Header.Set("Authorization", "Basic "+base64.StdEncoding.EncodeToString([]byte("admin:password"))) | ||||
| 	router.ServeHTTP(w, req) | ||||
|  | ||||
| 	assert.False(t, called) | ||||
| 	assert.Equal(t, w.Code, 401) | ||||
| 	assert.Equal(t, w.HeaderMap.Get("WWW-Authenticate"), "Basic realm=\"Authorization Required\"") | ||||
| } | ||||
|  | ||||
| func TestBasicAuth401WithCustomRealm(t *testing.T) { | ||||
| 	called := false | ||||
| 	accounts := Accounts{"foo": "bar"} | ||||
| 	router := New() | ||||
| 	router.Use(BasicAuthForRealm(accounts, "My Custom \"Realm\"")) | ||||
| 	router.GET("/login", func(c *Context) { | ||||
| 		called = true | ||||
| 		c.String(200, c.MustGet(AuthUserKey).(string)) | ||||
| 	}) | ||||
|  | ||||
| 	w := httptest.NewRecorder() | ||||
| 	req, _ := http.NewRequest("GET", "/login", nil) | ||||
| 	req.Header.Set("Authorization", "Basic "+base64.StdEncoding.EncodeToString([]byte("admin:password"))) | ||||
| 	router.ServeHTTP(w, req) | ||||
|  | ||||
| 	assert.False(t, called) | ||||
| 	assert.Equal(t, w.Code, 401) | ||||
| 	assert.Equal(t, w.HeaderMap.Get("WWW-Authenticate"), "Basic realm=\"My Custom \\\"Realm\\\"\"") | ||||
| } | ||||
		Reference in New Issue
	
	Block a user