2016-07-06 08:02:35 +02:00
|
|
|
{{- $tableNameSingular := .Table.Name | singular | titleCase -}}
|
|
|
|
{{- $tableNamePlural := .Table.Name | plural | titleCase -}}
|
|
|
|
{{- $varNamePlural := .Table.Name | plural | camelCase -}}
|
|
|
|
{{- $varNameSingular := .Table.Name | singular | camelCase -}}
|
2016-08-15 11:36:38 +02:00
|
|
|
func test{{$tableNamePlural}}Update(t *testing.T) {
|
2016-08-14 10:58:36 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2016-08-18 09:06:28 +02:00
|
|
|
seed := randomize.NewSeed()
|
2016-08-15 05:14:39 +02:00
|
|
|
var err error
|
2016-08-14 08:38:41 +02:00
|
|
|
{{$varNameSingular}} := &{{$tableNameSingular}}{}
|
2016-08-18 09:06:28 +02:00
|
|
|
if err = randomize.Struct(seed, {{$varNameSingular}}, {{$varNameSingular}}DBTypes, true); err != nil {
|
2016-08-14 11:11:32 +02:00
|
|
|
t.Errorf("Unable to randomize {{$tableNameSingular}} struct: %s", err)
|
2016-07-15 12:14:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-15 05:14:39 +02:00
|
|
|
tx := MustTx(boil.Begin())
|
2016-08-14 08:38:41 +02:00
|
|
|
defer tx.Rollback()
|
|
|
|
if err = {{$varNameSingular}}.Insert(tx); err != nil {
|
|
|
|
t.Error(err)
|
2016-07-15 12:14:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
count, err := {{$tableNamePlural}}(tx).Count()
|
2016-07-15 12:14:47 +02:00
|
|
|
if err != nil {
|
2016-08-11 14:26:49 +02:00
|
|
|
t.Error(err)
|
|
|
|
}
|
2016-07-15 12:14:47 +02:00
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
if count != 1 {
|
|
|
|
t.Error("want one record, got:", count)
|
|
|
|
}
|
2016-08-11 10:23:47 +02:00
|
|
|
|
2016-08-18 09:06:28 +02:00
|
|
|
if err = randomize.Struct(seed, {{$varNameSingular}}, {{$varNameSingular}}DBTypes, true, {{$varNameSingular}}PrimaryKeyColumns...); err != nil {
|
2016-08-14 11:11:32 +02:00
|
|
|
t.Errorf("Unable to randomize {{$tableNameSingular}} struct: %s", err)
|
2016-08-11 10:23:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-21 07:44:49 +02:00
|
|
|
// If table only contains primary key columns, we need to pass
|
|
|
|
// them into a whitelist to get a valid test result,
|
|
|
|
// otherwise the Update method will error because it will not be able to
|
|
|
|
// generate a whitelist (due to it excluding primary key columns).
|
|
|
|
if strmangle.StringSliceMatch({{$varNameSingular}}Columns, {{$varNameSingular}}PrimaryKeyColumns) {
|
|
|
|
if err = {{$varNameSingular}}.Update(tx, {{$varNameSingular}}PrimaryKeyColumns...); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if err = {{$varNameSingular}}.Update(tx); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2016-08-11 10:23:47 +02:00
|
|
|
}
|
2016-08-14 08:38:41 +02:00
|
|
|
}
|
2016-08-11 10:23:47 +02:00
|
|
|
|
2016-08-15 11:36:38 +02:00
|
|
|
func test{{$tableNamePlural}}SliceUpdateAll(t *testing.T) {
|
2016-08-14 10:58:36 +02:00
|
|
|
t.Parallel()
|
|
|
|
|
2016-08-18 09:06:28 +02:00
|
|
|
seed := randomize.NewSeed()
|
2016-08-15 05:14:39 +02:00
|
|
|
var err error
|
2016-08-14 08:38:41 +02:00
|
|
|
{{$varNameSingular}} := &{{$tableNameSingular}}{}
|
2016-08-18 09:06:28 +02:00
|
|
|
if err = randomize.Struct(seed, {{$varNameSingular}}, {{$varNameSingular}}DBTypes, true); err != nil {
|
2016-08-14 11:11:32 +02:00
|
|
|
t.Errorf("Unable to randomize {{$tableNameSingular}} struct: %s", err)
|
2016-08-14 08:38:41 +02:00
|
|
|
}
|
2016-08-11 10:23:47 +02:00
|
|
|
|
2016-08-15 05:14:39 +02:00
|
|
|
tx := MustTx(boil.Begin())
|
2016-08-14 08:38:41 +02:00
|
|
|
defer tx.Rollback()
|
|
|
|
if err = {{$varNameSingular}}.Insert(tx); err != nil {
|
|
|
|
t.Error(err)
|
2016-08-11 10:23:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
count, err := {{$tableNamePlural}}(tx).Count()
|
2016-08-11 10:23:47 +02:00
|
|
|
if err != nil {
|
2016-08-14 08:38:41 +02:00
|
|
|
t.Error(err)
|
2016-08-11 10:23:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
if count != 1 {
|
|
|
|
t.Error("want one record, got:", count)
|
|
|
|
}
|
2016-08-11 14:26:49 +02:00
|
|
|
|
2016-08-18 09:06:28 +02:00
|
|
|
if err = randomize.Struct(seed, {{$varNameSingular}}, {{$varNameSingular}}DBTypes, true, {{$varNameSingular}}PrimaryKeyColumns...); err != nil {
|
2016-08-14 11:11:32 +02:00
|
|
|
t.Errorf("Unable to randomize {{$tableNameSingular}} struct: %s", err)
|
2016-08-11 10:23:47 +02:00
|
|
|
}
|
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
// Remove Primary keys and unique columns from what we plan to update
|
2016-08-21 07:44:49 +02:00
|
|
|
var fields []string
|
|
|
|
if strmangle.StringSliceMatch({{$varNameSingular}}Columns, {{$varNameSingular}}PrimaryKeyColumns) {
|
|
|
|
fields = {{$varNameSingular}}Columns
|
|
|
|
} else {
|
|
|
|
fields = strmangle.SetComplement(
|
|
|
|
{{$varNameSingular}}Columns,
|
|
|
|
{{$varNameSingular}}PrimaryKeyColumns,
|
|
|
|
)
|
|
|
|
}
|
2016-08-11 14:26:49 +02:00
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
value := reflect.Indirect(reflect.ValueOf({{$varNameSingular}}))
|
|
|
|
updateMap := M{}
|
|
|
|
for _, col := range fields {
|
|
|
|
updateMap[col] = value.FieldByName(strmangle.TitleCase(col)).Interface()
|
|
|
|
}
|
2016-08-11 14:26:49 +02:00
|
|
|
|
2016-08-14 08:38:41 +02:00
|
|
|
slice := {{$tableNameSingular}}Slice{{"{"}}{{$varNameSingular}}{{"}"}}
|
|
|
|
if err = slice.UpdateAll(tx, updateMap); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2016-08-11 10:23:47 +02:00
|
|
|
}
|