task_queue_test.go 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. package task_queue
  2. import (
  3. "github.com/allanpk716/ChineseSubFinder/internal/pkg/log_helper"
  4. "github.com/allanpk716/ChineseSubFinder/internal/pkg/settings"
  5. "github.com/allanpk716/ChineseSubFinder/internal/types/common"
  6. "github.com/allanpk716/ChineseSubFinder/internal/types/task_queue"
  7. "github.com/davecgh/go-spew/spew"
  8. "testing"
  9. )
  10. func TestTaskQueue_AddAndGetAndDel(t *testing.T) {
  11. defer func() {
  12. DelDb()
  13. }()
  14. DelDb()
  15. taskQueue := NewTaskQueue("testQueue", settings.NewSettings(), log_helper.GetLogger())
  16. for i := taskPriorityCount; i >= 0; i-- {
  17. bok, err := taskQueue.Add(*task_queue.NewOneJob(common.Movie, "", i))
  18. if err != nil {
  19. t.Fatal("TestTaskQueue.Add", err)
  20. }
  21. if bok == false {
  22. t.Fatal("TestTaskQueue.Add == false")
  23. }
  24. }
  25. bok, waitingJobs, err := taskQueue.Get(task_queue.Waiting)
  26. if err != nil {
  27. t.Fatal("TestTaskQueue.Get", err)
  28. }
  29. if bok == false {
  30. t.Fatal("TestTaskQueue.Get == false")
  31. }
  32. if len(waitingJobs) != taskPriorityCount+1 {
  33. t.Fatal("len(waitingJobs) != taskPriorityCount")
  34. }
  35. for i := 0; i <= taskPriorityCount; i++ {
  36. if waitingJobs[i].TaskPriority != i {
  37. t.Fatalf("TestTaskQueue.TaskPriority pop error, want = %d, got = %d", i, waitingJobs[i].TaskPriority)
  38. }
  39. }
  40. for _, waitingJob := range waitingJobs {
  41. bok, err = taskQueue.Del(waitingJob.Id)
  42. if err != nil {
  43. t.Fatal("TestTaskQueue.Del", err)
  44. }
  45. if bok == false {
  46. t.Fatal("TestTaskQueue.Del == false")
  47. }
  48. }
  49. if taskQueue.Size() != 0 {
  50. t.Fatal("taskQueue.Size() != 0")
  51. }
  52. }
  53. func TestTaskQueue_AddAndClear(t *testing.T) {
  54. defer func() {
  55. DelDb()
  56. }()
  57. DelDb()
  58. taskQueue := NewTaskQueue("testQueue", settings.NewSettings(), log_helper.GetLogger())
  59. for i := taskPriorityCount; i >= 0; i-- {
  60. bok, err := taskQueue.Add(*task_queue.NewOneJob(common.Movie, "", i))
  61. if err != nil {
  62. t.Fatal("TestTaskQueue.Add", err)
  63. }
  64. if bok == false {
  65. t.Fatal("TestTaskQueue.Add == false")
  66. }
  67. }
  68. err := taskQueue.Clear()
  69. if err != nil {
  70. t.Fatal("TestTaskQueue.Clear", err)
  71. }
  72. if taskQueue.Size() != 0 {
  73. t.Fatal("taskQueue.Size() != 0")
  74. }
  75. }
  76. func TestTaskQueue_Update(t *testing.T) {
  77. defer func() {
  78. DelDb()
  79. }()
  80. DelDb()
  81. taskQueue := NewTaskQueue("testQueue", settings.NewSettings(), log_helper.GetLogger())
  82. for i := taskPriorityCount; i >= 0; i-- {
  83. bok, err := taskQueue.Add(*task_queue.NewOneJob(common.Movie, "", i))
  84. if err != nil {
  85. t.Fatal("TestTaskQueue.Add", err)
  86. }
  87. if bok == false {
  88. t.Fatal("TestTaskQueue.Add == false")
  89. }
  90. }
  91. bok, waitingJobs, err := taskQueue.Get(task_queue.Waiting)
  92. if err != nil {
  93. t.Fatal("TestTaskQueue.Get", err)
  94. }
  95. if bok == false {
  96. t.Fatal("TestTaskQueue.Get == false")
  97. }
  98. if len(waitingJobs) != taskPriorityCount+1 {
  99. t.Fatal("len(waitingJobs) != taskPriorityCount")
  100. }
  101. for i := 0; i <= taskPriorityCount; i++ {
  102. if waitingJobs[i].TaskPriority != i {
  103. t.Fatalf("TestTaskQueue.TaskPriority pop error, want = %d, got = %d", i, waitingJobs[i].TaskPriority)
  104. }
  105. }
  106. for _, waitingJob := range waitingJobs {
  107. waitingJob.JobStatus = task_queue.Committed
  108. bok, err = taskQueue.Update(waitingJob)
  109. if err != nil {
  110. t.Fatal("TestTaskQueue.Update", err)
  111. }
  112. if bok == false {
  113. t.Fatal("TestTaskQueue.Update == false")
  114. }
  115. }
  116. bok, commitedJobs, err := taskQueue.Get(task_queue.Committed)
  117. if err != nil {
  118. t.Fatal("TestTaskQueue.Get", err)
  119. }
  120. if bok == false {
  121. t.Fatal("TestTaskQueue.Get == false")
  122. }
  123. if len(commitedJobs) != taskPriorityCount+1 {
  124. t.Fatal("len(commitedJobs) != taskPriorityCount")
  125. }
  126. }
  127. func TestTaskQueue_UpdateAdGetOneWaiting(t *testing.T) {
  128. defer func() {
  129. DelDb()
  130. }()
  131. DelDb()
  132. taskQueue := NewTaskQueue("testQueue", settings.NewSettings(), log_helper.GetLogger())
  133. for i := taskPriorityCount; i >= 0; i-- {
  134. bok, err := taskQueue.Add(*task_queue.NewOneJob(common.Movie, spew.Sprintf("%d", i), i))
  135. if err != nil {
  136. t.Fatal("TestTaskQueue.Add", err)
  137. }
  138. if bok == false {
  139. t.Fatal("TestTaskQueue.Add == false")
  140. }
  141. }
  142. bok, waitingJob, err := taskQueue.GetOneWaiting()
  143. if err != nil {
  144. t.Fatal("TestTaskQueue.GetOneWaiting", err)
  145. }
  146. if bok == false {
  147. t.Fatal("TestTaskQueue.GetOneWaiting == false")
  148. }
  149. if waitingJob.TaskPriority != 0 {
  150. t.Fatal("waitingJob.TaskPriority != 0")
  151. }
  152. waitingJob.JobStatus = task_queue.Committed
  153. bok, err = taskQueue.Update(waitingJob)
  154. if err != nil {
  155. t.Fatal("TestTaskQueue.Update", err)
  156. }
  157. if bok == false {
  158. t.Fatal("TestTaskQueue.Update == false")
  159. }
  160. bok, waitingJob, err = taskQueue.GetOneWaiting()
  161. if err != nil {
  162. t.Fatal("TestTaskQueue.GetOneWaiting", err)
  163. }
  164. if bok == false {
  165. t.Fatal("TestTaskQueue.GetOneWaiting == false")
  166. }
  167. if waitingJob.TaskPriority != 1 {
  168. t.Fatal("waitingJob.TaskPriority != 0")
  169. }
  170. }
  171. func TestTaskQueue_UpdatePriority(t *testing.T) {
  172. defer func() {
  173. DelDb()
  174. }()
  175. DelDb()
  176. taskQueue := NewTaskQueue("testQueue", settings.NewSettings(), log_helper.GetLogger())
  177. for i := taskPriorityCount; i >= 0; i-- {
  178. bok, err := taskQueue.Add(*task_queue.NewOneJob(common.Movie, spew.Sprintf("%d", i), i))
  179. if err != nil {
  180. t.Fatal("TestTaskQueue.Add", err)
  181. }
  182. if bok == false {
  183. t.Fatal("TestTaskQueue.Add == false")
  184. }
  185. }
  186. bok, waitingJob, err := taskQueue.GetOneWaiting()
  187. if err != nil {
  188. t.Fatal("TestTaskQueue.GetOneWaiting", err)
  189. }
  190. if bok == false {
  191. t.Fatal("TestTaskQueue.GetOneWaiting == false")
  192. }
  193. if waitingJob.TaskPriority != 0 {
  194. t.Fatal("waitingJob.TaskPriority != 0")
  195. }
  196. waitingJob.TaskPriority = 1
  197. bok, err = taskQueue.Update(waitingJob)
  198. if err != nil {
  199. t.Fatal("TestTaskQueue.Update", err)
  200. }
  201. if bok == false {
  202. t.Fatal("TestTaskQueue.Update == false")
  203. }
  204. bok, waitingJobs, err := taskQueue.GetTaskPriority(0, task_queue.Waiting)
  205. if err != nil {
  206. t.Fatal("TestTaskQueue.GetTaskPriority", err)
  207. }
  208. if bok == false {
  209. t.Fatal("TestTaskQueue.GetTaskPriority == false")
  210. }
  211. if len(waitingJobs) != 0 {
  212. t.Fatal("len(waitingJobs) != 0")
  213. }
  214. bok, waitingJobs, err = taskQueue.GetTaskPriority(1, task_queue.Waiting)
  215. if err != nil {
  216. t.Fatal("TestTaskQueue.GetTaskPriority", err)
  217. }
  218. if bok == false {
  219. t.Fatal("TestTaskQueue.GetTaskPriority == false")
  220. }
  221. if len(waitingJobs) != 2 {
  222. t.Fatal("len(waitingJobs) != 2")
  223. }
  224. }