processors_test.go 23 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031
  1. // Copyright 2017 The Xorm Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package xorm
  5. import (
  6. "errors"
  7. "fmt"
  8. "testing"
  9. "github.com/stretchr/testify/assert"
  10. )
  11. func TestBefore_Get(t *testing.T) {
  12. assert.NoError(t, prepareEngine())
  13. type BeforeTable struct {
  14. Id int64
  15. Name string
  16. Val string `xorm:"-"`
  17. }
  18. assert.NoError(t, testEngine.Sync2(new(BeforeTable)))
  19. cnt, err := testEngine.Insert(&BeforeTable{
  20. Name: "test",
  21. })
  22. assert.NoError(t, err)
  23. assert.EqualValues(t, 1, cnt)
  24. var be BeforeTable
  25. has, err := testEngine.Before(func(bean interface{}) {
  26. bean.(*BeforeTable).Val = "val"
  27. }).Get(&be)
  28. assert.NoError(t, err)
  29. assert.Equal(t, true, has)
  30. assert.Equal(t, "val", be.Val)
  31. assert.Equal(t, "test", be.Name)
  32. }
  33. func TestBefore_Find(t *testing.T) {
  34. assert.NoError(t, prepareEngine())
  35. type BeforeTable2 struct {
  36. Id int64
  37. Name string
  38. Val string `xorm:"-"`
  39. }
  40. assert.NoError(t, testEngine.Sync2(new(BeforeTable2)))
  41. cnt, err := testEngine.Insert([]BeforeTable2{
  42. {Name: "test1"},
  43. {Name: "test2"},
  44. })
  45. assert.NoError(t, err)
  46. assert.EqualValues(t, 2, cnt)
  47. var be []BeforeTable2
  48. err = testEngine.Before(func(bean interface{}) {
  49. bean.(*BeforeTable2).Val = "val"
  50. }).Find(&be)
  51. assert.NoError(t, err)
  52. assert.Equal(t, 2, len(be))
  53. assert.Equal(t, "val", be[0].Val)
  54. assert.Equal(t, "test1", be[0].Name)
  55. assert.Equal(t, "val", be[1].Val)
  56. assert.Equal(t, "test2", be[1].Name)
  57. }
  58. type ProcessorsStruct struct {
  59. Id int64
  60. B4InsertFlag int
  61. AfterInsertedFlag int
  62. B4UpdateFlag int
  63. AfterUpdatedFlag int
  64. B4DeleteFlag int `xorm:"-"`
  65. AfterDeletedFlag int `xorm:"-"`
  66. BeforeSetFlag int `xorm:"-"`
  67. B4InsertViaExt int
  68. AfterInsertedViaExt int
  69. B4UpdateViaExt int
  70. AfterUpdatedViaExt int
  71. B4DeleteViaExt int `xorm:"-"`
  72. AfterDeletedViaExt int `xorm:"-"`
  73. AfterSetFlag int `xorm:"-"`
  74. }
  75. func (p *ProcessorsStruct) BeforeInsert() {
  76. p.B4InsertFlag = 1
  77. }
  78. func (p *ProcessorsStruct) BeforeUpdate() {
  79. p.B4UpdateFlag = 1
  80. }
  81. func (p *ProcessorsStruct) BeforeDelete() {
  82. p.B4DeleteFlag = 1
  83. }
  84. func (p *ProcessorsStruct) BeforeSet(col string, cell Cell) {
  85. p.BeforeSetFlag = p.BeforeSetFlag + 1
  86. }
  87. func (p *ProcessorsStruct) AfterInsert() {
  88. p.AfterInsertedFlag = 1
  89. }
  90. func (p *ProcessorsStruct) AfterUpdate() {
  91. p.AfterUpdatedFlag = 1
  92. }
  93. func (p *ProcessorsStruct) AfterDelete() {
  94. p.AfterDeletedFlag = 1
  95. }
  96. func (p *ProcessorsStruct) AfterSet(col string, cell Cell) {
  97. p.AfterSetFlag = p.AfterSetFlag + 1
  98. }
  99. func TestProcessors(t *testing.T) {
  100. assert.NoError(t, prepareEngine())
  101. err := testEngine.DropTables(&ProcessorsStruct{})
  102. if err != nil {
  103. t.Error(err)
  104. panic(err)
  105. }
  106. p := &ProcessorsStruct{}
  107. err = testEngine.CreateTables(&ProcessorsStruct{})
  108. if err != nil {
  109. t.Error(err)
  110. panic(err)
  111. }
  112. b4InsertFunc := func(bean interface{}) {
  113. if v, ok := (bean).(*ProcessorsStruct); ok {
  114. v.B4InsertViaExt = 1
  115. } else {
  116. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  117. }
  118. }
  119. afterInsertFunc := func(bean interface{}) {
  120. if v, ok := (bean).(*ProcessorsStruct); ok {
  121. v.AfterInsertedViaExt = 1
  122. } else {
  123. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  124. }
  125. }
  126. _, err = testEngine.Before(b4InsertFunc).After(afterInsertFunc).Insert(p)
  127. if err != nil {
  128. t.Error(err)
  129. panic(err)
  130. } else {
  131. if p.B4InsertFlag == 0 {
  132. t.Error(errors.New("B4InsertFlag not set"))
  133. }
  134. if p.AfterInsertedFlag == 0 {
  135. t.Error(errors.New("B4InsertFlag not set"))
  136. }
  137. if p.B4InsertViaExt == 0 {
  138. t.Error(errors.New("B4InsertFlag not set"))
  139. }
  140. if p.AfterInsertedViaExt == 0 {
  141. t.Error(errors.New("AfterInsertedViaExt not set"))
  142. }
  143. }
  144. p2 := &ProcessorsStruct{}
  145. _, err = testEngine.ID(p.Id).Get(p2)
  146. if err != nil {
  147. t.Error(err)
  148. panic(err)
  149. } else {
  150. if p2.B4InsertFlag == 0 {
  151. t.Error(errors.New("B4InsertFlag not set"))
  152. }
  153. if p2.AfterInsertedFlag != 0 {
  154. t.Error(errors.New("AfterInsertedFlag is set"))
  155. }
  156. if p2.B4InsertViaExt == 0 {
  157. t.Error(errors.New("B4InsertViaExt not set"))
  158. }
  159. if p2.AfterInsertedViaExt != 0 {
  160. t.Error(errors.New("AfterInsertedViaExt is set"))
  161. }
  162. if p2.BeforeSetFlag != 9 {
  163. t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p2.BeforeSetFlag))
  164. }
  165. if p2.AfterSetFlag != 9 {
  166. t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p2.BeforeSetFlag))
  167. }
  168. }
  169. // --
  170. // test find processors
  171. var p2Find []*ProcessorsStruct
  172. err = testEngine.Find(&p2Find)
  173. if err != nil {
  174. t.Error(err)
  175. panic(err)
  176. } else {
  177. if len(p2Find) != 1 {
  178. err = errors.New("Should get 1")
  179. t.Error(err)
  180. }
  181. p21 := p2Find[0]
  182. if p21.B4InsertFlag == 0 {
  183. t.Error(errors.New("B4InsertFlag not set"))
  184. }
  185. if p21.AfterInsertedFlag != 0 {
  186. t.Error(errors.New("AfterInsertedFlag is set"))
  187. }
  188. if p21.B4InsertViaExt == 0 {
  189. t.Error(errors.New("B4InsertViaExt not set"))
  190. }
  191. if p21.AfterInsertedViaExt != 0 {
  192. t.Error(errors.New("AfterInsertedViaExt is set"))
  193. }
  194. if p21.BeforeSetFlag != 9 {
  195. t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p21.BeforeSetFlag))
  196. }
  197. if p21.AfterSetFlag != 9 {
  198. t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p21.BeforeSetFlag))
  199. }
  200. }
  201. // --
  202. // test find map processors
  203. var p2FindMap = make(map[int64]*ProcessorsStruct)
  204. err = testEngine.Find(&p2FindMap)
  205. if err != nil {
  206. t.Error(err)
  207. panic(err)
  208. } else {
  209. if len(p2FindMap) != 1 {
  210. err = errors.New("Should get 1")
  211. t.Error(err)
  212. }
  213. var p22 *ProcessorsStruct
  214. for _, v := range p2FindMap {
  215. p22 = v
  216. }
  217. if p22.B4InsertFlag == 0 {
  218. t.Error(errors.New("B4InsertFlag not set"))
  219. }
  220. if p22.AfterInsertedFlag != 0 {
  221. t.Error(errors.New("AfterInsertedFlag is set"))
  222. }
  223. if p22.B4InsertViaExt == 0 {
  224. t.Error(errors.New("B4InsertViaExt not set"))
  225. }
  226. if p22.AfterInsertedViaExt != 0 {
  227. t.Error(errors.New("AfterInsertedViaExt is set"))
  228. }
  229. if p22.BeforeSetFlag != 9 {
  230. t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p22.BeforeSetFlag))
  231. }
  232. if p22.AfterSetFlag != 9 {
  233. t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p22.BeforeSetFlag))
  234. }
  235. }
  236. // --
  237. // test update processors
  238. b4UpdateFunc := func(bean interface{}) {
  239. if v, ok := (bean).(*ProcessorsStruct); ok {
  240. v.B4UpdateViaExt = 1
  241. } else {
  242. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  243. }
  244. }
  245. afterUpdateFunc := func(bean interface{}) {
  246. if v, ok := (bean).(*ProcessorsStruct); ok {
  247. v.AfterUpdatedViaExt = 1
  248. } else {
  249. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  250. }
  251. }
  252. p = p2 // reset
  253. _, err = testEngine.Before(b4UpdateFunc).After(afterUpdateFunc).Update(p)
  254. if err != nil {
  255. t.Error(err)
  256. panic(err)
  257. } else {
  258. if p.B4UpdateFlag == 0 {
  259. t.Error(errors.New("B4UpdateFlag not set"))
  260. }
  261. if p.AfterUpdatedFlag == 0 {
  262. t.Error(errors.New("AfterUpdatedFlag not set"))
  263. }
  264. if p.B4UpdateViaExt == 0 {
  265. t.Error(errors.New("B4UpdateViaExt not set"))
  266. }
  267. if p.AfterUpdatedViaExt == 0 {
  268. t.Error(errors.New("AfterUpdatedViaExt not set"))
  269. }
  270. }
  271. p2 = &ProcessorsStruct{}
  272. _, err = testEngine.ID(p.Id).Get(p2)
  273. if err != nil {
  274. t.Error(err)
  275. panic(err)
  276. } else {
  277. if p2.B4UpdateFlag == 0 {
  278. t.Error(errors.New("B4UpdateFlag not set"))
  279. }
  280. if p2.AfterUpdatedFlag != 0 {
  281. t.Error(errors.New("AfterUpdatedFlag is set: " + string(p.AfterUpdatedFlag)))
  282. }
  283. if p2.B4UpdateViaExt == 0 {
  284. t.Error(errors.New("B4UpdateViaExt not set"))
  285. }
  286. if p2.AfterUpdatedViaExt != 0 {
  287. t.Error(errors.New("AfterUpdatedViaExt is set: " + string(p.AfterUpdatedViaExt)))
  288. }
  289. if p2.BeforeSetFlag != 9 {
  290. t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p2.BeforeSetFlag))
  291. }
  292. if p2.AfterSetFlag != 9 {
  293. t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p2.BeforeSetFlag))
  294. }
  295. }
  296. // --
  297. // test delete processors
  298. b4DeleteFunc := func(bean interface{}) {
  299. if v, ok := (bean).(*ProcessorsStruct); ok {
  300. v.B4DeleteViaExt = 1
  301. } else {
  302. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  303. }
  304. }
  305. afterDeleteFunc := func(bean interface{}) {
  306. if v, ok := (bean).(*ProcessorsStruct); ok {
  307. v.AfterDeletedViaExt = 1
  308. } else {
  309. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  310. }
  311. }
  312. p = p2 // reset
  313. _, err = testEngine.Before(b4DeleteFunc).After(afterDeleteFunc).Delete(p)
  314. if err != nil {
  315. t.Error(err)
  316. panic(err)
  317. } else {
  318. if p.B4DeleteFlag == 0 {
  319. t.Error(errors.New("B4DeleteFlag not set"))
  320. }
  321. if p.AfterDeletedFlag == 0 {
  322. t.Error(errors.New("AfterDeletedFlag not set"))
  323. }
  324. if p.B4DeleteViaExt == 0 {
  325. t.Error(errors.New("B4DeleteViaExt not set"))
  326. }
  327. if p.AfterDeletedViaExt == 0 {
  328. t.Error(errors.New("AfterDeletedViaExt not set"))
  329. }
  330. }
  331. // --
  332. // test insert multi
  333. pslice := make([]*ProcessorsStruct, 0)
  334. pslice = append(pslice, &ProcessorsStruct{})
  335. pslice = append(pslice, &ProcessorsStruct{})
  336. cnt, err := testEngine.Before(b4InsertFunc).After(afterInsertFunc).Insert(&pslice)
  337. if err != nil {
  338. t.Error(err)
  339. panic(err)
  340. } else {
  341. if cnt != 2 {
  342. t.Error(errors.New("incorrect insert count"))
  343. }
  344. for _, elem := range pslice {
  345. if elem.B4InsertFlag == 0 {
  346. t.Error(errors.New("B4InsertFlag not set"))
  347. }
  348. if elem.AfterInsertedFlag == 0 {
  349. t.Error(errors.New("B4InsertFlag not set"))
  350. }
  351. if elem.B4InsertViaExt == 0 {
  352. t.Error(errors.New("B4InsertFlag not set"))
  353. }
  354. if elem.AfterInsertedViaExt == 0 {
  355. t.Error(errors.New("AfterInsertedViaExt not set"))
  356. }
  357. }
  358. }
  359. for _, elem := range pslice {
  360. p = &ProcessorsStruct{}
  361. _, err = testEngine.ID(elem.Id).Get(p)
  362. if err != nil {
  363. t.Error(err)
  364. panic(err)
  365. } else {
  366. if p2.B4InsertFlag == 0 {
  367. t.Error(errors.New("B4InsertFlag not set"))
  368. }
  369. if p2.AfterInsertedFlag != 0 {
  370. t.Error(errors.New("AfterInsertedFlag is set"))
  371. }
  372. if p2.B4InsertViaExt == 0 {
  373. t.Error(errors.New("B4InsertViaExt not set"))
  374. }
  375. if p2.AfterInsertedViaExt != 0 {
  376. t.Error(errors.New("AfterInsertedViaExt is set"))
  377. }
  378. if p2.BeforeSetFlag != 9 {
  379. t.Error(fmt.Errorf("BeforeSetFlag is %d not 9", p2.BeforeSetFlag))
  380. }
  381. if p2.AfterSetFlag != 9 {
  382. t.Error(fmt.Errorf("AfterSetFlag is %d not 9", p2.BeforeSetFlag))
  383. }
  384. }
  385. }
  386. // --
  387. }
  388. func TestProcessorsTx(t *testing.T) {
  389. assert.NoError(t, prepareEngine())
  390. err := testEngine.DropTables(&ProcessorsStruct{})
  391. if err != nil {
  392. t.Error(err)
  393. panic(err)
  394. }
  395. err = testEngine.CreateTables(&ProcessorsStruct{})
  396. if err != nil {
  397. t.Error(err)
  398. panic(err)
  399. }
  400. // test insert processors with tx rollback
  401. session := testEngine.NewSession()
  402. err = session.Begin()
  403. if err != nil {
  404. t.Error(err)
  405. panic(err)
  406. }
  407. p := &ProcessorsStruct{}
  408. b4InsertFunc := func(bean interface{}) {
  409. if v, ok := (bean).(*ProcessorsStruct); ok {
  410. v.B4InsertViaExt = 1
  411. } else {
  412. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  413. }
  414. }
  415. afterInsertFunc := func(bean interface{}) {
  416. if v, ok := (bean).(*ProcessorsStruct); ok {
  417. v.AfterInsertedViaExt = 1
  418. } else {
  419. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  420. }
  421. }
  422. _, err = session.Before(b4InsertFunc).After(afterInsertFunc).Insert(p)
  423. if err != nil {
  424. t.Error(err)
  425. panic(err)
  426. } else {
  427. if p.B4InsertFlag == 0 {
  428. t.Error(errors.New("B4InsertFlag not set"))
  429. }
  430. if p.AfterInsertedFlag != 0 {
  431. t.Error(errors.New("B4InsertFlag is set"))
  432. }
  433. if p.B4InsertViaExt == 0 {
  434. t.Error(errors.New("B4InsertViaExt not set"))
  435. }
  436. if p.AfterInsertedViaExt != 0 {
  437. t.Error(errors.New("AfterInsertedViaExt is set"))
  438. }
  439. }
  440. err = session.Rollback()
  441. if err != nil {
  442. t.Error(err)
  443. panic(err)
  444. } else {
  445. if p.B4InsertFlag == 0 {
  446. t.Error(errors.New("B4InsertFlag not set"))
  447. }
  448. if p.AfterInsertedFlag != 0 {
  449. t.Error(errors.New("B4InsertFlag is set"))
  450. }
  451. if p.B4InsertViaExt == 0 {
  452. t.Error(errors.New("B4InsertViaExt not set"))
  453. }
  454. if p.AfterInsertedViaExt != 0 {
  455. t.Error(errors.New("AfterInsertedViaExt is set"))
  456. }
  457. }
  458. session.Close()
  459. p2 := &ProcessorsStruct{}
  460. _, err = testEngine.ID(p.Id).Get(p2)
  461. if err != nil {
  462. t.Error(err)
  463. panic(err)
  464. } else {
  465. if p2.Id > 0 {
  466. err = errors.New("tx got committed upon insert!?")
  467. t.Error(err)
  468. panic(err)
  469. }
  470. }
  471. // --
  472. // test insert processors with tx commit
  473. session = testEngine.NewSession()
  474. err = session.Begin()
  475. if err != nil {
  476. t.Error(err)
  477. panic(err)
  478. }
  479. p = &ProcessorsStruct{}
  480. _, err = session.Before(b4InsertFunc).After(afterInsertFunc).Insert(p)
  481. if err != nil {
  482. t.Error(err)
  483. panic(err)
  484. } else {
  485. if p.B4InsertFlag == 0 {
  486. t.Error(errors.New("B4InsertFlag not set"))
  487. }
  488. if p.AfterInsertedFlag != 0 {
  489. t.Error(errors.New("AfterInsertedFlag is set"))
  490. }
  491. if p.B4InsertViaExt == 0 {
  492. t.Error(errors.New("B4InsertViaExt not set"))
  493. }
  494. if p.AfterInsertedViaExt != 0 {
  495. t.Error(errors.New("AfterInsertedViaExt is set"))
  496. }
  497. }
  498. err = session.Commit()
  499. if err != nil {
  500. t.Error(err)
  501. panic(err)
  502. } else {
  503. if p.B4InsertFlag == 0 {
  504. t.Error(errors.New("B4InsertFlag not set"))
  505. }
  506. if p.AfterInsertedFlag == 0 {
  507. t.Error(errors.New("AfterInsertedFlag not set"))
  508. }
  509. if p.B4InsertViaExt == 0 {
  510. t.Error(errors.New("B4InsertViaExt not set"))
  511. }
  512. if p.AfterInsertedViaExt == 0 {
  513. t.Error(errors.New("AfterInsertedViaExt not set"))
  514. }
  515. }
  516. session.Close()
  517. p2 = &ProcessorsStruct{}
  518. _, err = testEngine.ID(p.Id).Get(p2)
  519. if err != nil {
  520. t.Error(err)
  521. panic(err)
  522. } else {
  523. if p2.B4InsertFlag == 0 {
  524. t.Error(errors.New("B4InsertFlag not set"))
  525. }
  526. if p2.AfterInsertedFlag != 0 {
  527. t.Error(errors.New("AfterInsertedFlag is set"))
  528. }
  529. if p2.B4InsertViaExt == 0 {
  530. t.Error(errors.New("B4InsertViaExt not set"))
  531. }
  532. if p2.AfterInsertedViaExt != 0 {
  533. t.Error(errors.New("AfterInsertedViaExt is set"))
  534. }
  535. }
  536. insertedId := p2.Id
  537. // --
  538. // test update processors with tx rollback
  539. session = testEngine.NewSession()
  540. err = session.Begin()
  541. if err != nil {
  542. t.Error(err)
  543. panic(err)
  544. }
  545. b4UpdateFunc := func(bean interface{}) {
  546. if v, ok := (bean).(*ProcessorsStruct); ok {
  547. v.B4UpdateViaExt = 1
  548. } else {
  549. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  550. }
  551. }
  552. afterUpdateFunc := func(bean interface{}) {
  553. if v, ok := (bean).(*ProcessorsStruct); ok {
  554. v.AfterUpdatedViaExt = 1
  555. } else {
  556. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  557. }
  558. }
  559. p = p2 // reset
  560. _, err = session.ID(insertedId).Before(b4UpdateFunc).After(afterUpdateFunc).Update(p)
  561. if err != nil {
  562. t.Error(err)
  563. panic(err)
  564. } else {
  565. if p.B4UpdateFlag == 0 {
  566. t.Error(errors.New("B4UpdateFlag not set"))
  567. }
  568. if p.AfterUpdatedFlag != 0 {
  569. t.Error(errors.New("AfterUpdatedFlag is set"))
  570. }
  571. if p.B4UpdateViaExt == 0 {
  572. t.Error(errors.New("B4UpdateViaExt not set"))
  573. }
  574. if p.AfterUpdatedViaExt != 0 {
  575. t.Error(errors.New("AfterUpdatedViaExt is set"))
  576. }
  577. }
  578. err = session.Rollback()
  579. if err != nil {
  580. t.Error(err)
  581. panic(err)
  582. } else {
  583. if p.B4UpdateFlag == 0 {
  584. t.Error(errors.New("B4UpdateFlag not set"))
  585. }
  586. if p.AfterUpdatedFlag != 0 {
  587. t.Error(errors.New("AfterUpdatedFlag is set"))
  588. }
  589. if p.B4UpdateViaExt == 0 {
  590. t.Error(errors.New("B4UpdateViaExt not set"))
  591. }
  592. if p.AfterUpdatedViaExt != 0 {
  593. t.Error(errors.New("AfterUpdatedViaExt is set"))
  594. }
  595. }
  596. session.Close()
  597. p2 = &ProcessorsStruct{}
  598. _, err = testEngine.ID(insertedId).Get(p2)
  599. if err != nil {
  600. t.Error(err)
  601. panic(err)
  602. } else {
  603. if p2.B4UpdateFlag != 0 {
  604. t.Error(errors.New("B4UpdateFlag is set"))
  605. }
  606. if p2.AfterUpdatedFlag != 0 {
  607. t.Error(errors.New("AfterUpdatedFlag is set"))
  608. }
  609. if p2.B4UpdateViaExt != 0 {
  610. t.Error(errors.New("B4UpdateViaExt not set"))
  611. }
  612. if p2.AfterUpdatedViaExt != 0 {
  613. t.Error(errors.New("AfterUpdatedViaExt is set"))
  614. }
  615. }
  616. // --
  617. // test update processors with tx rollback
  618. session = testEngine.NewSession()
  619. err = session.Begin()
  620. if err != nil {
  621. t.Error(err)
  622. panic(err)
  623. }
  624. p = &ProcessorsStruct{Id: insertedId}
  625. _, err = session.Update(p)
  626. if err != nil {
  627. t.Error(err)
  628. panic(err)
  629. } else {
  630. if p.B4UpdateFlag == 0 {
  631. t.Error(errors.New("B4UpdateFlag not set"))
  632. }
  633. if p.AfterUpdatedFlag != 0 {
  634. t.Error(errors.New("AfterUpdatedFlag is set"))
  635. }
  636. }
  637. err = session.Commit()
  638. if err != nil {
  639. t.Error(err)
  640. panic(err)
  641. } else {
  642. if p.B4UpdateFlag == 0 {
  643. t.Error(errors.New("B4UpdateFlag not set"))
  644. }
  645. if p.AfterUpdatedFlag == 0 {
  646. t.Error(errors.New("AfterUpdatedFlag not set"))
  647. }
  648. if p.AfterDeletedFlag != 0 {
  649. t.Error(errors.New("AfterDeletedFlag set"))
  650. }
  651. if p.AfterInsertedFlag != 0 {
  652. t.Error(errors.New("AfterInsertedFlag set"))
  653. }
  654. }
  655. session.Close()
  656. // test update processors with tx commit
  657. session = testEngine.NewSession()
  658. err = session.Begin()
  659. if err != nil {
  660. t.Error(err)
  661. panic(err)
  662. }
  663. p = &ProcessorsStruct{}
  664. _, err = session.ID(insertedId).Before(b4UpdateFunc).After(afterUpdateFunc).Update(p)
  665. if err != nil {
  666. t.Error(err)
  667. panic(err)
  668. } else {
  669. if p.B4UpdateFlag == 0 {
  670. t.Error(errors.New("B4UpdateFlag not set"))
  671. }
  672. if p.AfterUpdatedFlag != 0 {
  673. t.Error(errors.New("AfterUpdatedFlag is set"))
  674. }
  675. if p.B4UpdateViaExt == 0 {
  676. t.Error(errors.New("B4UpdateViaExt not set"))
  677. }
  678. if p.AfterUpdatedViaExt != 0 {
  679. t.Error(errors.New("AfterUpdatedViaExt is set"))
  680. }
  681. }
  682. err = session.Commit()
  683. if err != nil {
  684. t.Error(err)
  685. panic(err)
  686. } else {
  687. if p.B4UpdateFlag == 0 {
  688. t.Error(errors.New("B4UpdateFlag not set"))
  689. }
  690. if p.AfterUpdatedFlag == 0 {
  691. t.Error(errors.New("AfterUpdatedFlag not set"))
  692. }
  693. if p.B4UpdateViaExt == 0 {
  694. t.Error(errors.New("B4UpdateViaExt not set"))
  695. }
  696. if p.AfterUpdatedViaExt == 0 {
  697. t.Error(errors.New("AfterUpdatedViaExt not set"))
  698. }
  699. }
  700. session.Close()
  701. p2 = &ProcessorsStruct{}
  702. _, err = testEngine.ID(insertedId).Get(p2)
  703. if err != nil {
  704. t.Error(err)
  705. panic(err)
  706. } else {
  707. if p.B4UpdateFlag == 0 {
  708. t.Error(errors.New("B4UpdateFlag not set"))
  709. }
  710. if p.AfterUpdatedFlag == 0 {
  711. t.Error(errors.New("AfterUpdatedFlag not set"))
  712. }
  713. if p.B4UpdateViaExt == 0 {
  714. t.Error(errors.New("B4UpdateViaExt not set"))
  715. }
  716. if p.AfterUpdatedViaExt == 0 {
  717. t.Error(errors.New("AfterUpdatedViaExt not set"))
  718. }
  719. }
  720. // --
  721. // test delete processors with tx rollback
  722. session = testEngine.NewSession()
  723. err = session.Begin()
  724. if err != nil {
  725. t.Error(err)
  726. panic(err)
  727. }
  728. b4DeleteFunc := func(bean interface{}) {
  729. if v, ok := (bean).(*ProcessorsStruct); ok {
  730. v.B4DeleteViaExt = 1
  731. } else {
  732. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  733. }
  734. }
  735. afterDeleteFunc := func(bean interface{}) {
  736. if v, ok := (bean).(*ProcessorsStruct); ok {
  737. v.AfterDeletedViaExt = 1
  738. } else {
  739. t.Error(errors.New("cast to ProcessorsStruct failed, how can this be!?"))
  740. }
  741. }
  742. p = &ProcessorsStruct{} // reset
  743. _, err = session.ID(insertedId).Before(b4DeleteFunc).After(afterDeleteFunc).Delete(p)
  744. if err != nil {
  745. t.Error(err)
  746. panic(err)
  747. } else {
  748. if p.B4DeleteFlag == 0 {
  749. t.Error(errors.New("B4DeleteFlag not set"))
  750. }
  751. if p.AfterDeletedFlag != 0 {
  752. t.Error(errors.New("AfterDeletedFlag is set"))
  753. }
  754. if p.B4DeleteViaExt == 0 {
  755. t.Error(errors.New("B4DeleteViaExt not set"))
  756. }
  757. if p.AfterDeletedViaExt != 0 {
  758. t.Error(errors.New("AfterDeletedViaExt is set"))
  759. }
  760. }
  761. err = session.Rollback()
  762. if err != nil {
  763. t.Error(err)
  764. panic(err)
  765. } else {
  766. if p.B4DeleteFlag == 0 {
  767. t.Error(errors.New("B4DeleteFlag not set"))
  768. }
  769. if p.AfterDeletedFlag != 0 {
  770. t.Error(errors.New("AfterDeletedFlag is set"))
  771. }
  772. if p.B4DeleteViaExt == 0 {
  773. t.Error(errors.New("B4DeleteViaExt not set"))
  774. }
  775. if p.AfterDeletedViaExt != 0 {
  776. t.Error(errors.New("AfterDeletedViaExt is set"))
  777. }
  778. }
  779. session.Close()
  780. p2 = &ProcessorsStruct{}
  781. _, err = testEngine.ID(insertedId).Get(p2)
  782. if err != nil {
  783. t.Error(err)
  784. panic(err)
  785. } else {
  786. if p2.B4DeleteFlag != 0 {
  787. t.Error(errors.New("B4DeleteFlag is set"))
  788. }
  789. if p2.AfterDeletedFlag != 0 {
  790. t.Error(errors.New("AfterDeletedFlag is set"))
  791. }
  792. if p2.B4DeleteViaExt != 0 {
  793. t.Error(errors.New("B4DeleteViaExt is set"))
  794. }
  795. if p2.AfterDeletedViaExt != 0 {
  796. t.Error(errors.New("AfterDeletedViaExt is set"))
  797. }
  798. }
  799. // --
  800. // test delete processors with tx commit
  801. session = testEngine.NewSession()
  802. err = session.Begin()
  803. if err != nil {
  804. t.Error(err)
  805. panic(err)
  806. }
  807. p = &ProcessorsStruct{}
  808. _, err = session.ID(insertedId).Before(b4DeleteFunc).After(afterDeleteFunc).Delete(p)
  809. if err != nil {
  810. t.Error(err)
  811. panic(err)
  812. } else {
  813. if p.B4DeleteFlag == 0 {
  814. t.Error(errors.New("B4DeleteFlag not set"))
  815. }
  816. if p.AfterDeletedFlag != 0 {
  817. t.Error(errors.New("AfterDeletedFlag is set"))
  818. }
  819. if p.B4DeleteViaExt == 0 {
  820. t.Error(errors.New("B4DeleteViaExt not set"))
  821. }
  822. if p.AfterDeletedViaExt != 0 {
  823. t.Error(errors.New("AfterDeletedViaExt is set"))
  824. }
  825. }
  826. err = session.Commit()
  827. if err != nil {
  828. t.Error(err)
  829. panic(err)
  830. } else {
  831. if p.B4DeleteFlag == 0 {
  832. t.Error(errors.New("B4DeleteFlag not set"))
  833. }
  834. if p.AfterDeletedFlag == 0 {
  835. t.Error(errors.New("AfterDeletedFlag not set"))
  836. }
  837. if p.B4DeleteViaExt == 0 {
  838. t.Error(errors.New("B4DeleteViaExt not set"))
  839. }
  840. if p.AfterDeletedViaExt == 0 {
  841. t.Error(errors.New("AfterDeletedViaExt not set"))
  842. }
  843. }
  844. session.Close()
  845. // test delete processors with tx commit
  846. session = testEngine.NewSession()
  847. err = session.Begin()
  848. if err != nil {
  849. t.Error(err)
  850. panic(err)
  851. }
  852. p = &ProcessorsStruct{Id: insertedId}
  853. fmt.Println("delete")
  854. _, err = session.Delete(p)
  855. if err != nil {
  856. t.Error(err)
  857. panic(err)
  858. } else {
  859. if p.B4DeleteFlag == 0 {
  860. t.Error(errors.New("B4DeleteFlag not set"))
  861. }
  862. if p.AfterDeletedFlag != 0 {
  863. t.Error(errors.New("AfterDeletedFlag is set"))
  864. }
  865. }
  866. err = session.Commit()
  867. if err != nil {
  868. t.Error(err)
  869. panic(err)
  870. } else {
  871. if p.B4DeleteFlag == 0 {
  872. t.Error(errors.New("B4DeleteFlag not set"))
  873. }
  874. if p.AfterDeletedFlag == 0 {
  875. t.Error(errors.New("AfterDeletedFlag not set"))
  876. }
  877. if p.AfterInsertedFlag != 0 {
  878. t.Error(errors.New("AfterInsertedFlag set"))
  879. }
  880. if p.AfterUpdatedFlag != 0 {
  881. t.Error(errors.New("AfterUpdatedFlag set"))
  882. }
  883. }
  884. session.Close()
  885. // --
  886. }
  887. type AfterLoadStructA struct {
  888. Id int64
  889. Content string
  890. }
  891. type AfterLoadStructB struct {
  892. Id int64
  893. Content string
  894. AId int64
  895. A AfterLoadStructA `xorm:"-"`
  896. Err error `xorm:"-"`
  897. }
  898. func (s *AfterLoadStructB) AfterLoad(session *Session) {
  899. has, err := session.ID(s.AId).NoAutoCondition().Get(&s.A)
  900. if err != nil {
  901. s.Err = err
  902. return
  903. }
  904. if !has {
  905. s.Err = ErrNotExist
  906. }
  907. }
  908. func TestAfterLoadProcessor(t *testing.T) {
  909. assert.NoError(t, prepareEngine())
  910. assertSync(t, new(AfterLoadStructA), new(AfterLoadStructB))
  911. var a = AfterLoadStructA{
  912. Content: "testa",
  913. }
  914. _, err := testEngine.Insert(&a)
  915. assert.NoError(t, err)
  916. var b = AfterLoadStructB{
  917. Content: "testb",
  918. AId: a.Id,
  919. }
  920. _, err = testEngine.Insert(&b)
  921. assert.NoError(t, err)
  922. var b2 AfterLoadStructB
  923. has, err := testEngine.ID(b.Id).Get(&b2)
  924. assert.NoError(t, err)
  925. assert.True(t, has)
  926. assert.EqualValues(t, a.Id, b2.A.Id)
  927. assert.EqualValues(t, a.Content, b2.A.Content)
  928. assert.NoError(t, b2.Err)
  929. b.Id = 0
  930. _, err = testEngine.Insert(&b)
  931. assert.NoError(t, err)
  932. var bs []AfterLoadStructB
  933. err = testEngine.Find(&bs)
  934. assert.NoError(t, err)
  935. assert.EqualValues(t, 2, len(bs))
  936. for i := 0; i < len(bs); i++ {
  937. assert.EqualValues(t, a.Id, bs[i].A.Id)
  938. assert.EqualValues(t, a.Content, bs[i].A.Content)
  939. assert.NoError(t, bs[i].Err)
  940. }
  941. }