|
@@ -85,7 +85,7 @@ func TestVersion1(t *testing.T) {
|
|
|
}
|
|
}
|
|
|
fmt.Println(newVer)
|
|
fmt.Println(newVer)
|
|
|
if newVer.Ver != 2 {
|
|
if newVer.Ver != 2 {
|
|
|
- err = errors.New("insert error")
|
|
|
|
|
|
|
+ err = errors.New("update error")
|
|
|
t.Error(err)
|
|
t.Error(err)
|
|
|
panic(err)
|
|
panic(err)
|
|
|
}
|
|
}
|
|
@@ -126,3 +126,117 @@ func TestVersion2(t *testing.T) {
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+type VersionUintS struct {
|
|
|
|
|
+ Id int64
|
|
|
|
|
+ Name string
|
|
|
|
|
+ Ver uint `xorm:"version"`
|
|
|
|
|
+ Created time.Time `xorm:"created"`
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func TestVersion3(t *testing.T) {
|
|
|
|
|
+ assert.NoError(t, prepareEngine())
|
|
|
|
|
+
|
|
|
|
|
+ err := testEngine.DropTables(new(VersionUintS))
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ err = testEngine.CreateTables(new(VersionUintS))
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ ver := &VersionUintS{Name: "sfsfdsfds"}
|
|
|
|
|
+ _, err = testEngine.Insert(ver)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+ fmt.Println(ver)
|
|
|
|
|
+ if ver.Ver != 1 {
|
|
|
|
|
+ err = errors.New("insert error")
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ newVer := new(VersionUintS)
|
|
|
|
|
+ has, err := testEngine.ID(ver.Id).Get(newVer)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ if !has {
|
|
|
|
|
+ t.Error(errors.New(fmt.Sprintf("no version id is %v", ver.Id)))
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+ fmt.Println(newVer)
|
|
|
|
|
+ if newVer.Ver != 1 {
|
|
|
|
|
+ err = errors.New("insert error")
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ newVer.Name = "-------"
|
|
|
|
|
+ _, err = testEngine.ID(ver.Id).Update(newVer)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+ if newVer.Ver != 2 {
|
|
|
|
|
+ err = errors.New("update should set version back to struct")
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ newVer = new(VersionUintS)
|
|
|
|
|
+ has, err = testEngine.ID(ver.Id).Get(newVer)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+ fmt.Println(newVer)
|
|
|
|
|
+ if newVer.Ver != 2 {
|
|
|
|
|
+ err = errors.New("update error")
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func TestVersion4(t *testing.T) {
|
|
|
|
|
+ assert.NoError(t, prepareEngine())
|
|
|
|
|
+
|
|
|
|
|
+ err := testEngine.DropTables(new(VersionUintS))
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ err = testEngine.CreateTables(new(VersionUintS))
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ var vers = []VersionUintS{
|
|
|
|
|
+ {Name: "sfsfdsfds"},
|
|
|
|
|
+ {Name: "xxxxx"},
|
|
|
|
|
+ }
|
|
|
|
|
+ _, err = testEngine.Insert(vers)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ fmt.Println(vers)
|
|
|
|
|
+
|
|
|
|
|
+ for _, v := range vers {
|
|
|
|
|
+ if v.Ver != 1 {
|
|
|
|
|
+ err := errors.New("version should be 1")
|
|
|
|
|
+ t.Error(err)
|
|
|
|
|
+ panic(err)
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+}
|