| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031 |
- // Copyright 2017 The Xorm Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style
- // license that can be found in the LICENSE file.
- package xorm
- import (
- "errors"
- "fmt"
- "testing"
- "github.com/stretchr/testify/assert"
- )
- func TestBefore_Get(t *testing.T) {
- assert.NoError(t, prepareEngine())
- type BeforeTable struct {
- Id int64
- Name string
- Val string `xorm:"-"`
- }
- assert.NoError(t, testEngine.Sync2(new(BeforeTable)))
- cnt, err := testEngine.Insert(&BeforeTable{
- Name: "test",
- })
- assert.NoError(t, err)
- assert.EqualValues(t, 1, cnt)
- var be BeforeTable
- has, err := testEngine.Before(func(bean interface{}) {
- bean.(*BeforeTable).Val = "val"
- }).Get(&be)
- assert.NoError(t, err)
- assert.Equal(t, true, has)
- assert.Equal(t, "val", be.Val)
- assert.Equal(t, "test", be.Name)
- }
- func TestBefore_Find(t *testing.T) {
- assert.NoError(t, prepareEngine())
- type BeforeTable2 struct {
- Id int64
- Name string
- Val string `xorm:"-"`
- }
- assert.NoError(t, testEngine.Sync2(new(BeforeTable2)))
- cnt, err := testEngine.Insert([]BeforeTable2{
- {Name: "test1"},
- {Name: "test2"},
- })
- assert.NoError(t, err)
- assert.EqualValues(t, 2, cnt)
- var be []BeforeTable2
- err = testEngine.Before(func(bean interface{}) {
- bean.(*BeforeTable2).Val = "val"
- }).Find(&be)
- assert.NoError(t, err)
- assert.Equal(t, 2, len(be))
- assert.Equal(t, "val", be[0].Val)
- assert.Equal(t, "test1", be[0].Name)
- assert.Equal(t, "val", be[1].Val)
- assert.Equal(t, "test2", be[1].Name)
- }
- type ProcessorsStruct struct {
- Id int64
- B4InsertFlag int
- AfterInsertedFlag int
- B4UpdateFlag int
- AfterUpdatedFlag int
- B4DeleteFlag int `xorm:"-"`
- AfterDeletedFlag int `xorm:"-"`
- BeforeSetFlag int `xorm:"-"`
- B4InsertViaExt int
- AfterInsertedViaExt int
- B4UpdateViaExt int
- AfterUpdatedViaExt int
- B4DeleteViaExt int `xorm:"-"`
- AfterDeletedViaExt int `xorm:"-"`
- AfterSetFlag int `xorm:"-"`
- }
- func (p *ProcessorsStruct) BeforeInsert() {
- p.B4InsertFlag = 1
- }
- func (p *ProcessorsStruct) BeforeUpdate() {
- p.B4UpdateFlag = 1
- }
- func (p *ProcessorsStruct) BeforeDelete() {
- p.B4DeleteFlag = 1
- }
- func (p *ProcessorsStruct) BeforeSet(col string, cell Cell) {
- p.BeforeSetFlag = p.BeforeSetFlag + 1
- }
- func (p *ProcessorsStruct) AfterInsert() {
- p.AfterInsertedFlag = 1
- }
- func (p *ProcessorsStruct) AfterUpdate() {
- p.AfterUpdatedFlag = 1
- }
- func (p *ProcessorsStruct) AfterDelete() {
- p.AfterDeletedFlag = 1
- }
- func (p *ProcessorsStruct) AfterSet(col string, cell Cell) {
- p.AfterSetFlag = p.AfterSetFlag + 1
- }
- func TestProcessors(t *testing.T) {
- assert.NoError(t, prepareEngine())
- err := testEngine.DropTables(&ProcessorsStruct{})
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p := &ProcessorsStruct{}
- err = testEngine.CreateTables(&ProcessorsStruct{})
- if err != nil {
- t.Error(err)
- panic(err)
- }
- b4InsertFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.B4InsertViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- afterInsertFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.AfterInsertedViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- _, err = testEngine.Before(b4InsertFunc).After(afterInsertFunc).Insert(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.AfterInsertedFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.AfterInsertedViaExt == 0 {
- t.Error(errors.New("AfterInsertedViaExt not set"))
- }
- }
- p2 := &ProcessorsStruct{}
- _, err = testEngine.ID(p.Id).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p2.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag is set"))
- }
- if p2.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p2.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- if p2.BeforeSetFlag != 9 {
- t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p2.BeforeSetFlag))
- }
- if p2.AfterSetFlag != 9 {
- t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p2.BeforeSetFlag))
- }
- }
- // --
- // test find processors
- var p2Find []*ProcessorsStruct
- err = testEngine.Find(&p2Find)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if len(p2Find) != 1 {
- err = errors.New("Should get 1")
- t.Error(err)
- }
- p21 := p2Find[0]
- if p21.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p21.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag is set"))
- }
- if p21.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p21.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- if p21.BeforeSetFlag != 9 {
- t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p21.BeforeSetFlag))
- }
- if p21.AfterSetFlag != 9 {
- t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p21.BeforeSetFlag))
- }
- }
- // --
- // test find map processors
- var p2FindMap = make(map[int64]*ProcessorsStruct)
- err = testEngine.Find(&p2FindMap)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if len(p2FindMap) != 1 {
- err = errors.New("Should get 1")
- t.Error(err)
- }
- var p22 *ProcessorsStruct
- for _, v := range p2FindMap {
- p22 = v
- }
- if p22.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p22.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag is set"))
- }
- if p22.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p22.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- if p22.BeforeSetFlag != 9 {
- t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p22.BeforeSetFlag))
- }
- if p22.AfterSetFlag != 9 {
- t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p22.BeforeSetFlag))
- }
- }
- // --
- // test update processors
- b4UpdateFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.B4UpdateViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- afterUpdateFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.AfterUpdatedViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- p = p2 // reset
- _, err = testEngine.Before(b4UpdateFunc).After(afterUpdateFunc).Update(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag == 0 {
- t.Error(errors.New("AfterUpdatedFlag not set"))
- }
- if p.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p.AfterUpdatedViaExt == 0 {
- t.Error(errors.New("AfterUpdatedViaExt not set"))
- }
- }
- p2 = &ProcessorsStruct{}
- _, err = testEngine.ID(p.Id).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p2.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag is set: " + string(p.AfterUpdatedFlag)))
- }
- if p2.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p2.AfterUpdatedViaExt != 0 {
- t.Error(errors.New("AfterUpdatedViaExt is set: " + string(p.AfterUpdatedViaExt)))
- }
- if p2.BeforeSetFlag != 9 {
- t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p2.BeforeSetFlag))
- }
- if p2.AfterSetFlag != 9 {
- t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p2.BeforeSetFlag))
- }
- }
- // --
- // test delete processors
- b4DeleteFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.B4DeleteViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- afterDeleteFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.AfterDeletedViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- p = p2 // reset
- _, err = testEngine.Before(b4DeleteFunc).After(afterDeleteFunc).Delete(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag == 0 {
- t.Error(errors.New("AfterDeletedFlag not set"))
- }
- if p.B4DeleteViaExt == 0 {
- t.Error(errors.New("B4DeleteViaExt not set"))
- }
- if p.AfterDeletedViaExt == 0 {
- t.Error(errors.New("AfterDeletedViaExt not set"))
- }
- }
- // --
- // test insert multi
- pslice := make([]*ProcessorsStruct, 0)
- pslice = append(pslice, &ProcessorsStruct{})
- pslice = append(pslice, &ProcessorsStruct{})
- cnt, err := testEngine.Before(b4InsertFunc).After(afterInsertFunc).Insert(&pslice)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if cnt != 2 {
- t.Error(errors.New("incorrect insert count"))
- }
- for _, elem := range pslice {
- if elem.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if elem.AfterInsertedFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if elem.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if elem.AfterInsertedViaExt == 0 {
- t.Error(errors.New("AfterInsertedViaExt not set"))
- }
- }
- }
- for _, elem := range pslice {
- p = &ProcessorsStruct{}
- _, err = testEngine.ID(elem.Id).Get(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p2.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag is set"))
- }
- if p2.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p2.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- if p2.BeforeSetFlag != 9 {
- t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p2.BeforeSetFlag))
- }
- if p2.AfterSetFlag != 9 {
- t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p2.BeforeSetFlag))
- }
- }
- }
- // --
- }
- func TestProcessorsTx(t *testing.T) {
- assert.NoError(t, prepareEngine())
- err := testEngine.DropTables(&ProcessorsStruct{})
- if err != nil {
- t.Error(err)
- panic(err)
- }
- err = testEngine.CreateTables(&ProcessorsStruct{})
- if err != nil {
- t.Error(err)
- panic(err)
- }
- // test insert processors with tx rollback
- session := testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p := &ProcessorsStruct{}
- b4InsertFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.B4InsertViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- afterInsertFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.AfterInsertedViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- _, err = session.Before(b4InsertFunc).After(afterInsertFunc).Insert(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.AfterInsertedFlag != 0 {
- t.Error(errors.New("B4InsertFlag is set"))
- }
- if p.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- }
- err = session.Rollback()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.AfterInsertedFlag != 0 {
- t.Error(errors.New("B4InsertFlag is set"))
- }
- if p.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- }
- session.Close()
- p2 := &ProcessorsStruct{}
- _, err = testEngine.ID(p.Id).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.Id > 0 {
- err = errors.New("tx got committed upon insert!?")
- t.Error(err)
- panic(err)
- }
- }
- // --
- // test insert processors with tx commit
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p = &ProcessorsStruct{}
- _, err = session.Before(b4InsertFunc).After(afterInsertFunc).Insert(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag is set"))
- }
- if p.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- }
- err = session.Commit()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p.AfterInsertedFlag == 0 {
- t.Error(errors.New("AfterInsertedFlag not set"))
- }
- if p.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p.AfterInsertedViaExt == 0 {
- t.Error(errors.New("AfterInsertedViaExt not set"))
- }
- }
- session.Close()
- p2 = &ProcessorsStruct{}
- _, err = testEngine.ID(p.Id).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.B4InsertFlag == 0 {
- t.Error(errors.New("B4InsertFlag not set"))
- }
- if p2.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag is set"))
- }
- if p2.B4InsertViaExt == 0 {
- t.Error(errors.New("B4InsertViaExt not set"))
- }
- if p2.AfterInsertedViaExt != 0 {
- t.Error(errors.New("AfterInsertedViaExt is set"))
- }
- }
- insertedId := p2.Id
- // --
- // test update processors with tx rollback
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- b4UpdateFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.B4UpdateViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- afterUpdateFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.AfterUpdatedViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- p = p2 // reset
- _, err = session.ID(insertedId).Before(b4UpdateFunc).After(afterUpdateFunc).Update(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag is set"))
- }
- if p.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p.AfterUpdatedViaExt != 0 {
- t.Error(errors.New("AfterUpdatedViaExt is set"))
- }
- }
- err = session.Rollback()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag is set"))
- }
- if p.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p.AfterUpdatedViaExt != 0 {
- t.Error(errors.New("AfterUpdatedViaExt is set"))
- }
- }
- session.Close()
- p2 = &ProcessorsStruct{}
- _, err = testEngine.ID(insertedId).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.B4UpdateFlag != 0 {
- t.Error(errors.New("B4UpdateFlag is set"))
- }
- if p2.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag is set"))
- }
- if p2.B4UpdateViaExt != 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p2.AfterUpdatedViaExt != 0 {
- t.Error(errors.New("AfterUpdatedViaExt is set"))
- }
- }
- // --
- // test update processors with tx rollback
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p = &ProcessorsStruct{Id: insertedId}
- _, err = session.Update(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag is set"))
- }
- }
- err = session.Commit()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag == 0 {
- t.Error(errors.New("AfterUpdatedFlag not set"))
- }
- if p.AfterDeletedFlag != 0 {
- t.Error(errors.New("AfterDeletedFlag set"))
- }
- if p.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag set"))
- }
- }
- session.Close()
- // test update processors with tx commit
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p = &ProcessorsStruct{}
- _, err = session.ID(insertedId).Before(b4UpdateFunc).After(afterUpdateFunc).Update(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag is set"))
- }
- if p.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p.AfterUpdatedViaExt != 0 {
- t.Error(errors.New("AfterUpdatedViaExt is set"))
- }
- }
- err = session.Commit()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag == 0 {
- t.Error(errors.New("AfterUpdatedFlag not set"))
- }
- if p.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p.AfterUpdatedViaExt == 0 {
- t.Error(errors.New("AfterUpdatedViaExt not set"))
- }
- }
- session.Close()
- p2 = &ProcessorsStruct{}
- _, err = testEngine.ID(insertedId).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4UpdateFlag == 0 {
- t.Error(errors.New("B4UpdateFlag not set"))
- }
- if p.AfterUpdatedFlag == 0 {
- t.Error(errors.New("AfterUpdatedFlag not set"))
- }
- if p.B4UpdateViaExt == 0 {
- t.Error(errors.New("B4UpdateViaExt not set"))
- }
- if p.AfterUpdatedViaExt == 0 {
- t.Error(errors.New("AfterUpdatedViaExt not set"))
- }
- }
- // --
- // test delete processors with tx rollback
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- b4DeleteFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.B4DeleteViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- afterDeleteFunc := func(bean interface{}) {
- if v, ok := (bean).(*ProcessorsStruct); ok {
- v.AfterDeletedViaExt = 1
- } else {
- t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
- }
- }
- p = &ProcessorsStruct{} // reset
- _, err = session.ID(insertedId).Before(b4DeleteFunc).After(afterDeleteFunc).Delete(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag != 0 {
- t.Error(errors.New("AfterDeletedFlag is set"))
- }
- if p.B4DeleteViaExt == 0 {
- t.Error(errors.New("B4DeleteViaExt not set"))
- }
- if p.AfterDeletedViaExt != 0 {
- t.Error(errors.New("AfterDeletedViaExt is set"))
- }
- }
- err = session.Rollback()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag != 0 {
- t.Error(errors.New("AfterDeletedFlag is set"))
- }
- if p.B4DeleteViaExt == 0 {
- t.Error(errors.New("B4DeleteViaExt not set"))
- }
- if p.AfterDeletedViaExt != 0 {
- t.Error(errors.New("AfterDeletedViaExt is set"))
- }
- }
- session.Close()
- p2 = &ProcessorsStruct{}
- _, err = testEngine.ID(insertedId).Get(p2)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p2.B4DeleteFlag != 0 {
- t.Error(errors.New("B4DeleteFlag is set"))
- }
- if p2.AfterDeletedFlag != 0 {
- t.Error(errors.New("AfterDeletedFlag is set"))
- }
- if p2.B4DeleteViaExt != 0 {
- t.Error(errors.New("B4DeleteViaExt is set"))
- }
- if p2.AfterDeletedViaExt != 0 {
- t.Error(errors.New("AfterDeletedViaExt is set"))
- }
- }
- // --
- // test delete processors with tx commit
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p = &ProcessorsStruct{}
- _, err = session.ID(insertedId).Before(b4DeleteFunc).After(afterDeleteFunc).Delete(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag != 0 {
- t.Error(errors.New("AfterDeletedFlag is set"))
- }
- if p.B4DeleteViaExt == 0 {
- t.Error(errors.New("B4DeleteViaExt not set"))
- }
- if p.AfterDeletedViaExt != 0 {
- t.Error(errors.New("AfterDeletedViaExt is set"))
- }
- }
- err = session.Commit()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag == 0 {
- t.Error(errors.New("AfterDeletedFlag not set"))
- }
- if p.B4DeleteViaExt == 0 {
- t.Error(errors.New("B4DeleteViaExt not set"))
- }
- if p.AfterDeletedViaExt == 0 {
- t.Error(errors.New("AfterDeletedViaExt not set"))
- }
- }
- session.Close()
- // test delete processors with tx commit
- session = testEngine.NewSession()
- err = session.Begin()
- if err != nil {
- t.Error(err)
- panic(err)
- }
- p = &ProcessorsStruct{Id: insertedId}
- fmt.Println("delete")
- _, err = session.Delete(p)
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag != 0 {
- t.Error(errors.New("AfterDeletedFlag is set"))
- }
- }
- err = session.Commit()
- if err != nil {
- t.Error(err)
- panic(err)
- } else {
- if p.B4DeleteFlag == 0 {
- t.Error(errors.New("B4DeleteFlag not set"))
- }
- if p.AfterDeletedFlag == 0 {
- t.Error(errors.New("AfterDeletedFlag not set"))
- }
- if p.AfterInsertedFlag != 0 {
- t.Error(errors.New("AfterInsertedFlag set"))
- }
- if p.AfterUpdatedFlag != 0 {
- t.Error(errors.New("AfterUpdatedFlag set"))
- }
- }
- session.Close()
- // --
- }
- type AfterLoadStructA struct {
- Id int64
- Content string
- }
- type AfterLoadStructB struct {
- Id int64
- Content string
- AId int64
- A AfterLoadStructA `xorm:"-"`
- Err error `xorm:"-"`
- }
- func (s *AfterLoadStructB) AfterLoad(session *Session) {
- has, err := session.ID(s.AId).NoAutoCondition().Get(&s.A)
- if err != nil {
- s.Err = err
- return
- }
- if !has {
- s.Err = ErrNotExist
- }
- }
- func TestAfterLoadProcessor(t *testing.T) {
- assert.NoError(t, prepareEngine())
- assertSync(t, new(AfterLoadStructA), new(AfterLoadStructB))
- var a = AfterLoadStructA{
- Content: "testa",
- }
- _, err := testEngine.Insert(&a)
- assert.NoError(t, err)
- var b = AfterLoadStructB{
- Content: "testb",
- AId: a.Id,
- }
- _, err = testEngine.Insert(&b)
- assert.NoError(t, err)
- var b2 AfterLoadStructB
- has, err := testEngine.ID(b.Id).Get(&b2)
- assert.NoError(t, err)
- assert.True(t, has)
- assert.EqualValues(t, a.Id, b2.A.Id)
- assert.EqualValues(t, a.Content, b2.A.Content)
- assert.NoError(t, b2.Err)
- b.Id = 0
- _, err = testEngine.Insert(&b)
- assert.NoError(t, err)
- var bs []AfterLoadStructB
- err = testEngine.Find(&bs)
- assert.NoError(t, err)
- assert.EqualValues(t, 2, len(bs))
- for i := 0; i < len(bs); i++ {
- assert.EqualValues(t, a.Id, bs[i].A.Id)
- assert.EqualValues(t, a.Content, bs[i].A.Content)
- assert.NoError(t, bs[i].Err)
- }
- }
|