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.

tool_test.go 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  1. package base
  2. import (
  3. "net/url"
  4. "os"
  5. "testing"
  6. "time"
  7. "code.gitea.io/gitea/modules/setting"
  8. "github.com/Unknwon/i18n"
  9. macaroni18n "github.com/go-macaron/i18n"
  10. "github.com/stretchr/testify/assert"
  11. )
  12. var BaseDate time.Time
  13. // time durations
  14. const (
  15. DayDur = 24 * time.Hour
  16. WeekDur = 7 * DayDur
  17. MonthDur = 30 * DayDur
  18. YearDur = 12 * MonthDur
  19. )
  20. func TestMain(m *testing.M) {
  21. // setup
  22. macaroni18n.I18n(macaroni18n.Options{
  23. Directory: "../../options/locale/",
  24. DefaultLang: "en-US",
  25. Langs: []string{"en-US"},
  26. Names: []string{"english"},
  27. })
  28. BaseDate = time.Date(2000, time.January, 1, 0, 0, 0, 0, time.UTC)
  29. // run the tests
  30. retVal := m.Run()
  31. os.Exit(retVal)
  32. }
  33. func TestEncodeMD5(t *testing.T) {
  34. assert.Equal(t,
  35. "3858f62230ac3c915f300c664312c63f",
  36. EncodeMD5("foobar"),
  37. )
  38. }
  39. func TestEncodeSha1(t *testing.T) {
  40. assert.Equal(t,
  41. "8843d7f92416211de9ebb963ff4ce28125932878",
  42. EncodeSha1("foobar"),
  43. )
  44. }
  45. func TestEncodeSha256(t *testing.T) {
  46. assert.Equal(t,
  47. "c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2",
  48. EncodeSha256("foobar"),
  49. )
  50. }
  51. func TestShortSha(t *testing.T) {
  52. assert.Equal(t, "veryverylo", ShortSha("veryverylong"))
  53. }
  54. func TestBasicAuthDecode(t *testing.T) {
  55. _, _, err := BasicAuthDecode("?")
  56. assert.Equal(t, "illegal base64 data at input byte 0", err.Error())
  57. user, pass, err := BasicAuthDecode("Zm9vOmJhcg==")
  58. assert.NoError(t, err)
  59. assert.Equal(t, "foo", user)
  60. assert.Equal(t, "bar", pass)
  61. }
  62. func TestBasicAuthEncode(t *testing.T) {
  63. assert.Equal(t, "Zm9vOmJhcg==", BasicAuthEncode("foo", "bar"))
  64. }
  65. // TODO: Test PBKDF2()
  66. // TODO: Test VerifyTimeLimitCode()
  67. // TODO: Test CreateTimeLimitCode()
  68. func TestHashEmail(t *testing.T) {
  69. assert.Equal(t,
  70. "d41d8cd98f00b204e9800998ecf8427e",
  71. HashEmail(""),
  72. )
  73. assert.Equal(t,
  74. "353cbad9b58e69c96154ad99f92bedc7",
  75. HashEmail("gitea@example.com"),
  76. )
  77. }
  78. const gravatarSource = "https://secure.gravatar.com/avatar/"
  79. func disableGravatar() {
  80. setting.EnableFederatedAvatar = false
  81. setting.LibravatarService = nil
  82. setting.DisableGravatar = true
  83. }
  84. func enableGravatar(t *testing.T) {
  85. setting.DisableGravatar = false
  86. var err error
  87. setting.GravatarSourceURL, err = url.Parse(gravatarSource)
  88. assert.NoError(t, err)
  89. }
  90. func TestSizedAvatarLink(t *testing.T) {
  91. disableGravatar()
  92. assert.Equal(t, "/img/avatar_default.png",
  93. SizedAvatarLink("gitea@example.com", 100))
  94. enableGravatar(t)
  95. assert.Equal(t,
  96. "https://secure.gravatar.com/avatar/353cbad9b58e69c96154ad99f92bedc7?d=identicon&s=100",
  97. SizedAvatarLink("gitea@example.com", 100),
  98. )
  99. }
  100. func TestAvatarLink(t *testing.T) {
  101. disableGravatar()
  102. assert.Equal(t, "/img/avatar_default.png", AvatarLink("gitea@example.com"))
  103. enableGravatar(t)
  104. assert.Equal(t,
  105. "https://secure.gravatar.com/avatar/353cbad9b58e69c96154ad99f92bedc7?d=identicon",
  106. AvatarLink("gitea@example.com"),
  107. )
  108. }
  109. func TestComputeTimeDiff(t *testing.T) {
  110. // test that for each offset in offsets,
  111. // computeTimeDiff(base + offset) == (offset, str)
  112. test := func(base int64, str string, offsets ...int64) {
  113. for _, offset := range offsets {
  114. diff, diffStr := computeTimeDiff(base+offset, "en")
  115. assert.Equal(t, offset, diff)
  116. assert.Equal(t, str, diffStr)
  117. }
  118. }
  119. test(0, "now", 0)
  120. test(1, "1 second", 0)
  121. test(2, "2 seconds", 0)
  122. test(Minute, "1 minute", 0, 1, 30, Minute-1)
  123. test(2*Minute, "2 minutes", 0, Minute-1)
  124. test(Hour, "1 hour", 0, 1, Hour-1)
  125. test(5*Hour, "5 hours", 0, Hour-1)
  126. test(Day, "1 day", 0, 1, Day-1)
  127. test(5*Day, "5 days", 0, Day-1)
  128. test(Week, "1 week", 0, 1, Week-1)
  129. test(3*Week, "3 weeks", 0, 4*Day+25000)
  130. test(Month, "1 month", 0, 1, Month-1)
  131. test(10*Month, "10 months", 0, Month-1)
  132. test(Year, "1 year", 0, Year-1)
  133. test(3*Year, "3 years", 0, Year-1)
  134. }
  135. func TestMinutesToFriendly(t *testing.T) {
  136. // test that a number of minutes yields the expected string
  137. test := func(expected string, minutes int) {
  138. actual := MinutesToFriendly(minutes, "en")
  139. assert.Equal(t, expected, actual)
  140. }
  141. test("1 minute", 1)
  142. test("2 minutes", 2)
  143. test("1 hour", 60)
  144. test("1 hour, 1 minute", 61)
  145. test("1 hour, 2 minutes", 62)
  146. test("2 hours", 120)
  147. }
  148. func TestTimeSince(t *testing.T) {
  149. assert.Equal(t, "now", timeSince(BaseDate, BaseDate, "en"))
  150. // test that each diff in `diffs` yields the expected string
  151. test := func(expected string, diffs ...time.Duration) {
  152. for _, diff := range diffs {
  153. actual := timeSince(BaseDate, BaseDate.Add(diff), "en")
  154. assert.Equal(t, i18n.Tr("en", "tool.ago", expected), actual)
  155. actual = timeSince(BaseDate.Add(diff), BaseDate, "en")
  156. assert.Equal(t, i18n.Tr("en", "tool.from_now", expected), actual)
  157. }
  158. }
  159. test("1 second", time.Second, time.Second+50*time.Millisecond)
  160. test("2 seconds", 2*time.Second, 2*time.Second+50*time.Millisecond)
  161. test("1 minute", time.Minute, time.Minute+30*time.Second)
  162. test("2 minutes", 2*time.Minute, 2*time.Minute+30*time.Second)
  163. test("1 hour", time.Hour, time.Hour+30*time.Minute)
  164. test("2 hours", 2*time.Hour, 2*time.Hour+30*time.Minute)
  165. test("1 day", DayDur, DayDur+12*time.Hour)
  166. test("2 days", 2*DayDur, 2*DayDur+12*time.Hour)
  167. test("1 week", WeekDur, WeekDur+3*DayDur)
  168. test("2 weeks", 2*WeekDur, 2*WeekDur+3*DayDur)
  169. test("1 month", MonthDur, MonthDur+15*DayDur)
  170. test("2 months", 2*MonthDur, 2*MonthDur+15*DayDur)
  171. test("1 year", YearDur, YearDur+6*MonthDur)
  172. test("2 years", 2*YearDur, 2*YearDur+6*MonthDur)
  173. }
  174. func TestTimeSincePro(t *testing.T) {
  175. assert.Equal(t, "now", timeSincePro(BaseDate, BaseDate, "en"))
  176. // test that a difference of `diff` yields the expected string
  177. test := func(expected string, diff time.Duration) {
  178. actual := timeSincePro(BaseDate, BaseDate.Add(diff), "en")
  179. assert.Equal(t, expected, actual)
  180. assert.Equal(t, "future", timeSincePro(BaseDate.Add(diff), BaseDate, "en"))
  181. }
  182. test("1 second", time.Second)
  183. test("2 seconds", 2*time.Second)
  184. test("1 minute", time.Minute)
  185. test("1 minute, 1 second", time.Minute+time.Second)
  186. test("1 minute, 59 seconds", time.Minute+59*time.Second)
  187. test("2 minutes", 2*time.Minute)
  188. test("1 hour", time.Hour)
  189. test("1 hour, 1 second", time.Hour+time.Second)
  190. test("1 hour, 59 minutes, 59 seconds", time.Hour+59*time.Minute+59*time.Second)
  191. test("2 hours", 2*time.Hour)
  192. test("1 day", DayDur)
  193. test("1 day, 23 hours, 59 minutes, 59 seconds",
  194. DayDur+23*time.Hour+59*time.Minute+59*time.Second)
  195. test("2 days", 2*DayDur)
  196. test("1 week", WeekDur)
  197. test("2 weeks", 2*WeekDur)
  198. test("1 month", MonthDur)
  199. test("3 months", 3*MonthDur)
  200. test("1 year", YearDur)
  201. test("2 years, 3 months, 1 week, 2 days, 4 hours, 12 minutes, 17 seconds",
  202. 2*YearDur+3*MonthDur+WeekDur+2*DayDur+4*time.Hour+
  203. 12*time.Minute+17*time.Second)
  204. }
  205. func TestHtmlTimeSince(t *testing.T) {
  206. setting.TimeFormat = time.UnixDate
  207. // test that `diff` yields a result containing `expected`
  208. test := func(expected string, diff time.Duration) {
  209. actual := htmlTimeSince(BaseDate, BaseDate.Add(diff), "en")
  210. assert.Contains(t, actual, `title="Sat Jan 1 00:00:00 UTC 2000"`)
  211. assert.Contains(t, actual, expected)
  212. }
  213. test("1 second", time.Second)
  214. test("3 minutes", 3*time.Minute+5*time.Second)
  215. test("1 day", DayDur+18*time.Hour)
  216. test("1 week", WeekDur+6*DayDur)
  217. test("3 months", 3*MonthDur+3*WeekDur)
  218. test("2 years", 2*YearDur)
  219. test("3 years", 3*YearDur+11*MonthDur+4*WeekDur)
  220. }
  221. func TestFileSize(t *testing.T) {
  222. var size int64 = 512
  223. assert.Equal(t, "512B", FileSize(size))
  224. size *= 1024
  225. assert.Equal(t, "512KB", FileSize(size))
  226. size *= 1024
  227. assert.Equal(t, "512MB", FileSize(size))
  228. size *= 1024
  229. assert.Equal(t, "512GB", FileSize(size))
  230. size *= 1024
  231. assert.Equal(t, "512TB", FileSize(size))
  232. size *= 1024
  233. assert.Equal(t, "512PB", FileSize(size))
  234. size *= 4
  235. assert.Equal(t, "2.0EB", FileSize(size))
  236. }
  237. func TestSubtract(t *testing.T) {
  238. toFloat64 := func(n interface{}) float64 {
  239. switch v := n.(type) {
  240. case int:
  241. return float64(v)
  242. case int8:
  243. return float64(v)
  244. case int16:
  245. return float64(v)
  246. case int32:
  247. return float64(v)
  248. case int64:
  249. return float64(v)
  250. case float32:
  251. return float64(v)
  252. case float64:
  253. return v
  254. default:
  255. return 0.0
  256. }
  257. }
  258. values := []interface{}{
  259. int(-3),
  260. int8(14),
  261. int16(81),
  262. int32(-156),
  263. int64(1528),
  264. float32(3.5),
  265. float64(-15.348),
  266. }
  267. for _, left := range values {
  268. for _, right := range values {
  269. expected := toFloat64(left) - toFloat64(right)
  270. sub := Subtract(left, right)
  271. assert.InDelta(t, expected, sub, 1e-3)
  272. }
  273. }
  274. }
  275. func TestEllipsisString(t *testing.T) {
  276. assert.Equal(t, "...", EllipsisString("foobar", 0))
  277. assert.Equal(t, "...", EllipsisString("foobar", 1))
  278. assert.Equal(t, "...", EllipsisString("foobar", 2))
  279. assert.Equal(t, "...", EllipsisString("foobar", 3))
  280. assert.Equal(t, "f...", EllipsisString("foobar", 4))
  281. assert.Equal(t, "fo...", EllipsisString("foobar", 5))
  282. assert.Equal(t, "foobar", EllipsisString("foobar", 6))
  283. assert.Equal(t, "foobar", EllipsisString("foobar", 10))
  284. }
  285. func TestTruncateString(t *testing.T) {
  286. assert.Equal(t, "", TruncateString("foobar", 0))
  287. assert.Equal(t, "f", TruncateString("foobar", 1))
  288. assert.Equal(t, "fo", TruncateString("foobar", 2))
  289. assert.Equal(t, "foo", TruncateString("foobar", 3))
  290. assert.Equal(t, "foob", TruncateString("foobar", 4))
  291. assert.Equal(t, "fooba", TruncateString("foobar", 5))
  292. assert.Equal(t, "foobar", TruncateString("foobar", 6))
  293. assert.Equal(t, "foobar", TruncateString("foobar", 7))
  294. }
  295. func TestStringsToInt64s(t *testing.T) {
  296. testSuccess := func(input []string, expected []int64) {
  297. result, err := StringsToInt64s(input)
  298. assert.NoError(t, err)
  299. assert.Equal(t, expected, result)
  300. }
  301. testSuccess([]string{}, []int64{})
  302. testSuccess([]string{"-1234"}, []int64{-1234})
  303. testSuccess([]string{"1", "4", "16", "64", "256"},
  304. []int64{1, 4, 16, 64, 256})
  305. _, err := StringsToInt64s([]string{"-1", "a", "$"})
  306. assert.Error(t, err)
  307. }
  308. func TestInt64sToStrings(t *testing.T) {
  309. assert.Equal(t, []string{}, Int64sToStrings([]int64{}))
  310. assert.Equal(t,
  311. []string{"1", "4", "16", "64", "256"},
  312. Int64sToStrings([]int64{1, 4, 16, 64, 256}),
  313. )
  314. }
  315. func TestInt64sToMap(t *testing.T) {
  316. assert.Equal(t, map[int64]bool{}, Int64sToMap([]int64{}))
  317. assert.Equal(t,
  318. map[int64]bool{1: true, 4: true, 16: true},
  319. Int64sToMap([]int64{1, 4, 16}),
  320. )
  321. }
  322. func TestIsLetter(t *testing.T) {
  323. assert.True(t, IsLetter('a'))
  324. assert.True(t, IsLetter('e'))
  325. assert.True(t, IsLetter('q'))
  326. assert.True(t, IsLetter('z'))
  327. assert.True(t, IsLetter('A'))
  328. assert.True(t, IsLetter('E'))
  329. assert.True(t, IsLetter('Q'))
  330. assert.True(t, IsLetter('Z'))
  331. assert.True(t, IsLetter('_'))
  332. assert.False(t, IsLetter('-'))
  333. assert.False(t, IsLetter('1'))
  334. assert.False(t, IsLetter('$'))
  335. }
  336. func TestIsTextFile(t *testing.T) {
  337. assert.True(t, IsTextFile([]byte{}))
  338. assert.True(t, IsTextFile([]byte("lorem ipsum")))
  339. }
  340. // TODO: IsImageFile(), currently no idea how to test
  341. // TODO: IsPDFFile(), currently no idea how to test