signoz/pkg/sqlschema/constraint_test.go
Vibhu Pandey c9e48b6de9
feat(sqlschema): add sqlschema (#8384)
## 📄 Summary

- add sqlschema package
- add unique index on email,org_id in users and user_invite
2025-07-08 00:21:26 +05:30

73 lines
1.7 KiB
Go

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