feed_test.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package model // import "miniflux.app/v2/internal/model"
  4. import (
  5. "fmt"
  6. "os"
  7. "testing"
  8. "time"
  9. "miniflux.app/v2/internal/config"
  10. )
  11. func TestFeedCategorySetter(t *testing.T) {
  12. feed := &Feed{}
  13. feed.WithCategoryID(int64(123))
  14. if feed.Category == nil {
  15. t.Fatal(`The category field should not be null`)
  16. }
  17. if feed.Category.ID != int64(123) {
  18. t.Error(`The category ID must be set`)
  19. }
  20. }
  21. func TestFeedErrorCounter(t *testing.T) {
  22. feed := &Feed{}
  23. feed.WithTranslatedErrorMessage("Some Error")
  24. if feed.ParsingErrorMsg != "Some Error" {
  25. t.Error(`The error message must be set`)
  26. }
  27. if feed.ParsingErrorCount != 1 {
  28. t.Error(`The error counter must be set to 1`)
  29. }
  30. feed.ResetErrorCounter()
  31. if feed.ParsingErrorMsg != "" {
  32. t.Error(`The error message must be removed`)
  33. }
  34. if feed.ParsingErrorCount != 0 {
  35. t.Error(`The error counter must be set to 0`)
  36. }
  37. }
  38. func TestFeedCheckedNow(t *testing.T) {
  39. feed := &Feed{}
  40. feed.FeedURL = "https://example.org/feed"
  41. feed.CheckedNow()
  42. if feed.SiteURL != feed.FeedURL {
  43. t.Error(`The site URL must not be empty`)
  44. }
  45. if feed.CheckedAt.IsZero() {
  46. t.Error(`The checked date must be set`)
  47. }
  48. }
  49. func TestFeedScheduleNextCheckDefault(t *testing.T) {
  50. var err error
  51. parser := config.NewParser()
  52. config.Opts, err = parser.ParseEnvironmentVariables()
  53. if err != nil {
  54. t.Fatalf(`Parsing failure: %v`, err)
  55. }
  56. feed := &Feed{}
  57. weeklyCount := 10
  58. feed.ScheduleNextCheck(weeklyCount)
  59. if feed.NextCheckAt.IsZero() {
  60. t.Error(`The next_check_at must be set`)
  61. }
  62. if feed.NextCheckAt.After(time.Now().Add(time.Minute * time.Duration(config.Opts.PollingFrequency()))) {
  63. t.Error(`The next_check_at should not be after the now + polling frequency`)
  64. }
  65. }
  66. func TestFeedScheduleNextCheckRoundRobinMinInterval(t *testing.T) {
  67. minInterval := 1
  68. os.Clearenv()
  69. os.Setenv("POLLING_SCHEDULER", "round_robin")
  70. os.Setenv("SCHEDULER_ROUND_ROBIN_MIN_INTERVAL", fmt.Sprintf("%d", minInterval))
  71. var err error
  72. parser := config.NewParser()
  73. config.Opts, err = parser.ParseEnvironmentVariables()
  74. if err != nil {
  75. t.Fatalf(`Parsing failure: %v`, err)
  76. }
  77. feed := &Feed{}
  78. weeklyCount := 100
  79. feed.ScheduleNextCheck(weeklyCount)
  80. if feed.NextCheckAt.IsZero() {
  81. t.Error(`The next_check_at must be set`)
  82. }
  83. if feed.NextCheckAt.After(time.Now().Add(time.Minute * time.Duration(minInterval))) {
  84. t.Error(`The next_check_at should not be after the now + min interval`)
  85. }
  86. }
  87. func TestFeedScheduleNextCheckEntryCountBasedMaxInterval(t *testing.T) {
  88. maxInterval := 5
  89. minInterval := 1
  90. os.Clearenv()
  91. os.Setenv("POLLING_SCHEDULER", "entry_frequency")
  92. os.Setenv("SCHEDULER_ENTRY_FREQUENCY_MAX_INTERVAL", fmt.Sprintf("%d", maxInterval))
  93. os.Setenv("SCHEDULER_ENTRY_FREQUENCY_MIN_INTERVAL", fmt.Sprintf("%d", minInterval))
  94. var err error
  95. parser := config.NewParser()
  96. config.Opts, err = parser.ParseEnvironmentVariables()
  97. if err != nil {
  98. t.Fatalf(`Parsing failure: %v`, err)
  99. }
  100. feed := &Feed{}
  101. weeklyCount := maxInterval * 100
  102. feed.ScheduleNextCheck(weeklyCount)
  103. if feed.NextCheckAt.IsZero() {
  104. t.Error(`The next_check_at must be set`)
  105. }
  106. if feed.NextCheckAt.After(time.Now().Add(time.Minute * time.Duration(maxInterval))) {
  107. t.Error(`The next_check_at should not be after the now + max interval`)
  108. }
  109. }
  110. func TestFeedScheduleNextCheckEntryCountBasedMinInterval(t *testing.T) {
  111. maxInterval := 500
  112. minInterval := 100
  113. os.Clearenv()
  114. os.Setenv("POLLING_SCHEDULER", "entry_frequency")
  115. os.Setenv("SCHEDULER_ENTRY_FREQUENCY_MAX_INTERVAL", fmt.Sprintf("%d", maxInterval))
  116. os.Setenv("SCHEDULER_ENTRY_FREQUENCY_MIN_INTERVAL", fmt.Sprintf("%d", minInterval))
  117. var err error
  118. parser := config.NewParser()
  119. config.Opts, err = parser.ParseEnvironmentVariables()
  120. if err != nil {
  121. t.Fatalf(`Parsing failure: %v`, err)
  122. }
  123. feed := &Feed{}
  124. weeklyCount := minInterval / 2
  125. feed.ScheduleNextCheck(weeklyCount)
  126. if feed.NextCheckAt.IsZero() {
  127. t.Error(`The next_check_at must be set`)
  128. }
  129. if feed.NextCheckAt.Before(time.Now().Add(time.Minute * time.Duration(minInterval))) {
  130. t.Error(`The next_check_at should not be before the now + min interval`)
  131. }
  132. }
  133. func TestFeedScheduleNextCheckEntryFrequencyFactor(t *testing.T) {
  134. factor := 2
  135. os.Clearenv()
  136. os.Setenv("POLLING_SCHEDULER", "entry_frequency")
  137. os.Setenv("SCHEDULER_ENTRY_FREQUENCY_FACTOR", fmt.Sprintf("%d", factor))
  138. var err error
  139. parser := config.NewParser()
  140. config.Opts, err = parser.ParseEnvironmentVariables()
  141. if err != nil {
  142. t.Fatalf(`Parsing failure: %v`, err)
  143. }
  144. feed := &Feed{}
  145. weeklyCount := 7
  146. feed.ScheduleNextCheck(weeklyCount)
  147. if feed.NextCheckAt.IsZero() {
  148. t.Error(`The next_check_at must be set`)
  149. }
  150. if feed.NextCheckAt.After(time.Now().Add(time.Minute * time.Duration(config.Opts.SchedulerEntryFrequencyMaxInterval()/factor))) {
  151. t.Error(`The next_check_at should not be after the now + factor * count`)
  152. }
  153. }