mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-06 07:38:43 +00:00
187 lines
3.4 KiB
Go
187 lines
3.4 KiB
Go
package datastore
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/drone/drone/model"
|
|
)
|
|
|
|
func TestPermFind(t *testing.T) {
|
|
s := newTest()
|
|
defer func() {
|
|
s.Exec("delete from perms")
|
|
s.Exec("delete from repos")
|
|
s.Close()
|
|
}()
|
|
|
|
user := &model.User{ID: 1}
|
|
repo := &model.Repo{
|
|
UserID: 1,
|
|
FullName: "bradrydzewski/drone",
|
|
Owner: "bradrydzewski",
|
|
Name: "drone",
|
|
}
|
|
s.CreateRepo(repo)
|
|
|
|
err := s.PermUpsert(
|
|
&model.Perm{
|
|
UserID: user.ID,
|
|
RepoID: repo.ID,
|
|
Repo: repo.FullName,
|
|
Pull: true,
|
|
Push: false,
|
|
Admin: false,
|
|
},
|
|
)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
|
|
perm, err := s.PermFind(user, repo)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
if got, want := perm.Pull, true; got != want {
|
|
t.Errorf("Wanted pull %v, got %v", want, got)
|
|
}
|
|
if got, want := perm.Push, false; got != want {
|
|
t.Errorf("Wanted push %v, got %v", want, got)
|
|
}
|
|
if got, want := perm.Admin, false; got != want {
|
|
t.Errorf("Wanted admin %v, got %v", want, got)
|
|
}
|
|
}
|
|
|
|
func TestPermUpsert(t *testing.T) {
|
|
s := newTest()
|
|
defer func() {
|
|
s.Exec("delete from perms")
|
|
s.Exec("delete from repos")
|
|
s.Close()
|
|
}()
|
|
|
|
user := &model.User{ID: 1}
|
|
repo := &model.Repo{
|
|
UserID: 1,
|
|
FullName: "bradrydzewski/drone",
|
|
Owner: "bradrydzewski",
|
|
Name: "drone",
|
|
}
|
|
s.CreateRepo(repo)
|
|
|
|
err := s.PermUpsert(
|
|
&model.Perm{
|
|
UserID: user.ID,
|
|
RepoID: repo.ID,
|
|
Repo: repo.FullName,
|
|
Pull: true,
|
|
Push: false,
|
|
Admin: false,
|
|
},
|
|
)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
|
|
perm, err := s.PermFind(user, repo)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
if got, want := perm.Pull, true; got != want {
|
|
t.Errorf("Wanted pull %v, got %v", want, got)
|
|
}
|
|
if got, want := perm.Push, false; got != want {
|
|
t.Errorf("Wanted push %v, got %v", want, got)
|
|
}
|
|
if got, want := perm.Admin, false; got != want {
|
|
t.Errorf("Wanted admin %v, got %v", want, got)
|
|
}
|
|
|
|
//
|
|
// this will attempt to replace the existing permissions
|
|
// using the insert or replace logic.
|
|
//
|
|
|
|
err = s.PermUpsert(
|
|
&model.Perm{
|
|
UserID: user.ID,
|
|
RepoID: repo.ID,
|
|
Repo: repo.FullName,
|
|
Pull: true,
|
|
Push: true,
|
|
Admin: true,
|
|
},
|
|
)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
|
|
perm, err = s.PermFind(user, repo)
|
|
if err != nil {
|
|
t.Error(err)
|
|
return
|
|
}
|
|
if got, want := perm.Pull, true; got != want {
|
|
t.Errorf("Wanted pull %v, got %v", want, got)
|
|
}
|
|
if got, want := perm.Push, true; got != want {
|
|
t.Errorf("Wanted push %v, got %v", want, got)
|
|
}
|
|
if got, want := perm.Admin, true; got != want {
|
|
t.Errorf("Wanted admin %v, got %v", want, got)
|
|
}
|
|
}
|
|
|
|
func TestPermDelete(t *testing.T) {
|
|
s := newTest()
|
|
defer func() {
|
|
s.Exec("delete from perms")
|
|
s.Exec("delete from repos")
|
|
s.Close()
|
|
}()
|
|
|
|
user := &model.User{ID: 1}
|
|
repo := &model.Repo{
|
|
UserID: 1,
|
|
FullName: "bradrydzewski/drone",
|
|
Owner: "bradrydzewski",
|
|
Name: "drone",
|
|
}
|
|
s.CreateRepo(repo)
|
|
|
|
err := s.PermUpsert(
|
|
&model.Perm{
|
|
UserID: user.ID,
|
|
RepoID: repo.ID,
|
|
Repo: repo.FullName,
|
|
Pull: true,
|
|
Push: false,
|
|
Admin: false,
|
|
},
|
|
)
|
|
if err != nil {
|
|
t.Errorf("Unexpected error: insert perm: %s", err)
|
|
return
|
|
}
|
|
|
|
perm, err := s.PermFind(user, repo)
|
|
if err != nil {
|
|
t.Errorf("Unexpected error: select perm: %s", err)
|
|
return
|
|
}
|
|
err = s.PermDelete(perm)
|
|
if err != nil {
|
|
t.Errorf("Unexpected error: delete perm: %s", err)
|
|
return
|
|
}
|
|
_, err = s.PermFind(user, repo)
|
|
if err == nil {
|
|
t.Errorf("Expect error: sql.ErrNoRows")
|
|
return
|
|
}
|
|
}
|