rows_test.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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. "testing"
  7. "github.com/stretchr/testify/assert"
  8. )
  9. func TestRows(t *testing.T) {
  10. assert.NoError(t, prepareEngine())
  11. type UserRows struct {
  12. Id int64
  13. IsMan bool
  14. }
  15. assert.NoError(t, testEngine.Sync2(new(UserRows)))
  16. cnt, err := testEngine.Insert(&UserRows{
  17. IsMan: true,
  18. })
  19. assert.NoError(t, err)
  20. assert.EqualValues(t, 1, cnt)
  21. rows, err := testEngine.Rows(new(UserRows))
  22. assert.NoError(t, err)
  23. defer rows.Close()
  24. cnt = 0
  25. user := new(UserRows)
  26. for rows.Next() {
  27. err = rows.Scan(user)
  28. assert.NoError(t, err)
  29. cnt++
  30. }
  31. assert.EqualValues(t, 1, cnt)
  32. sess := testEngine.NewSession()
  33. defer sess.Close()
  34. rows1, err := sess.Prepare().Rows(new(UserRows))
  35. assert.NoError(t, err)
  36. defer rows1.Close()
  37. cnt = 0
  38. for rows1.Next() {
  39. err = rows1.Scan(user)
  40. assert.NoError(t, err)
  41. cnt++
  42. }
  43. assert.EqualValues(t, 1, cnt)
  44. var tbName = testEngine.Quote(testEngine.TableName(user, true))
  45. rows2, err := testEngine.SQL("SELECT * FROM " + tbName).Rows(new(UserRows))
  46. assert.NoError(t, err)
  47. defer rows2.Close()
  48. cnt = 0
  49. for rows2.Next() {
  50. err = rows2.Scan(user)
  51. assert.NoError(t, err)
  52. cnt++
  53. }
  54. assert.EqualValues(t, 1, cnt)
  55. }
  56. func TestRowsMyTableName(t *testing.T) {
  57. assert.NoError(t, prepareEngine())
  58. type UserRowsMyTable struct {
  59. Id int64
  60. IsMan bool
  61. }
  62. var tableName = "user_rows_my_table_name"
  63. assert.NoError(t, testEngine.Table(tableName).Sync2(new(UserRowsMyTable)))
  64. cnt, err := testEngine.Table(tableName).Insert(&UserRowsMyTable{
  65. IsMan: true,
  66. })
  67. assert.NoError(t, err)
  68. assert.EqualValues(t, 1, cnt)
  69. rows, err := testEngine.Table(tableName).Rows(new(UserRowsMyTable))
  70. assert.NoError(t, err)
  71. defer rows.Close()
  72. cnt = 0
  73. user := new(UserRowsMyTable)
  74. for rows.Next() {
  75. err = rows.Scan(user)
  76. assert.NoError(t, err)
  77. cnt++
  78. }
  79. assert.EqualValues(t, 1, cnt)
  80. }
  81. type UserRowsSpecTable struct {
  82. Id int64
  83. IsMan bool
  84. }
  85. func (UserRowsSpecTable) TableName() string {
  86. return "user_rows_my_table_name"
  87. }
  88. func TestRowsSpecTableName(t *testing.T) {
  89. assert.NoError(t, prepareEngine())
  90. assert.NoError(t, testEngine.Sync2(new(UserRowsSpecTable)))
  91. cnt, err := testEngine.Insert(&UserRowsSpecTable{
  92. IsMan: true,
  93. })
  94. assert.NoError(t, err)
  95. assert.EqualValues(t, 1, cnt)
  96. rows, err := testEngine.Rows(new(UserRowsSpecTable))
  97. assert.NoError(t, err)
  98. defer rows.Close()
  99. cnt = 0
  100. user := new(UserRowsSpecTable)
  101. for rows.Next() {
  102. err = rows.Scan(user)
  103. assert.NoError(t, err)
  104. cnt++
  105. }
  106. assert.EqualValues(t, 1, cnt)
  107. }