github.com/eden-framework/sqlx@v0.0.2/generator/__examples__/database/user_test.go (about) 1 package database 2 3 import ( 4 "database/sql/driver" 5 "testing" 6 7 "github.com/eden-framework/sqlx/builder" 8 "github.com/eden-framework/sqlx/migration" 9 "github.com/eden-framework/sqlx/mysqlconnector" 10 "github.com/eden-framework/sqlx/postgresqlconnector" 11 _ "github.com/go-sql-driver/mysql" 12 "github.com/google/uuid" 13 "github.com/onsi/gomega" 14 "github.com/sirupsen/logrus" 15 ) 16 17 var ( 18 mysqlConnector = &mysqlconnector.MysqlConnector{ 19 Host: "root@tcp(0.0.0.0:3306)", 20 Extra: "charset=utf8mb4&parseTime=true&interpolateParams=true&autocommit=true&loc=Local", 21 } 22 23 postgresConnector = &postgresqlconnector.PostgreSQLConnector{ 24 Host: "postgres://postgres@0.0.0.0:5432", 25 Extra: "sslmode=disable", 26 Extensions: []string{"postgis"}, 27 } 28 ) 29 30 func init() { 31 logrus.SetLevel(logrus.DebugLevel) 32 } 33 34 func TestUser(t *testing.T) { 35 t.Run("CRUD", func(t *testing.T) { 36 for _, connector := range []driver.Connector{ 37 mysqlConnector, 38 postgresConnector, 39 } { 40 db := DBTest.OpenDB(connector) 41 42 db.D().Tables.Range(func(table *builder.Table, idx int) { 43 _, err := db.ExecExpr(db.Dialect().DropTable(table)) 44 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 45 }) 46 47 err := migration.Migrate(db, nil) 48 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 49 50 t.Run("Create flow", func(t *testing.T) { 51 user := User{} 52 user.Name = uuid.New().String() 53 user.Geom = GeomString{ 54 V: "Point(0 0)", 55 } 56 57 errForCreate := user.Create(db) 58 gomega.NewWithT(t).Expect(errForCreate).To(gomega.BeNil()) 59 gomega.NewWithT(t).Expect(user.ID, uint64(0)) 60 61 user.Gender = GenderMale 62 { 63 err := user.CreateOnDuplicateWithUpdateFields(db, []string{"Gender"}) 64 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 65 } 66 { 67 userForFetch := User{ 68 Name: user.Name, 69 } 70 err := userForFetch.FetchByName(db) 71 72 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 73 gomega.NewWithT(t).Expect(userForFetch.Gender).To(gomega.Equal(user.Gender)) 74 } 75 }) 76 t.Run("delete flow", func(t *testing.T) { 77 user := User{} 78 user.Name = uuid.New().String() 79 user.Geom = GeomString{ 80 V: "Point(0 0)", 81 } 82 83 errForCreate := user.Create(db) 84 gomega.NewWithT(t).Expect(errForCreate).To(gomega.BeNil()) 85 86 { 87 userForDelete := User{ 88 Name: user.Name, 89 } 90 err := userForDelete.SoftDeleteByName(db) 91 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 92 93 userForSelect := &User{ 94 Name: user.Name, 95 } 96 errForSelect := userForSelect.FetchByName(db) 97 gomega.NewWithT(t).Expect(errForSelect).NotTo(gomega.BeNil()) 98 } 99 }) 100 db.D().Tables.Range(func(table *builder.Table, idx int) { 101 _, err := db.ExecExpr(db.Dialect().DropTable(table)) 102 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 103 }) 104 } 105 }) 106 t.Run("List", func(t *testing.T) { 107 for _, connector := range []driver.Connector{ 108 mysqlConnector, 109 postgresConnector, 110 } { 111 db := DBTest.OpenDB(connector) 112 113 db.D().Tables.Range(func(table *builder.Table, idx int) { 114 _, err := db.ExecExpr(db.Dialect().DropTable(table)) 115 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 116 }) 117 118 err := migration.Migrate(db, nil) 119 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 120 121 createUser := func() { 122 user := User{} 123 user.Name = uuid.New().String() 124 user.Geom = GeomString{ 125 V: "Point(0 0)", 126 } 127 128 err := user.Create(db) 129 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 130 } 131 132 for i := 0; i < 10; i++ { 133 createUser() 134 } 135 136 list, err := (&User{}).List(db, nil) 137 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 138 gomega.NewWithT(t).Expect(list).To(gomega.HaveLen(10)) 139 140 count, err := (&User{}).Count(db, nil) 141 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 142 gomega.NewWithT(t).Expect(count).To(gomega.Equal(10)) 143 144 names := make([]string, 0) 145 for _, user := range list { 146 names = append(names, user.Name) 147 } 148 149 { 150 list, err := (&User{}).BatchFetchByNameList(db, names) 151 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 152 gomega.NewWithT(t).Expect(list).To(gomega.HaveLen(10)) 153 } 154 155 db.D().Tables.Range(func(table *builder.Table, idx int) { 156 _, err := db.ExecExpr(db.Dialect().DropTable(table)) 157 gomega.NewWithT(t).Expect(err).To(gomega.BeNil()) 158 }) 159 } 160 }) 161 }