// Code generated by SQLBoiler 4.8.3 (https://github.com/volatiletech/sqlboiler). DO NOT EDIT. // This file is meant to be re-generated in place and/or deleted at any time. package models import ( "bytes" "context" "reflect" "testing" "github.com/volatiletech/randomize" "github.com/volatiletech/sqlboiler/v4/boil" "github.com/volatiletech/sqlboiler/v4/queries" "github.com/volatiletech/strmangle" ) func testHeadersUpsert(t *testing.T) { t.Parallel() if len(headerAllColumns) == len(headerPrimaryKeyColumns) { t.Skip("Skipping table with only primary key columns") } seed := randomize.NewSeed() var err error // Attempt the INSERT side of an UPSERT o := Header{} if err = randomize.Struct(seed, &o, headerDBTypes, true); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Upsert(ctx, tx, false, nil, boil.Infer(), boil.Infer()); err != nil { t.Errorf("Unable to upsert Header: %s", err) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 1 { t.Error("want one record, got:", count) } // Attempt the UPDATE side of an UPSERT if err = randomize.Struct(seed, &o, headerDBTypes, false, headerPrimaryKeyColumns...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } if err = o.Upsert(ctx, tx, true, nil, boil.Infer(), boil.Infer()); err != nil { t.Errorf("Unable to upsert Header: %s", err) } count, err = Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 1 { t.Error("want one record, got:", count) } } var ( // Relationships sometimes use the reflection helper queries.Equal/queries.Assign // so force a package dependency in case they don't. _ = queries.Equal ) func testHeaders(t *testing.T) { t.Parallel() query := Headers() if query.Query == nil { t.Error("expected a query, got nothing") } } func testHeadersDelete(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if rowsAff, err := o.Delete(ctx, tx); err != nil { t.Error(err) } else if rowsAff != 1 { t.Error("should only have deleted one row, but affected:", rowsAff) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 0 { t.Error("want zero records, got:", count) } } func testHeadersQueryDeleteAll(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if rowsAff, err := Headers().DeleteAll(ctx, tx); err != nil { t.Error(err) } else if rowsAff != 1 { t.Error("should only have deleted one row, but affected:", rowsAff) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 0 { t.Error("want zero records, got:", count) } } func testHeadersSliceDeleteAll(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } slice := HeaderSlice{o} if rowsAff, err := slice.DeleteAll(ctx, tx); err != nil { t.Error(err) } else if rowsAff != 1 { t.Error("should only have deleted one row, but affected:", rowsAff) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 0 { t.Error("want zero records, got:", count) } } func testHeadersExists(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } e, err := HeaderExists(ctx, tx, o.Name) if err != nil { t.Errorf("Unable to check if Header exists: %s", err) } if !e { t.Errorf("Expected HeaderExists to return true, but got false.") } } func testHeadersFind(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } headerFound, err := FindHeader(ctx, tx, o.Name) if err != nil { t.Error(err) } if headerFound == nil { t.Error("want a record, got nil") } } func testHeadersBind(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if err = Headers().Bind(ctx, tx, o); err != nil { t.Error(err) } } func testHeadersOne(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if x, err := Headers().One(ctx, tx); err != nil { t.Error(err) } else if x == nil { t.Error("expected to get a non nil record") } } func testHeadersAll(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error headerOne := &Header{} headerTwo := &Header{} if err = randomize.Struct(seed, headerOne, headerDBTypes, false, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } if err = randomize.Struct(seed, headerTwo, headerDBTypes, false, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = headerOne.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if err = headerTwo.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } slice, err := Headers().All(ctx, tx) if err != nil { t.Error(err) } if len(slice) != 2 { t.Error("want 2 records, got:", len(slice)) } } func testHeadersCount(t *testing.T) { t.Parallel() var err error seed := randomize.NewSeed() headerOne := &Header{} headerTwo := &Header{} if err = randomize.Struct(seed, headerOne, headerDBTypes, false, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } if err = randomize.Struct(seed, headerTwo, headerDBTypes, false, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = headerOne.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if err = headerTwo.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 2 { t.Error("want 2 records, got:", count) } } func headerBeforeInsertHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerAfterInsertHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerAfterSelectHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerBeforeUpdateHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerAfterUpdateHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerBeforeDeleteHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerAfterDeleteHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerBeforeUpsertHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func headerAfterUpsertHook(ctx context.Context, e boil.ContextExecutor, o *Header) error { *o = Header{} return nil } func testHeadersHooks(t *testing.T) { t.Parallel() var err error ctx := context.Background() empty := &Header{} o := &Header{} seed := randomize.NewSeed() if err = randomize.Struct(seed, o, headerDBTypes, false); err != nil { t.Errorf("Unable to randomize Header object: %s", err) } AddHeaderHook(boil.BeforeInsertHook, headerBeforeInsertHook) if err = o.doBeforeInsertHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doBeforeInsertHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected BeforeInsertHook function to empty object, but got: %#v", o) } headerBeforeInsertHooks = []HeaderHook{} AddHeaderHook(boil.AfterInsertHook, headerAfterInsertHook) if err = o.doAfterInsertHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doAfterInsertHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected AfterInsertHook function to empty object, but got: %#v", o) } headerAfterInsertHooks = []HeaderHook{} AddHeaderHook(boil.AfterSelectHook, headerAfterSelectHook) if err = o.doAfterSelectHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doAfterSelectHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected AfterSelectHook function to empty object, but got: %#v", o) } headerAfterSelectHooks = []HeaderHook{} AddHeaderHook(boil.BeforeUpdateHook, headerBeforeUpdateHook) if err = o.doBeforeUpdateHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doBeforeUpdateHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected BeforeUpdateHook function to empty object, but got: %#v", o) } headerBeforeUpdateHooks = []HeaderHook{} AddHeaderHook(boil.AfterUpdateHook, headerAfterUpdateHook) if err = o.doAfterUpdateHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doAfterUpdateHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected AfterUpdateHook function to empty object, but got: %#v", o) } headerAfterUpdateHooks = []HeaderHook{} AddHeaderHook(boil.BeforeDeleteHook, headerBeforeDeleteHook) if err = o.doBeforeDeleteHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doBeforeDeleteHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected BeforeDeleteHook function to empty object, but got: %#v", o) } headerBeforeDeleteHooks = []HeaderHook{} AddHeaderHook(boil.AfterDeleteHook, headerAfterDeleteHook) if err = o.doAfterDeleteHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doAfterDeleteHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected AfterDeleteHook function to empty object, but got: %#v", o) } headerAfterDeleteHooks = []HeaderHook{} AddHeaderHook(boil.BeforeUpsertHook, headerBeforeUpsertHook) if err = o.doBeforeUpsertHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doBeforeUpsertHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected BeforeUpsertHook function to empty object, but got: %#v", o) } headerBeforeUpsertHooks = []HeaderHook{} AddHeaderHook(boil.AfterUpsertHook, headerAfterUpsertHook) if err = o.doAfterUpsertHooks(ctx, nil); err != nil { t.Errorf("Unable to execute doAfterUpsertHooks: %s", err) } if !reflect.DeepEqual(o, empty) { t.Errorf("Expected AfterUpsertHook function to empty object, but got: %#v", o) } headerAfterUpsertHooks = []HeaderHook{} } func testHeadersInsert(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 1 { t.Error("want one record, got:", count) } } func testHeadersInsertWhitelist(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Whitelist(headerColumnsWithoutDefault...)); err != nil { t.Error(err) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 1 { t.Error("want one record, got:", count) } } func testHeadersReload(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } if err = o.Reload(ctx, tx); err != nil { t.Error(err) } } func testHeadersReloadAll(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } slice := HeaderSlice{o} if err = slice.ReloadAll(ctx, tx); err != nil { t.Error(err) } } func testHeadersSelect(t *testing.T) { t.Parallel() seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } slice, err := Headers().All(ctx, tx) if err != nil { t.Error(err) } if len(slice) != 1 { t.Error("want one record, got:", len(slice)) } } var ( headerDBTypes = map[string]string{`Record`: `INTEGER`, `Lastknownrecord`: `INTEGER`, `Block`: `INTEGER`, `Lastknownblock`: `INTEGER`, `Deleted`: `INTEGER`, `Typeflag`: `INTEGER`, `Name`: `TEXT`, `Linkname`: `TEXT`, `Size`: `INTEGER`, `Mode`: `INTEGER`, `UID`: `INTEGER`, `Gid`: `INTEGER`, `Uname`: `TEXT`, `Gname`: `TEXT`, `Modtime`: `DATE`, `Accesstime`: `DATE`, `Changetime`: `DATE`, `Devmajor`: `INTEGER`, `Devminor`: `INTEGER`, `Paxrecords`: `TEXT`, `Format`: `INTEGER`} _ = bytes.MinRead ) func testHeadersUpdate(t *testing.T) { t.Parallel() if 0 == len(headerPrimaryKeyColumns) { t.Skip("Skipping table with no primary key columns") } if len(headerAllColumns) == len(headerPrimaryKeyColumns) { t.Skip("Skipping table with only primary key columns") } seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 1 { t.Error("want one record, got:", count) } if err = randomize.Struct(seed, o, headerDBTypes, true, headerPrimaryKeyColumns...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } if rowsAff, err := o.Update(ctx, tx, boil.Infer()); err != nil { t.Error(err) } else if rowsAff != 1 { t.Error("should only affect one row but affected", rowsAff) } } func testHeadersSliceUpdateAll(t *testing.T) { t.Parallel() if len(headerAllColumns) == len(headerPrimaryKeyColumns) { t.Skip("Skipping table with only primary key columns") } seed := randomize.NewSeed() var err error o := &Header{} if err = randomize.Struct(seed, o, headerDBTypes, true, headerColumnsWithDefault...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } ctx := context.Background() tx := MustTx(boil.BeginTx(ctx, nil)) defer func() { _ = tx.Rollback() }() if err = o.Insert(ctx, tx, boil.Infer()); err != nil { t.Error(err) } count, err := Headers().Count(ctx, tx) if err != nil { t.Error(err) } if count != 1 { t.Error("want one record, got:", count) } if err = randomize.Struct(seed, o, headerDBTypes, true, headerPrimaryKeyColumns...); err != nil { t.Errorf("Unable to randomize Header struct: %s", err) } // Remove Primary keys and unique columns from what we plan to update var fields []string if strmangle.StringSliceMatch(headerAllColumns, headerPrimaryKeyColumns) { fields = headerAllColumns } else { fields = strmangle.SetComplement( headerAllColumns, headerPrimaryKeyColumns, ) } value := reflect.Indirect(reflect.ValueOf(o)) typ := reflect.TypeOf(o).Elem() n := typ.NumField() updateMap := M{} for _, col := range fields { for i := 0; i < n; i++ { f := typ.Field(i) if f.Tag.Get("boil") == col { updateMap[col] = value.Field(i).Interface() } } } slice := HeaderSlice{o} if rowsAff, err := slice.UpdateAll(ctx, tx, updateMap); err != nil { t.Error(err) } else if rowsAff != 1 { t.Error("wanted one record updated but got", rowsAff) } }