2016-08-15 11:36:38 +02:00
|
|
|
// This test suite runs each operation test in parallel.
|
|
|
|
// Example, if your database has 3 tables, the suite will run:
|
|
|
|
// table1, table2 and table3 Delete in parallel
|
|
|
|
// table1, table2 and table3 Insert in parallel, and so forth.
|
|
|
|
// It does NOT run each operation group in parallel.
|
|
|
|
// Separating the tests thusly grants avoidance of Postgres deadlocks.
|
2016-08-16 06:07:15 +02:00
|
|
|
func TestParent(t *testing.T) {
|
2016-08-15 11:36:38 +02:00
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}})
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDelete(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Delete)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestQueryDeleteAll(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}QueryDeleteAll)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSliceDeleteAll(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}SliceDeleteAll)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestExists(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Exists)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFind(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Find)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
2016-08-16 06:07:15 +02:00
|
|
|
func TestBind(t *testing.T) {
|
2016-08-15 11:36:38 +02:00
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Bind)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestOne(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}One)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestAll(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}All)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCount(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Count)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHelpers(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}InPrimaryKeyArgs)
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}SliceInPrimaryKeyArgs)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
2016-08-28 12:48:50 +02:00
|
|
|
{{if eq .NoHooks false -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
func TestHooks(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Hooks)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
2016-08-28 12:48:50 +02:00
|
|
|
{{- end}}
|
2016-08-15 11:36:38 +02:00
|
|
|
|
|
|
|
func TestInsert(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Insert)
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}InsertWhitelist)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
2016-08-27 07:04:49 +02:00
|
|
|
// TestToOne tests cannot be run in parallel
|
|
|
|
// or deadlocks can occur.
|
|
|
|
func TestToOne(t *testing.T) {
|
|
|
|
{{- $dot := . -}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.FKeys -}}
|
|
|
|
{{- $rel := textsFromForeignKey $dot.PkgName $dot.Tables $table . -}}
|
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}To{{$rel.ForeignTable.NameGo}}_{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToOne{{$rel.ForeignTable.NameGo}}_{{$rel.Function.Name}})
|
|
|
|
{{end -}}{{- /* fkey range */ -}}
|
|
|
|
{{- end -}}{{- /* if join table */ -}}
|
|
|
|
{{- end -}}{{- /* tables range */ -}}
|
|
|
|
}
|
|
|
|
|
2016-08-17 06:54:36 +02:00
|
|
|
// TestToMany tests cannot be run in parallel
|
2016-08-27 07:04:49 +02:00
|
|
|
// or deadlocks can occur.
|
2016-08-17 06:54:36 +02:00
|
|
|
func TestToMany(t *testing.T) {
|
2016-08-15 11:36:38 +02:00
|
|
|
{{- $dot := .}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.ToManyRelationships -}}
|
|
|
|
{{- $rel := textsFromRelationship $dot.Tables $table . -}}
|
|
|
|
{{- if (and .ForeignColumnUnique (not .ToJoinTable)) -}}
|
2016-08-17 06:54:36 +02:00
|
|
|
{{- $oneToOne := textsFromOneToOneRelationship $dot.PkgName $dot.Tables $table . -}}
|
|
|
|
t.Run("{{$oneToOne.LocalTable.NameGo}}OneToOne{{$oneToOne.ForeignTable.NameGo}}_{{$oneToOne.Function.Name}}", test{{$oneToOne.LocalTable.NameGo}}ToOne{{$oneToOne.ForeignTable.NameGo}}_{{$oneToOne.Function.Name}})
|
2016-08-15 11:36:38 +02:00
|
|
|
{{else -}}
|
2016-08-17 06:54:36 +02:00
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}ToMany{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToMany{{$rel.Function.Name}})
|
2016-08-15 11:36:38 +02:00
|
|
|
{{end -}}{{- /* if unique */ -}}
|
|
|
|
{{- end -}}{{- /* range */ -}}
|
|
|
|
{{- end -}}{{- /* outer if join table */ -}}
|
|
|
|
{{- end -}}{{- /* outer tables range */ -}}
|
|
|
|
}
|
|
|
|
|
2016-08-27 07:04:49 +02:00
|
|
|
// TestToOneSet tests cannot be run in parallel
|
|
|
|
// or deadlocks can occur.
|
|
|
|
func TestToOneSet(t *testing.T) {
|
2016-08-17 06:54:36 +02:00
|
|
|
{{- $dot := . -}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.FKeys -}}
|
|
|
|
{{- $rel := textsFromForeignKey $dot.PkgName $dot.Tables $table . -}}
|
2016-08-27 07:04:49 +02:00
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}To{{$rel.ForeignTable.NameGo}}_{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToOneSetOp{{$rel.ForeignTable.NameGo}}_{{$rel.Function.Name}})
|
2016-08-17 06:54:36 +02:00
|
|
|
{{end -}}{{- /* fkey range */ -}}
|
|
|
|
{{- end -}}{{- /* if join table */ -}}
|
|
|
|
{{- end -}}{{- /* tables range */ -}}
|
|
|
|
}
|
|
|
|
|
2016-08-27 07:04:49 +02:00
|
|
|
// TestToOneRemove tests cannot be run in parallel
|
|
|
|
// or deadlocks can occur.
|
|
|
|
func TestToOneRemove(t *testing.T) {
|
|
|
|
{{- $dot := . -}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.FKeys -}}
|
|
|
|
{{- $rel := textsFromForeignKey $dot.PkgName $dot.Tables $table . -}}
|
|
|
|
{{- if $rel.ForeignKey.Nullable -}}
|
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}To{{$rel.ForeignTable.NameGo}}_{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToOneRemoveOp{{$rel.ForeignTable.NameGo}}_{{$rel.Function.Name}})
|
|
|
|
{{end -}}{{- /* if foreign key nullable */ -}}
|
|
|
|
{{- end -}}{{- /* fkey range */ -}}
|
|
|
|
{{- end -}}{{- /* if join table */ -}}
|
|
|
|
{{- end -}}{{- /* tables range */ -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestToManyAdd tests cannot be run in parallel
|
|
|
|
// or deadlocks can occur.
|
|
|
|
func TestToManyAdd(t *testing.T) {
|
|
|
|
{{- $dot := .}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.ToManyRelationships -}}
|
|
|
|
{{- $rel := textsFromRelationship $dot.Tables $table . -}}
|
|
|
|
{{- if (and .ForeignColumnUnique (not .ToJoinTable)) -}}
|
|
|
|
{{- else -}}
|
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}ToMany{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToManyAddOp{{$rel.Function.Name}})
|
|
|
|
{{end -}}{{- /* if unique */ -}}
|
|
|
|
{{- end -}}{{- /* range */ -}}
|
|
|
|
{{- end -}}{{- /* outer if join table */ -}}
|
|
|
|
{{- end -}}{{- /* outer tables range */ -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestToManySet tests cannot be run in parallel
|
|
|
|
// or deadlocks can occur.
|
|
|
|
func TestToManySet(t *testing.T) {
|
|
|
|
{{- $dot := .}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.ToManyRelationships -}}
|
|
|
|
{{- if not .ForeignColumnNullable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $rel := textsFromRelationship $dot.Tables $table . -}}
|
|
|
|
{{- if (and .ForeignColumnUnique (not .ToJoinTable)) -}}
|
|
|
|
{{- $oneToOne := textsFromOneToOneRelationship $dot.PkgName $dot.Tables $table . -}}
|
|
|
|
t.Run("{{$oneToOne.LocalTable.NameGo}}OneToOne{{$oneToOne.ForeignTable.NameGo}}_{{$oneToOne.Function.Name}}", test{{$oneToOne.LocalTable.NameGo}}ToOneSetOp{{$oneToOne.ForeignTable.NameGo}}_{{$oneToOne.Function.Name}})
|
|
|
|
{{else -}}
|
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}ToMany{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToManySetOp{{$rel.Function.Name}})
|
|
|
|
{{end -}}{{- /* if unique */ -}}
|
|
|
|
{{- end -}}{{- /* if foreign column nullable */ -}}
|
|
|
|
{{- end -}}{{- /* range */ -}}
|
|
|
|
{{- end -}}{{- /* outer if join table */ -}}
|
|
|
|
{{- end -}}{{- /* outer tables range */ -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestToManyRemove tests cannot be run in parallel
|
|
|
|
// or deadlocks can occur.
|
|
|
|
func TestToManyRemove(t *testing.T) {
|
|
|
|
{{- $dot := .}}
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- range $table.ToManyRelationships -}}
|
|
|
|
{{- if not .ForeignColumnNullable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $rel := textsFromRelationship $dot.Tables $table . -}}
|
|
|
|
{{- if (and .ForeignColumnUnique (not .ToJoinTable)) -}}
|
|
|
|
{{- $oneToOne := textsFromOneToOneRelationship $dot.PkgName $dot.Tables $table . -}}
|
|
|
|
t.Run("{{$oneToOne.LocalTable.NameGo}}OneToOne{{$oneToOne.ForeignTable.NameGo}}_{{$oneToOne.Function.Name}}", test{{$oneToOne.LocalTable.NameGo}}ToOneRemoveOp{{$oneToOne.ForeignTable.NameGo}}_{{$oneToOne.Function.Name}})
|
|
|
|
{{else -}}
|
|
|
|
t.Run("{{$rel.LocalTable.NameGo}}ToMany{{$rel.Function.Name}}", test{{$rel.LocalTable.NameGo}}ToManyRemoveOp{{$rel.Function.Name}})
|
|
|
|
{{end -}}{{- /* if unique */ -}}
|
|
|
|
{{- end -}}{{- /* if foreign column nullable */ -}}
|
|
|
|
{{- end -}}{{- /* range */ -}}
|
|
|
|
{{- end -}}{{- /* outer if join table */ -}}
|
|
|
|
{{- end -}}{{- /* outer tables range */ -}}
|
|
|
|
}
|
|
|
|
|
2016-08-15 11:36:38 +02:00
|
|
|
func TestReload(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Reload)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReloadAll(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}ReloadAll)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSelect(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Select)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUpdate(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Update)
|
2016-08-16 06:07:15 +02:00
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSliceUpdateAll(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}SliceUpdateAll)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUpsert(t *testing.T) {
|
|
|
|
{{- range $index, $table := .Tables}}
|
|
|
|
{{- if $table.IsJoinTable -}}
|
|
|
|
{{- else -}}
|
|
|
|
{{- $tableName := $table.Name | plural | titleCase -}}
|
|
|
|
t.Run("{{$tableName}}", test{{$tableName}}Upsert)
|
|
|
|
{{end -}}
|
|
|
|
{{- end -}}
|
|
|
|
}
|