You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

unit_tests.go 2.4KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. // Copyright 2016 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package models
  5. import (
  6. "testing"
  7. "github.com/go-xorm/core"
  8. "github.com/go-xorm/xorm"
  9. _ "github.com/mattn/go-sqlite3" // for the test engine
  10. "github.com/stretchr/testify/assert"
  11. "gopkg.in/testfixtures.v2"
  12. )
  13. // NonexistentID an ID that will never exist
  14. const NonexistentID = 9223372036854775807
  15. // CreateTestEngine create an xorm engine for testing
  16. func CreateTestEngine() error {
  17. var err error
  18. x, err = xorm.NewEngine("sqlite3", "file::memory:?cache=shared")
  19. if err != nil {
  20. return err
  21. }
  22. x.SetMapper(core.GonicMapper{})
  23. if err = x.StoreEngine("InnoDB").Sync2(tables...); err != nil {
  24. return err
  25. }
  26. return InitFixtures(&testfixtures.SQLite{}, "fixtures/")
  27. }
  28. // PrepareTestDatabase load test fixtures into test database
  29. func PrepareTestDatabase() error {
  30. return LoadFixtures()
  31. }
  32. func loadBeanIfExists(bean interface{}, conditions ...interface{}) (bool, error) {
  33. sess := x.NewSession()
  34. defer sess.Close()
  35. for _, cond := range conditions {
  36. sess = sess.Where(cond)
  37. }
  38. return sess.Get(bean)
  39. }
  40. // BeanExists for testing, check if a bean exists
  41. func BeanExists(t *testing.T, bean interface{}, conditions ...interface{}) bool {
  42. exists, err := loadBeanIfExists(bean, conditions...)
  43. assert.NoError(t, err)
  44. return exists
  45. }
  46. // AssertExistsAndLoadBean assert that a bean exists and load it from the test
  47. // database
  48. func AssertExistsAndLoadBean(t *testing.T, bean interface{}, conditions ...interface{}) interface{} {
  49. exists, err := loadBeanIfExists(bean, conditions...)
  50. assert.NoError(t, err)
  51. assert.True(t, exists,
  52. "Expected to find %+v (of type %T, with conditions %+v), but did not",
  53. bean, bean, conditions)
  54. return bean
  55. }
  56. // AssertNotExistsBean assert that a bean does not exist in the test database
  57. func AssertNotExistsBean(t *testing.T, bean interface{}, conditions ...interface{}) {
  58. exists, err := loadBeanIfExists(bean, conditions...)
  59. assert.NoError(t, err)
  60. assert.False(t, exists)
  61. }
  62. // AssertSuccessfulInsert assert that beans is successfully inserted
  63. func AssertSuccessfulInsert(t *testing.T, beans ...interface{}) {
  64. _, err := x.Insert(beans...)
  65. assert.NoError(t, err)
  66. }
  67. // AssertCount assert the count of a bean
  68. func AssertCount(t *testing.T, bean interface{}, expected interface{}) {
  69. actual, err := x.Count(bean)
  70. assert.NoError(t, err)
  71. assert.EqualValues(t, expected, actual)
  72. }