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

tool_test.go 5.6 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. package base
  2. import (
  3. "net/url"
  4. "testing"
  5. "code.gitea.io/gitea/modules/setting"
  6. "github.com/stretchr/testify/assert"
  7. )
  8. func TestEncodeMD5(t *testing.T) {
  9. assert.Equal(t,
  10. "3858f62230ac3c915f300c664312c63f",
  11. EncodeMD5("foobar"),
  12. )
  13. }
  14. func TestEncodeSha1(t *testing.T) {
  15. assert.Equal(t,
  16. "8843d7f92416211de9ebb963ff4ce28125932878",
  17. EncodeSha1("foobar"),
  18. )
  19. }
  20. func TestEncodeSha256(t *testing.T) {
  21. assert.Equal(t,
  22. "c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2",
  23. EncodeSha256("foobar"),
  24. )
  25. }
  26. func TestShortSha(t *testing.T) {
  27. assert.Equal(t, "veryverylo", ShortSha("veryverylong"))
  28. }
  29. func TestBasicAuthDecode(t *testing.T) {
  30. _, _, err := BasicAuthDecode("?")
  31. assert.Equal(t, "illegal base64 data at input byte 0", err.Error())
  32. user, pass, err := BasicAuthDecode("Zm9vOmJhcg==")
  33. assert.NoError(t, err)
  34. assert.Equal(t, "foo", user)
  35. assert.Equal(t, "bar", pass)
  36. }
  37. func TestBasicAuthEncode(t *testing.T) {
  38. assert.Equal(t, "Zm9vOmJhcg==", BasicAuthEncode("foo", "bar"))
  39. }
  40. // TODO: Test PBKDF2()
  41. // TODO: Test VerifyTimeLimitCode()
  42. // TODO: Test CreateTimeLimitCode()
  43. func TestHashEmail(t *testing.T) {
  44. assert.Equal(t,
  45. "d41d8cd98f00b204e9800998ecf8427e",
  46. HashEmail(""),
  47. )
  48. assert.Equal(t,
  49. "353cbad9b58e69c96154ad99f92bedc7",
  50. HashEmail("gitea@example.com"),
  51. )
  52. }
  53. const gravatarSource = "https://secure.gravatar.com/avatar/"
  54. func disableGravatar() {
  55. setting.EnableFederatedAvatar = false
  56. setting.LibravatarService = nil
  57. setting.DisableGravatar = true
  58. }
  59. func enableGravatar(t *testing.T) {
  60. setting.DisableGravatar = false
  61. var err error
  62. setting.GravatarSourceURL, err = url.Parse(gravatarSource)
  63. assert.NoError(t, err)
  64. }
  65. func TestSizedAvatarLink(t *testing.T) {
  66. disableGravatar()
  67. assert.Equal(t, "/img/avatar_default.png",
  68. SizedAvatarLink("gitea@example.com", 100))
  69. enableGravatar(t)
  70. assert.Equal(t,
  71. "https://secure.gravatar.com/avatar/353cbad9b58e69c96154ad99f92bedc7?d=identicon&s=100",
  72. SizedAvatarLink("gitea@example.com", 100),
  73. )
  74. }
  75. func TestFileSize(t *testing.T) {
  76. var size int64 = 512
  77. assert.Equal(t, "512 B", FileSize(size))
  78. size *= 1024
  79. assert.Equal(t, "512 KiB", FileSize(size))
  80. size *= 1024
  81. assert.Equal(t, "512 MiB", FileSize(size))
  82. size *= 1024
  83. assert.Equal(t, "512 GiB", FileSize(size))
  84. size *= 1024
  85. assert.Equal(t, "512 TiB", FileSize(size))
  86. size *= 1024
  87. assert.Equal(t, "512 PiB", FileSize(size))
  88. size *= 4
  89. assert.Equal(t, "2.0 EiB", FileSize(size))
  90. }
  91. func TestSubtract(t *testing.T) {
  92. toFloat64 := func(n interface{}) float64 {
  93. switch v := n.(type) {
  94. case int:
  95. return float64(v)
  96. case int8:
  97. return float64(v)
  98. case int16:
  99. return float64(v)
  100. case int32:
  101. return float64(v)
  102. case int64:
  103. return float64(v)
  104. case float32:
  105. return float64(v)
  106. case float64:
  107. return v
  108. default:
  109. return 0.0
  110. }
  111. }
  112. values := []interface{}{
  113. int(-3),
  114. int8(14),
  115. int16(81),
  116. int32(-156),
  117. int64(1528),
  118. float32(3.5),
  119. float64(-15.348),
  120. }
  121. for _, left := range values {
  122. for _, right := range values {
  123. expected := toFloat64(left) - toFloat64(right)
  124. sub := Subtract(left, right)
  125. assert.InDelta(t, expected, sub, 1e-3)
  126. }
  127. }
  128. }
  129. func TestEllipsisString(t *testing.T) {
  130. assert.Equal(t, "...", EllipsisString("foobar", 0))
  131. assert.Equal(t, "...", EllipsisString("foobar", 1))
  132. assert.Equal(t, "...", EllipsisString("foobar", 2))
  133. assert.Equal(t, "...", EllipsisString("foobar", 3))
  134. assert.Equal(t, "f...", EllipsisString("foobar", 4))
  135. assert.Equal(t, "fo...", EllipsisString("foobar", 5))
  136. assert.Equal(t, "foobar", EllipsisString("foobar", 6))
  137. assert.Equal(t, "foobar", EllipsisString("foobar", 10))
  138. }
  139. func TestTruncateString(t *testing.T) {
  140. assert.Equal(t, "", TruncateString("foobar", 0))
  141. assert.Equal(t, "f", TruncateString("foobar", 1))
  142. assert.Equal(t, "fo", TruncateString("foobar", 2))
  143. assert.Equal(t, "foo", TruncateString("foobar", 3))
  144. assert.Equal(t, "foob", TruncateString("foobar", 4))
  145. assert.Equal(t, "fooba", TruncateString("foobar", 5))
  146. assert.Equal(t, "foobar", TruncateString("foobar", 6))
  147. assert.Equal(t, "foobar", TruncateString("foobar", 7))
  148. }
  149. func TestStringsToInt64s(t *testing.T) {
  150. testSuccess := func(input []string, expected []int64) {
  151. result, err := StringsToInt64s(input)
  152. assert.NoError(t, err)
  153. assert.Equal(t, expected, result)
  154. }
  155. testSuccess([]string{}, []int64{})
  156. testSuccess([]string{"-1234"}, []int64{-1234})
  157. testSuccess([]string{"1", "4", "16", "64", "256"},
  158. []int64{1, 4, 16, 64, 256})
  159. _, err := StringsToInt64s([]string{"-1", "a", "$"})
  160. assert.Error(t, err)
  161. }
  162. func TestInt64sToStrings(t *testing.T) {
  163. assert.Equal(t, []string{}, Int64sToStrings([]int64{}))
  164. assert.Equal(t,
  165. []string{"1", "4", "16", "64", "256"},
  166. Int64sToStrings([]int64{1, 4, 16, 64, 256}),
  167. )
  168. }
  169. func TestInt64sToMap(t *testing.T) {
  170. assert.Equal(t, map[int64]bool{}, Int64sToMap([]int64{}))
  171. assert.Equal(t,
  172. map[int64]bool{1: true, 4: true, 16: true},
  173. Int64sToMap([]int64{1, 4, 16}),
  174. )
  175. }
  176. func TestIsLetter(t *testing.T) {
  177. assert.True(t, IsLetter('a'))
  178. assert.True(t, IsLetter('e'))
  179. assert.True(t, IsLetter('q'))
  180. assert.True(t, IsLetter('z'))
  181. assert.True(t, IsLetter('A'))
  182. assert.True(t, IsLetter('E'))
  183. assert.True(t, IsLetter('Q'))
  184. assert.True(t, IsLetter('Z'))
  185. assert.True(t, IsLetter('_'))
  186. assert.False(t, IsLetter('-'))
  187. assert.False(t, IsLetter('1'))
  188. assert.False(t, IsLetter('$'))
  189. }
  190. func TestIsTextFile(t *testing.T) {
  191. assert.True(t, IsTextFile([]byte{}))
  192. assert.True(t, IsTextFile([]byte("lorem ipsum")))
  193. }
  194. // TODO: IsImageFile(), currently no idea how to test
  195. // TODO: IsPDFFile(), currently no idea how to test