mirror of
				https://github.com/gin-gonic/gin.git
				synced 2025-11-04 09:12:12 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			177 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			177 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// 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, "admin", user)
 | 
						|
	assert.True(t, found)
 | 
						|
 | 
						|
	user, found = pairs.searchCredential(authorizationHeader("foo", "bar"))
 | 
						|
	assert.Equal(t, "foo", user)
 | 
						|
	assert.True(t, found)
 | 
						|
 | 
						|
	user, found = pairs.searchCredential(authorizationHeader("bar", "foo"))
 | 
						|
	assert.Equal(t, "bar", user)
 | 
						|
	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, "Basic YWRtaW46cGFzc3dvcmQ=", authorizationHeader("admin", "password"))
 | 
						|
}
 | 
						|
 | 
						|
func TestBasicAuthSucceed(t *testing.T) {
 | 
						|
	accounts := Accounts{"admin": "password"}
 | 
						|
	router := New()
 | 
						|
	router.Use(BasicAuth(accounts))
 | 
						|
	router.GET("/login", func(c *Context) {
 | 
						|
		c.String(http.StatusOK, c.MustGet(AuthUserKey).(string))
 | 
						|
	})
 | 
						|
 | 
						|
	w := httptest.NewRecorder()
 | 
						|
	req, _ := http.NewRequest(http.MethodGet, "/login", nil)
 | 
						|
	req.Header.Set("Authorization", authorizationHeader("admin", "password"))
 | 
						|
	router.ServeHTTP(w, req)
 | 
						|
 | 
						|
	assert.Equal(t, http.StatusOK, w.Code)
 | 
						|
	assert.Equal(t, "admin", w.Body.String())
 | 
						|
}
 | 
						|
 | 
						|
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(http.StatusOK, c.MustGet(AuthUserKey).(string))
 | 
						|
	})
 | 
						|
 | 
						|
	w := httptest.NewRecorder()
 | 
						|
	req, _ := http.NewRequest(http.MethodGet, "/login", nil)
 | 
						|
	req.Header.Set("Authorization", "Basic "+base64.StdEncoding.EncodeToString([]byte("admin:password")))
 | 
						|
	router.ServeHTTP(w, req)
 | 
						|
 | 
						|
	assert.False(t, called)
 | 
						|
	assert.Equal(t, http.StatusUnauthorized, w.Code)
 | 
						|
	assert.Equal(t, "Basic realm=\"Authorization Required\"", w.Header().Get("WWW-Authenticate"))
 | 
						|
}
 | 
						|
 | 
						|
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(http.StatusOK, c.MustGet(AuthUserKey).(string))
 | 
						|
	})
 | 
						|
 | 
						|
	w := httptest.NewRecorder()
 | 
						|
	req, _ := http.NewRequest(http.MethodGet, "/login", nil)
 | 
						|
	req.Header.Set("Authorization", "Basic "+base64.StdEncoding.EncodeToString([]byte("admin:password")))
 | 
						|
	router.ServeHTTP(w, req)
 | 
						|
 | 
						|
	assert.False(t, called)
 | 
						|
	assert.Equal(t, http.StatusUnauthorized, w.Code)
 | 
						|
	assert.Equal(t, "Basic realm=\"My Custom \\\"Realm\\\"\"", w.Header().Get("WWW-Authenticate"))
 | 
						|
}
 | 
						|
 | 
						|
func TestBasicAuthForProxySucceed(t *testing.T) {
 | 
						|
	accounts := Accounts{"admin": "password"}
 | 
						|
	router := New()
 | 
						|
	router.Use(BasicAuthForProxy(accounts, ""))
 | 
						|
	router.Any("/*proxyPath", func(c *Context) {
 | 
						|
		c.String(http.StatusOK, c.MustGet(AuthProxyUserKey).(string))
 | 
						|
	})
 | 
						|
 | 
						|
	w := httptest.NewRecorder()
 | 
						|
	req, _ := http.NewRequest(http.MethodGet, "/test", nil)
 | 
						|
	req.Header.Set("Proxy-Authorization", authorizationHeader("admin", "password"))
 | 
						|
	router.ServeHTTP(w, req)
 | 
						|
 | 
						|
	assert.Equal(t, http.StatusOK, w.Code)
 | 
						|
	assert.Equal(t, "admin", w.Body.String())
 | 
						|
}
 | 
						|
 | 
						|
func TestBasicAuthForProxy407(t *testing.T) {
 | 
						|
	called := false
 | 
						|
	accounts := Accounts{"foo": "bar"}
 | 
						|
	router := New()
 | 
						|
	router.Use(BasicAuthForProxy(accounts, ""))
 | 
						|
	router.Any("/*proxyPath", func(c *Context) {
 | 
						|
		called = true
 | 
						|
		c.String(http.StatusOK, c.MustGet(AuthProxyUserKey).(string))
 | 
						|
	})
 | 
						|
 | 
						|
	w := httptest.NewRecorder()
 | 
						|
	req, _ := http.NewRequest(http.MethodGet, "/test", nil)
 | 
						|
	req.Header.Set("Proxy-Authorization", "Basic "+base64.StdEncoding.EncodeToString([]byte("admin:password")))
 | 
						|
	router.ServeHTTP(w, req)
 | 
						|
 | 
						|
	assert.False(t, called)
 | 
						|
	assert.Equal(t, http.StatusProxyAuthRequired, w.Code)
 | 
						|
	assert.Equal(t, "Basic realm=\"Proxy Authorization Required\"", w.Header().Get("Proxy-Authenticate"))
 | 
						|
}
 |