gitea源码

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. // Copyright 2020 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package project
  4. import (
  5. "fmt"
  6. "testing"
  7. "code.gitea.io/gitea/models/unittest"
  8. "github.com/stretchr/testify/assert"
  9. )
  10. func TestGetDefaultColumn(t *testing.T) {
  11. assert.NoError(t, unittest.PrepareTestDatabase())
  12. projectWithoutDefault, err := GetProjectByID(t.Context(), 5)
  13. assert.NoError(t, err)
  14. // check if default column was added
  15. column, err := projectWithoutDefault.MustDefaultColumn(t.Context())
  16. assert.NoError(t, err)
  17. assert.Equal(t, int64(5), column.ProjectID)
  18. assert.Equal(t, "Done", column.Title)
  19. projectWithMultipleDefaults, err := GetProjectByID(t.Context(), 6)
  20. assert.NoError(t, err)
  21. // check if multiple defaults were removed
  22. column, err = projectWithMultipleDefaults.MustDefaultColumn(t.Context())
  23. assert.NoError(t, err)
  24. assert.Equal(t, int64(6), column.ProjectID)
  25. assert.Equal(t, int64(9), column.ID) // there are 2 default columns in the test data, use the latest one
  26. // set 8 as default column
  27. assert.NoError(t, SetDefaultColumn(t.Context(), column.ProjectID, 8))
  28. // then 9 will become a non-default column
  29. column, err = GetColumn(t.Context(), 9)
  30. assert.NoError(t, err)
  31. assert.Equal(t, int64(6), column.ProjectID)
  32. assert.False(t, column.Default)
  33. }
  34. func Test_moveIssuesToAnotherColumn(t *testing.T) {
  35. assert.NoError(t, unittest.PrepareTestDatabase())
  36. column1 := unittest.AssertExistsAndLoadBean(t, &Column{ID: 1, ProjectID: 1})
  37. issues, err := column1.GetIssues(t.Context())
  38. assert.NoError(t, err)
  39. assert.Len(t, issues, 1)
  40. assert.EqualValues(t, 1, issues[0].ID)
  41. column2 := unittest.AssertExistsAndLoadBean(t, &Column{ID: 2, ProjectID: 1})
  42. issues, err = column2.GetIssues(t.Context())
  43. assert.NoError(t, err)
  44. assert.Len(t, issues, 1)
  45. assert.EqualValues(t, 3, issues[0].ID)
  46. err = column1.moveIssuesToAnotherColumn(t.Context(), column2)
  47. assert.NoError(t, err)
  48. issues, err = column1.GetIssues(t.Context())
  49. assert.NoError(t, err)
  50. assert.Empty(t, issues)
  51. issues, err = column2.GetIssues(t.Context())
  52. assert.NoError(t, err)
  53. assert.Len(t, issues, 2)
  54. assert.EqualValues(t, 3, issues[0].ID)
  55. assert.EqualValues(t, 0, issues[0].Sorting)
  56. assert.EqualValues(t, 1, issues[1].ID)
  57. assert.EqualValues(t, 1, issues[1].Sorting)
  58. }
  59. func Test_MoveColumnsOnProject(t *testing.T) {
  60. assert.NoError(t, unittest.PrepareTestDatabase())
  61. project1 := unittest.AssertExistsAndLoadBean(t, &Project{ID: 1})
  62. columns, err := project1.GetColumns(t.Context())
  63. assert.NoError(t, err)
  64. assert.Len(t, columns, 3)
  65. assert.EqualValues(t, 0, columns[0].Sorting) // even if there is no default sorting, the code should also work
  66. assert.EqualValues(t, 0, columns[1].Sorting)
  67. assert.EqualValues(t, 0, columns[2].Sorting)
  68. err = MoveColumnsOnProject(t.Context(), project1, map[int64]int64{
  69. 0: columns[1].ID,
  70. 1: columns[2].ID,
  71. 2: columns[0].ID,
  72. })
  73. assert.NoError(t, err)
  74. columnsAfter, err := project1.GetColumns(t.Context())
  75. assert.NoError(t, err)
  76. assert.Len(t, columnsAfter, 3)
  77. assert.Equal(t, columns[1].ID, columnsAfter[0].ID)
  78. assert.Equal(t, columns[2].ID, columnsAfter[1].ID)
  79. assert.Equal(t, columns[0].ID, columnsAfter[2].ID)
  80. }
  81. func Test_NewColumn(t *testing.T) {
  82. assert.NoError(t, unittest.PrepareTestDatabase())
  83. project1 := unittest.AssertExistsAndLoadBean(t, &Project{ID: 1})
  84. columns, err := project1.GetColumns(t.Context())
  85. assert.NoError(t, err)
  86. assert.Len(t, columns, 3)
  87. for i := range maxProjectColumns - 3 {
  88. err := NewColumn(t.Context(), &Column{
  89. Title: fmt.Sprintf("column-%d", i+4),
  90. ProjectID: project1.ID,
  91. })
  92. assert.NoError(t, err)
  93. }
  94. err = NewColumn(t.Context(), &Column{
  95. Title: "column-21",
  96. ProjectID: project1.ID,
  97. })
  98. assert.Error(t, err)
  99. assert.Contains(t, err.Error(), "maximum number of columns reached")
  100. }