Merge pull request #129 from sgotti/configstore_disable_root_projectgroup_deletion
configstore: disable root project group deletion
This commit is contained in:
commit
b6d038d5da
|
@ -292,6 +292,12 @@ func (h *ActionHandler) DeleteProjectGroup(ctx context.Context, projectGroupRef
|
||||||
return util.NewErrBadRequest(errors.Errorf("project group %q doesn't exist", projectGroupRef))
|
return util.NewErrBadRequest(errors.Errorf("project group %q doesn't exist", projectGroupRef))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// cannot delete root project group
|
||||||
|
if projectGroup.Parent.Type == types.ConfigTypeOrg ||
|
||||||
|
projectGroup.Parent.Type == types.ConfigTypeUser {
|
||||||
|
return util.NewErrBadRequest(errors.Errorf("cannot delete root project group"))
|
||||||
|
}
|
||||||
|
|
||||||
// changegroup is the project group id.
|
// changegroup is the project group id.
|
||||||
cgNames := []string{util.EncodeSha256Hex(projectGroup.ID)}
|
cgNames := []string{util.EncodeSha256Hex(projectGroup.ID)}
|
||||||
cgt, err = h.readDB.GetChangeGroupsUpdateTokens(tx, cgNames)
|
cgt, err = h.readDB.GetChangeGroupsUpdateTokens(tx, cgNames)
|
||||||
|
|
|
@ -851,10 +851,62 @@ func TestProjectGroupDelete(t *testing.T) {
|
||||||
// TODO(sgotti) change the sleep with a real check that all is ready
|
// TODO(sgotti) change the sleep with a real check that all is ready
|
||||||
time.Sleep(2 * time.Second)
|
time.Sleep(2 * time.Second)
|
||||||
|
|
||||||
//user, err := cs.ah.CreateUser(ctx, &action.CreateUserRequest{UserName: "user01"})
|
org, err := cs.ah.CreateOrg(ctx, &types.Organization{Name: "org01", Visibility: types.VisibilityPublic})
|
||||||
//if err != nil {
|
if err != nil {
|
||||||
// t.Fatalf("unexpected err: %v", err)
|
t.Fatalf("unexpected err: %v", err)
|
||||||
//}
|
}
|
||||||
|
|
||||||
|
// TODO(sgotti) change the sleep with a real check that user is in readdb
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
|
||||||
|
// create a projectgroup in org root project group
|
||||||
|
pg01, err := cs.ah.CreateProjectGroup(ctx, &types.ProjectGroup{Name: "projectgroup01", Parent: types.Parent{Type: types.ConfigTypeProjectGroup, ID: path.Join("org", org.Name)}, Visibility: types.VisibilityPublic})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// create a child projectgroup in org root project group
|
||||||
|
_, err = cs.ah.CreateProjectGroup(ctx, &types.ProjectGroup{Name: "subprojectgroup01", Parent: types.Parent{Type: types.ConfigTypeProjectGroup, ID: pg01.ID}, Visibility: types.VisibilityPublic})
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
t.Run("delete root project group", func(t *testing.T) {
|
||||||
|
expectedErr := "cannot delete root project group"
|
||||||
|
err := cs.ah.DeleteProjectGroup(ctx, path.Join("org", org.Name))
|
||||||
|
if err.Error() != expectedErr {
|
||||||
|
t.Fatalf("expected err %v, got err: %v", expectedErr, err)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("delete project group", func(t *testing.T) {
|
||||||
|
err := cs.ah.DeleteProjectGroup(ctx, pg01.ID)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected err: %v", err)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestProjectGroupDeleteDontSeeOldChildObjects(t *testing.T) {
|
||||||
|
dir, err := ioutil.TempDir("", "agola")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected err: %v", err)
|
||||||
|
}
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
|
ctx := context.Background()
|
||||||
|
|
||||||
|
cs, tetcd := setupConfigstore(ctx, t, dir)
|
||||||
|
defer shutdownEtcd(tetcd)
|
||||||
|
|
||||||
|
t.Logf("starting cs")
|
||||||
|
go func() {
|
||||||
|
_ = cs.Run(ctx)
|
||||||
|
}()
|
||||||
|
|
||||||
|
// TODO(sgotti) change the sleep with a real check that all is ready
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
|
||||||
org, err := cs.ah.CreateOrg(ctx, &types.Organization{Name: "org01", Visibility: types.VisibilityPublic})
|
org, err := cs.ah.CreateOrg(ctx, &types.Organization{Name: "org01", Visibility: types.VisibilityPublic})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unexpected err: %v", err)
|
t.Fatalf("unexpected err: %v", err)
|
||||||
|
@ -892,7 +944,7 @@ func TestProjectGroupDelete(t *testing.T) {
|
||||||
t.Fatalf("unexpected err: %v", err)
|
t.Fatalf("unexpected err: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// delete root projectgroup
|
// delete projectgroup
|
||||||
if err = cs.ah.DeleteProjectGroup(ctx, pg01.ID); err != nil {
|
if err = cs.ah.DeleteProjectGroup(ctx, pg01.ID); err != nil {
|
||||||
t.Fatalf("unexpected err: %v", err)
|
t.Fatalf("unexpected err: %v", err)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue