mirror of
https://github.com/zitadel/zitadel.git
synced 2025-12-29 14:59:48 +00:00
* Abstracting the `OrganizationRepository` in `CommandOpts` to allow for mock implementations during testing. * Generating mocks for `OrganizationRepository` and `OrganizationDomainRepository` using `mockgen`. * Updating the `UpdateOrgCommand` tests to use the new mock repositories, which simplifies the test setup and removes the need for `dbmock`. * Enhancing the `database.Change`, `database.Column`, and `database.Condition` interfaces to implement `gomock.Matcher`, enabling more effective use of gomock for matching database operations in tests. * Introducing a `noopdb` package that provides a no-operation database client for testing purposes.
220 lines
4.8 KiB
Go
220 lines
4.8 KiB
Go
package database
|
|
|
|
import "go.uber.org/mock/gomock"
|
|
|
|
// Condition represents a SQL condition.
|
|
// Its written after the WHERE keyword in a SQL statement.
|
|
type Condition interface {
|
|
gomock.Matcher
|
|
Write(builder *StatementBuilder)
|
|
}
|
|
|
|
type and struct {
|
|
conditions []Condition
|
|
}
|
|
|
|
// Matches implements Condition.
|
|
func (a *and) Matches(x any) bool {
|
|
toMatch, ok := x.(*and)
|
|
if !ok {
|
|
return false
|
|
}
|
|
if len(a.conditions) != len(toMatch.conditions) {
|
|
return false
|
|
}
|
|
for i, condition := range a.conditions {
|
|
if !condition.Matches(toMatch.conditions[i]) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// String implements Condition.
|
|
func (a *and) String() string {
|
|
return "database.and"
|
|
}
|
|
|
|
// Write implements [Condition].
|
|
func (a *and) Write(builder *StatementBuilder) {
|
|
if len(a.conditions) > 1 {
|
|
builder.WriteString("(")
|
|
defer builder.WriteString(")")
|
|
}
|
|
for i, condition := range a.conditions {
|
|
if i > 0 {
|
|
builder.WriteString(" AND ")
|
|
}
|
|
condition.Write(builder)
|
|
}
|
|
}
|
|
|
|
// And combines multiple conditions with AND.
|
|
func And(conditions ...Condition) *and {
|
|
return &and{conditions: conditions}
|
|
}
|
|
|
|
var _ Condition = (*and)(nil)
|
|
|
|
type or struct {
|
|
conditions []Condition
|
|
}
|
|
|
|
// Matches implements Condition.
|
|
func (o *or) Matches(x any) bool {
|
|
toMatch, ok := x.(*or)
|
|
if !ok {
|
|
return false
|
|
}
|
|
if len(o.conditions) != len(toMatch.conditions) {
|
|
return false
|
|
}
|
|
for i, condition := range o.conditions {
|
|
if !condition.Matches(toMatch.conditions[i]) {
|
|
return false
|
|
}
|
|
}
|
|
return true
|
|
}
|
|
|
|
// String implements Condition.
|
|
func (o *or) String() string {
|
|
return "database.or"
|
|
}
|
|
|
|
// Write implements [Condition].
|
|
func (o *or) Write(builder *StatementBuilder) {
|
|
if len(o.conditions) > 1 {
|
|
builder.WriteString("(")
|
|
defer builder.WriteString(")")
|
|
}
|
|
for i, condition := range o.conditions {
|
|
if i > 0 {
|
|
builder.WriteString(" OR ")
|
|
}
|
|
condition.Write(builder)
|
|
}
|
|
}
|
|
|
|
// Or combines multiple conditions with OR.
|
|
func Or(conditions ...Condition) *or {
|
|
return &or{conditions: conditions}
|
|
}
|
|
|
|
var _ Condition = (*or)(nil)
|
|
|
|
type isNull struct {
|
|
column Column
|
|
}
|
|
|
|
// Matches implements Condition.
|
|
func (i *isNull) Matches(x any) bool {
|
|
toMatch, ok := x.(*isNull)
|
|
if !ok {
|
|
return false
|
|
}
|
|
return i.column.Matches(toMatch.column)
|
|
}
|
|
|
|
// String implements Condition.
|
|
func (i *isNull) String() string {
|
|
return "database.isNull"
|
|
}
|
|
|
|
// Write implements [Condition].
|
|
func (i *isNull) Write(builder *StatementBuilder) {
|
|
i.column.WriteQualified(builder)
|
|
builder.WriteString(" IS NULL")
|
|
}
|
|
|
|
// IsNull creates a condition that checks if a column is NULL.
|
|
func IsNull(column Column) *isNull {
|
|
return &isNull{column: column}
|
|
}
|
|
|
|
var _ Condition = (*isNull)(nil)
|
|
|
|
type isNotNull struct {
|
|
column Column
|
|
}
|
|
|
|
// Matches implements Condition.
|
|
func (i *isNotNull) Matches(x any) bool {
|
|
toMatch, ok := x.(*isNotNull)
|
|
if !ok {
|
|
return false
|
|
}
|
|
return i.column.Matches(toMatch.column)
|
|
}
|
|
|
|
// String implements Condition.
|
|
func (i *isNotNull) String() string {
|
|
return "database.isNotNull"
|
|
}
|
|
|
|
// Write implements [Condition].
|
|
func (i *isNotNull) Write(builder *StatementBuilder) {
|
|
i.column.WriteQualified(builder)
|
|
builder.WriteString(" IS NOT NULL")
|
|
}
|
|
|
|
// IsNotNull creates a condition that checks if a column is NOT NULL.
|
|
func IsNotNull(column Column) *isNotNull {
|
|
return &isNotNull{column: column}
|
|
}
|
|
|
|
var _ Condition = (*isNotNull)(nil)
|
|
|
|
type valueCondition func(builder *StatementBuilder)
|
|
|
|
// Matches implements Condition.
|
|
func (c valueCondition) Matches(x any) bool {
|
|
toMatch, ok := x.(valueCondition)
|
|
if !ok {
|
|
return false
|
|
}
|
|
return c.String() == toMatch.String()
|
|
}
|
|
|
|
// String implements Condition.
|
|
func (c valueCondition) String() string {
|
|
return "database.valueCondition"
|
|
}
|
|
|
|
// NewTextCondition creates a condition that compares a text column with a value.
|
|
func NewTextCondition[V Text](col Column, op TextOperation, value V) Condition {
|
|
return valueCondition(func(builder *StatementBuilder) {
|
|
writeTextOperation(builder, col, op, value)
|
|
})
|
|
}
|
|
|
|
// NewDateCondition creates a condition that compares a numeric column with a value.
|
|
func NewNumberCondition[V Number](col Column, op NumberOperation, value V) Condition {
|
|
return valueCondition(func(builder *StatementBuilder) {
|
|
writeNumberOperation(builder, col, op, value)
|
|
})
|
|
}
|
|
|
|
// NewDateCondition creates a condition that compares a boolean column with a value.
|
|
func NewBooleanCondition[V Boolean](col Column, value V) Condition {
|
|
return valueCondition(func(builder *StatementBuilder) {
|
|
writeBooleanOperation(builder, col, value)
|
|
})
|
|
}
|
|
|
|
// NewColumnCondition creates a condition that compares two columns on equality.
|
|
func NewColumnCondition(col1, col2 Column) Condition {
|
|
return valueCondition(func(builder *StatementBuilder) {
|
|
col1.WriteQualified(builder)
|
|
builder.WriteString(" = ")
|
|
col2.WriteQualified(builder)
|
|
})
|
|
}
|
|
|
|
// Write implements [Condition].
|
|
func (c valueCondition) Write(builder *StatementBuilder) {
|
|
c(builder)
|
|
}
|
|
|
|
var _ Condition = (*valueCondition)(nil)
|