mirror of
https://github.com/gin-gonic/gin.git
synced 2026-01-11 17:17:04 +08:00
102 lines
3.8 KiB
Go
102 lines
3.8 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 (
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"testing"
|
|
|
|
"github.com/casbin/casbin"
|
|
)
|
|
|
|
func testAuthzRequest(t *testing.T, router *Engine, user string, path string, method string, code int) {
|
|
r, _ := http.NewRequest(method, path, nil)
|
|
r.SetBasicAuth(user, "123")
|
|
w := httptest.NewRecorder()
|
|
router.ServeHTTP(w, r)
|
|
|
|
if w.Code != code {
|
|
t.Errorf("%s, %s, %s: %d, supposed to be %d", user, path, method, w.Code, code)
|
|
}
|
|
}
|
|
|
|
func TestBasic(t *testing.T) {
|
|
router := New()
|
|
router.Use(NewAuthorizer(casbin.NewEnforcer("authz_model.conf", "authz_policy.csv")))
|
|
router.Any("/dataset1/resource1", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
router.Any("/dataset1/resource2", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
|
|
testAuthzRequest(t, router, "alice", "/dataset1/resource1", "GET", 200)
|
|
testAuthzRequest(t, router, "alice", "/dataset1/resource1", "POST", 200)
|
|
testAuthzRequest(t, router, "alice", "/dataset1/resource2", "GET", 200)
|
|
testAuthzRequest(t, router, "alice", "/dataset1/resource2", "POST", 403)
|
|
}
|
|
|
|
func TestPathWildcard(t *testing.T) {
|
|
router := New()
|
|
router.Use(NewAuthorizer(casbin.NewEnforcer("authz_model.conf", "authz_policy.csv")))
|
|
router.Any("/dataset2/resource1", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
router.Any("/dataset2/resource2", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
router.Any("/dataset2/folder1/item1", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
router.Any("/dataset2/folder1/item2", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
|
|
testAuthzRequest(t, router, "bob", "/dataset2/resource1", "GET", 200)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/resource1", "POST", 200)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/resource1", "DELETE", 200)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/resource2", "GET", 200)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/resource2", "POST", 403)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/resource2", "DELETE", 403)
|
|
|
|
testAuthzRequest(t, router, "bob", "/dataset2/folder1/item1", "GET", 403)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/folder1/item1", "POST", 200)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/folder1/item1", "DELETE", 403)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/folder1/item2", "GET", 403)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/folder1/item2", "POST", 200)
|
|
testAuthzRequest(t, router, "bob", "/dataset2/folder1/item2", "DELETE", 403)
|
|
}
|
|
|
|
func TestRBAC(t *testing.T) {
|
|
router := New()
|
|
e := casbin.NewEnforcer("authz_model.conf", "authz_policy.csv")
|
|
router.Use(NewAuthorizer(e))
|
|
router.Any("/dataset1/item", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
router.Any("/dataset2/item", func(c *Context) {
|
|
c.Status(200)
|
|
})
|
|
|
|
// cathy can access all /dataset1/* resources via all methods because it has the dataset1_admin role.
|
|
testAuthzRequest(t, router, "cathy", "/dataset1/item", "GET", 200)
|
|
testAuthzRequest(t, router, "cathy", "/dataset1/item", "POST", 200)
|
|
testAuthzRequest(t, router, "cathy", "/dataset1/item", "DELETE", 200)
|
|
testAuthzRequest(t, router, "cathy", "/dataset2/item", "GET", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset2/item", "POST", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset2/item", "DELETE", 403)
|
|
|
|
// delete all roles on user cathy, so cathy cannot access any resources now.
|
|
e.DeleteRolesForUser("cathy")
|
|
|
|
testAuthzRequest(t, router, "cathy", "/dataset1/item", "GET", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset1/item", "POST", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset1/item", "DELETE", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset2/item", "GET", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset2/item", "POST", 403)
|
|
testAuthzRequest(t, router, "cathy", "/dataset2/item", "DELETE", 403)
|
|
}
|