You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
boundary/internal/target/immutable_fields_test.go

230 lines
6.2 KiB

package target
import (
"context"
"testing"
"github.com/hashicorp/boundary/internal/db"
"github.com/hashicorp/boundary/internal/db/timestamp"
"github.com/hashicorp/boundary/internal/host/static"
"github.com/hashicorp/boundary/internal/iam"
"github.com/hashicorp/boundary/internal/kms"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"google.golang.org/protobuf/proto"
"google.golang.org/protobuf/types/known/timestamppb"
)
func TestTarget_ImmutableFields(t *testing.T) {
t.Parallel()
conn, _ := db.TestSetup(t, "postgres")
wrapper := db.TestWrapper(t)
rw := db.New(conn)
ts := timestamp.Timestamp{Timestamp: &timestamppb.Timestamp{Seconds: 0, Nanos: 0}}
_, proj := iam.TestScopes(t, iam.TestRepo(t, conn, wrapper))
new := TestTcpTarget(t, conn, proj.PublicId, testId(t))
tests := []struct {
name string
update *TcpTarget
fieldMask []string
}{
{
name: "public_id",
update: func() *TcpTarget {
target := new.Clone().(*TcpTarget)
target.PublicId = "p_thisIsNotAValidId"
return target
}(),
fieldMask: []string{"PublicId"},
},
{
name: "create time",
update: func() *TcpTarget {
target := new.Clone().(*TcpTarget)
target.CreateTime = &ts
return target
}(),
fieldMask: []string{"CreateTime"},
},
{
name: "scope_id",
update: func() *TcpTarget {
target := new.Clone().(*TcpTarget)
target.ScopeId = "o_thisIsNotAValidId"
return target
}(),
fieldMask: []string{"ScopeId"},
},
}
for _, tt := range tests {
tt := tt
t.Run(tt.name, func(t *testing.T) {
assert, require := assert.New(t), require.New(t)
orig := new.Clone()
orig.(*TcpTarget).SetTableName("target")
err := rw.LookupById(context.Background(), orig)
require.NoError(err)
tt.update.SetTableName("target")
rowsUpdated, err := rw.Update(context.Background(), tt.update, tt.fieldMask, nil, db.WithSkipVetForWrite(true))
require.Error(err)
assert.Equal(0, rowsUpdated)
after := new.Clone()
after.(*TcpTarget).SetTableName("target")
err = rw.LookupById(context.Background(), after)
require.NoError(err)
assert.True(proto.Equal(orig.(*TcpTarget), after.(*TcpTarget)))
})
}
}
func TestTcpTarget_ImmutableFields(t *testing.T) {
t.Parallel()
conn, _ := db.TestSetup(t, "postgres")
wrapper := db.TestWrapper(t)
rw := db.New(conn)
ts := timestamp.Timestamp{Timestamp: &timestamppb.Timestamp{Seconds: 0, Nanos: 0}}
_, proj := iam.TestScopes(t, iam.TestRepo(t, conn, wrapper))
new := TestTcpTarget(t, conn, proj.PublicId, testId(t))
tests := []struct {
name string
update *TcpTarget
fieldMask []string
}{
{
name: "public_id",
update: func() *TcpTarget {
target := new.Clone().(*TcpTarget)
target.PublicId = "p_thisIsNotAValidId"
return target
}(),
fieldMask: []string{"PublicId"},
},
{
name: "create time",
update: func() *TcpTarget {
target := new.Clone().(*TcpTarget)
target.CreateTime = &ts
return target
}(),
fieldMask: []string{"CreateTime"},
},
{
name: "scope_id",
update: func() *TcpTarget {
target := new.Clone().(*TcpTarget)
target.ScopeId = "o_thisIsNotAValidId"
return target
}(),
fieldMask: []string{"ScopeId"},
},
}
for _, tt := range tests {
tt := tt
t.Run(tt.name, func(t *testing.T) {
assert, require := assert.New(t), require.New(t)
orig := new.Clone()
err := rw.LookupById(context.Background(), orig)
require.NoError(err)
rowsUpdated, err := rw.Update(context.Background(), tt.update, tt.fieldMask, nil, db.WithSkipVetForWrite(true))
require.Error(err)
assert.Equal(0, rowsUpdated)
after := new.Clone()
err = rw.LookupById(context.Background(), after)
require.NoError(err)
assert.True(proto.Equal(orig.(*TcpTarget), after.(*TcpTarget)))
})
}
}
func TestTargetHostSet_ImmutableFields(t *testing.T) {
t.Parallel()
conn, _ := db.TestSetup(t, "postgres")
wrapper := db.TestWrapper(t)
testKms := kms.TestKms(t, conn, wrapper)
rw := db.New(conn)
repo, err := NewRepository(rw, rw, testKms)
require.NoError(t, err)
ts := timestamp.Timestamp{Timestamp: &timestamppb.Timestamp{Seconds: 0, Nanos: 0}}
_, proj := iam.TestScopes(t, iam.TestRepo(t, conn, wrapper))
projTarget := TestTcpTarget(t, conn, proj.PublicId, testId(t))
testCats := static.TestCatalogs(t, conn, proj.PublicId, 1)
hsets := static.TestSets(t, conn, testCats[0].GetPublicId(), 2)
require.Equal(t, 2, len(hsets))
updateTarget := TestTcpTarget(t, conn, proj.PublicId, testId(t))
updateHset := hsets[1]
_, gotHostSets, err := repo.AddTargetHostSets(context.Background(), projTarget.PublicId, 1, []string{hsets[0].PublicId})
require.NoError(t, err)
require.Equal(t, 1, len(gotHostSets))
new, err := NewTargetHostSet(projTarget.PublicId, gotHostSets[0].PublicId)
require.NoError(t, err)
tests := []struct {
name string
update *TargetHostSet
fieldMask []string
}{
{
name: "target_id",
update: func() *TargetHostSet {
target := new.Clone().(*TargetHostSet)
target.TargetId = updateTarget.PublicId
return target
}(),
fieldMask: []string{"TargetId"},
},
{
name: "create time",
update: func() *TargetHostSet {
target := new.Clone().(*TargetHostSet)
target.CreateTime = &ts
return target
}(),
fieldMask: []string{"CreateTime"},
},
{
name: "host_set_id",
update: func() *TargetHostSet {
target := new.Clone().(*TargetHostSet)
target.HostSetId = updateHset.PublicId
return target
}(),
fieldMask: []string{"HostSetId"},
},
}
for _, tt := range tests {
tt := tt
t.Run(tt.name, func(t *testing.T) {
assert, require := assert.New(t), require.New(t)
orig := new.Clone()
err := rw.LookupWhere(context.Background(), orig, "target_id = ? and host_set_id = ?", new.TargetId, new.HostSetId)
require.NoError(err)
rowsUpdated, err := rw.Update(context.Background(), tt.update, tt.fieldMask, nil, db.WithSkipVetForWrite(true))
require.Error(err)
assert.Equal(0, rowsUpdated)
after := new.Clone()
err = rw.LookupWhere(context.Background(), after, "target_id = ? and host_set_id = ?", new.TargetId, new.HostSetId)
require.NoError(err)
assert.True(proto.Equal(orig.(*TargetHostSet), after.(*TargetHostSet)))
})
}
}