// Copyright 2019-present Facebook Inc. All rights reserved. // This source code is licensed under the Apache 2.0 license found // in the LICENSE file in the root directory of this source tree. // Code generated by ent, DO NOT EDIT. package enttest import ( "context" "entgo.io/ent/entc/integration/migrate/entv2" // required by schema hooks. _ "entgo.io/ent/entc/integration/migrate/entv2/runtime" "entgo.io/ent/dialect/sql/schema" ) type ( // TestingT is the interface that is shared between // testing.T and testing.B and used by enttest. TestingT interface { FailNow() Error(...interface{}) } // Option configures client creation. Option func(*options) options struct { opts []entv2.Option migrateOpts []schema.MigrateOption } ) // WithOptions forwards options to client creation. func WithOptions(opts ...entv2.Option) Option { return func(o *options) { o.opts = append(o.opts, opts...) } } // WithMigrateOptions forwards options to auto migration. func WithMigrateOptions(opts ...schema.MigrateOption) Option { return func(o *options) { o.migrateOpts = append(o.migrateOpts, opts...) } } func newOptions(opts []Option) *options { o := &options{} for _, opt := range opts { opt(o) } return o } // Open calls entv2.Open and auto-run migration. func Open(t TestingT, driverName, dataSourceName string, opts ...Option) *entv2.Client { o := newOptions(opts) c, err := entv2.Open(driverName, dataSourceName, o.opts...) if err != nil { t.Error(err) t.FailNow() } if err := c.Schema.Create(context.Background(), o.migrateOpts...); err != nil { t.Error(err) t.FailNow() } return c } // NewClient calls entv2.NewClient and auto-run migration. func NewClient(t TestingT, opts ...Option) *entv2.Client { o := newOptions(opts) c := entv2.NewClient(o.opts...) if err := c.Schema.Create(context.Background(), o.migrateOpts...); err != nil { t.Error(err) t.FailNow() } return c }