signoz/pkg/sqlschema/constraint_test.go

73 lines
1.7 KiB
Go
Raw Permalink Normal View History

package sqlschema
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/uptrace/bun/schema"
)
func TestPrimaryKeyConstraintToDefinitionSQL(t *testing.T) {
testCases := []struct {
name string
tableName TableName
constraint *PrimaryKeyConstraint
sql string
}{
{
name: "SingleColumn",
tableName: "test",
constraint: &PrimaryKeyConstraint{
ColumnNames: []ColumnName{"id"},
},
sql: `CONSTRAINT "pk_test" PRIMARY KEY ("id")`,
},
{
name: "MultipleColumns",
tableName: "test",
constraint: &PrimaryKeyConstraint{
ColumnNames: []ColumnName{"id", "name"},
},
sql: `CONSTRAINT "pk_test" PRIMARY KEY ("id", "name")`,
},
}
for _, testCase := range testCases {
t.Run(testCase.name, func(t *testing.T) {
fmter := Formatter{schema.NewNopFormatter()}
sql := testCase.constraint.ToDefinitionSQL(fmter, testCase.tableName)
assert.Equal(t, testCase.sql, string(sql))
})
}
}
func TestForeignKeyConstraintToDefinitionSQL(t *testing.T) {
testCases := []struct {
name string
tableName TableName
constraint *ForeignKeyConstraint
sql string
}{
{
name: "NoCascade",
tableName: "test",
constraint: &ForeignKeyConstraint{
ReferencingColumnName: "id",
ReferencedTableName: "test_referenced",
ReferencedColumnName: "id",
},
sql: `CONSTRAINT "fk_test_id" FOREIGN KEY ("id") REFERENCES "test_referenced" ("id")`,
},
}
for _, testCase := range testCases {
t.Run(testCase.name, func(t *testing.T) {
fmter := Formatter{schema.NewNopFormatter()}
sql := testCase.constraint.ToDefinitionSQL(fmter, testCase.tableName)
assert.Equal(t, testCase.sql, string(sql))
})
}
}