gin/authz_test.go
2017-05-28 11:47:42 +08:00

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)
}