processors_test.go 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050
  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. }
  942. type AfterInsertStruct struct {
  943. Id int64
  944. }
  945. func (a *AfterInsertStruct) AfterInsert() {
  946. if a.Id == 0 {
  947. panic("a.Id")
  948. }
  949. }
  950. func TestAfterInsert(t *testing.T) {
  951. assert.NoError(t, prepareEngine())
  952. assertSync(t, new(AfterInsertStruct))
  953. _, err := testEngine.Insert(&AfterInsertStruct{})
  954. assert.NoError(t, err)
  955. }