mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-21 16:18:56 +00:00
99b7af6fc8
* fix url * modules/auth/pa: coverage: 40#.0% * modules/base coverage: 67.6% -> 89.9% * modules/cache coverage: 0% -> 12.0% * modules/convert coverage: 27.1% -> 29.7%
348 lines
11 KiB
Go
348 lines
11 KiB
Go
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package base
|
|
|
|
import (
|
|
"encoding/base64"
|
|
"os"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestEncodeMD5(t *testing.T) {
|
|
assert.Equal(t,
|
|
"3858f62230ac3c915f300c664312c63f",
|
|
EncodeMD5("foobar"),
|
|
)
|
|
}
|
|
|
|
func TestEncodeSha1(t *testing.T) {
|
|
assert.Equal(t,
|
|
"8843d7f92416211de9ebb963ff4ce28125932878",
|
|
EncodeSha1("foobar"),
|
|
)
|
|
}
|
|
|
|
func TestEncodeSha256(t *testing.T) {
|
|
assert.Equal(t,
|
|
"c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2",
|
|
EncodeSha256("foobar"),
|
|
)
|
|
}
|
|
|
|
func TestShortSha(t *testing.T) {
|
|
assert.Equal(t, "veryverylo", ShortSha("veryverylong"))
|
|
}
|
|
|
|
func TestBasicAuthDecode(t *testing.T) {
|
|
_, _, err := BasicAuthDecode("?")
|
|
assert.Equal(t, "illegal base64 data at input byte 0", err.Error())
|
|
|
|
user, pass, err := BasicAuthDecode("Zm9vOmJhcg==")
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, "foo", user)
|
|
assert.Equal(t, "bar", pass)
|
|
|
|
_, _, err = BasicAuthDecode("aW52YWxpZA==")
|
|
assert.Error(t, err)
|
|
|
|
_, _, err = BasicAuthDecode("invalid")
|
|
assert.Error(t, err)
|
|
}
|
|
|
|
func TestBasicAuthEncode(t *testing.T) {
|
|
assert.Equal(t, "Zm9vOmJhcg==", BasicAuthEncode("foo", "bar"))
|
|
assert.Equal(t, "MjM6IjotLS0t", BasicAuthEncode("23:\"", "----"))
|
|
}
|
|
|
|
func TestVerifyTimeLimitCode(t *testing.T) {
|
|
tc := []struct {
|
|
data string
|
|
minutes int
|
|
code string
|
|
valid bool
|
|
}{{
|
|
data: "data",
|
|
minutes: 2,
|
|
code: testCreateTimeLimitCode(t, "data", 2),
|
|
valid: true,
|
|
}, {
|
|
data: "abc123-ß",
|
|
minutes: 1,
|
|
code: testCreateTimeLimitCode(t, "abc123-ß", 1),
|
|
valid: true,
|
|
}, {
|
|
data: "data",
|
|
minutes: 2,
|
|
code: "2021012723240000005928251dac409d2c33a6eb82c63410aaad569bed",
|
|
valid: false,
|
|
}}
|
|
for _, test := range tc {
|
|
actualValid := VerifyTimeLimitCode(test.data, test.minutes, test.code)
|
|
assert.Equal(t, test.valid, actualValid, "data: '%s' code: '%s' should be valid: %t", test.data, test.code, test.valid)
|
|
}
|
|
}
|
|
|
|
func testCreateTimeLimitCode(t *testing.T, data string, m int) string {
|
|
result0 := CreateTimeLimitCode(data, m, nil)
|
|
result1 := CreateTimeLimitCode(data, m, time.Now().Format("200601021504"))
|
|
result2 := CreateTimeLimitCode(data, m, time.Unix(time.Now().Unix()+int64(time.Minute)*int64(m), 0).Format("200601021504"))
|
|
|
|
assert.Equal(t, result0, result1)
|
|
assert.NotEqual(t, result0, result2)
|
|
|
|
assert.True(t, len(result0) != 0)
|
|
return result0
|
|
}
|
|
|
|
func TestFileSize(t *testing.T) {
|
|
var size int64 = 512
|
|
assert.Equal(t, "512 B", FileSize(size))
|
|
size *= 1024
|
|
assert.Equal(t, "512 KiB", FileSize(size))
|
|
size *= 1024
|
|
assert.Equal(t, "512 MiB", FileSize(size))
|
|
size *= 1024
|
|
assert.Equal(t, "512 GiB", FileSize(size))
|
|
size *= 1024
|
|
assert.Equal(t, "512 TiB", FileSize(size))
|
|
size *= 1024
|
|
assert.Equal(t, "512 PiB", FileSize(size))
|
|
size *= 4
|
|
assert.Equal(t, "2.0 EiB", FileSize(size))
|
|
}
|
|
|
|
func TestPrettyNumber(t *testing.T) {
|
|
assert.Equal(t, "23,342,432", PrettyNumber(23342432))
|
|
assert.Equal(t, "0", PrettyNumber(0))
|
|
assert.Equal(t, "-100,000", PrettyNumber(-100000))
|
|
}
|
|
|
|
func TestSubtract(t *testing.T) {
|
|
toFloat64 := func(n interface{}) float64 {
|
|
switch v := n.(type) {
|
|
case int:
|
|
return float64(v)
|
|
case int8:
|
|
return float64(v)
|
|
case int16:
|
|
return float64(v)
|
|
case int32:
|
|
return float64(v)
|
|
case int64:
|
|
return float64(v)
|
|
case float32:
|
|
return float64(v)
|
|
case float64:
|
|
return v
|
|
default:
|
|
return 0.0
|
|
}
|
|
}
|
|
values := []interface{}{
|
|
int(-3),
|
|
int8(14),
|
|
int16(81),
|
|
int32(-156),
|
|
int64(1528),
|
|
float32(3.5),
|
|
float64(-15.348),
|
|
}
|
|
for _, left := range values {
|
|
for _, right := range values {
|
|
expected := toFloat64(left) - toFloat64(right)
|
|
sub := Subtract(left, right)
|
|
assert.InDelta(t, expected, sub, 1e-3)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestEllipsisString(t *testing.T) {
|
|
assert.Equal(t, "...", EllipsisString("foobar", 0))
|
|
assert.Equal(t, "...", EllipsisString("foobar", 1))
|
|
assert.Equal(t, "...", EllipsisString("foobar", 2))
|
|
assert.Equal(t, "...", EllipsisString("foobar", 3))
|
|
assert.Equal(t, "f...", EllipsisString("foobar", 4))
|
|
assert.Equal(t, "fo...", EllipsisString("foobar", 5))
|
|
assert.Equal(t, "foobar", EllipsisString("foobar", 6))
|
|
assert.Equal(t, "foobar", EllipsisString("foobar", 10))
|
|
}
|
|
|
|
func TestTruncateString(t *testing.T) {
|
|
assert.Equal(t, "", TruncateString("foobar", 0))
|
|
assert.Equal(t, "f", TruncateString("foobar", 1))
|
|
assert.Equal(t, "fo", TruncateString("foobar", 2))
|
|
assert.Equal(t, "foo", TruncateString("foobar", 3))
|
|
assert.Equal(t, "foob", TruncateString("foobar", 4))
|
|
assert.Equal(t, "fooba", TruncateString("foobar", 5))
|
|
assert.Equal(t, "foobar", TruncateString("foobar", 6))
|
|
assert.Equal(t, "foobar", TruncateString("foobar", 7))
|
|
}
|
|
|
|
func TestStringsToInt64s(t *testing.T) {
|
|
testSuccess := func(input []string, expected []int64) {
|
|
result, err := StringsToInt64s(input)
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, expected, result)
|
|
}
|
|
testSuccess([]string{}, []int64{})
|
|
testSuccess([]string{"-1234"}, []int64{-1234})
|
|
testSuccess([]string{"1", "4", "16", "64", "256"},
|
|
[]int64{1, 4, 16, 64, 256})
|
|
|
|
_, err := StringsToInt64s([]string{"-1", "a", "$"})
|
|
assert.Error(t, err)
|
|
}
|
|
|
|
func TestInt64sToStrings(t *testing.T) {
|
|
assert.Equal(t, []string{}, Int64sToStrings([]int64{}))
|
|
assert.Equal(t,
|
|
[]string{"1", "4", "16", "64", "256"},
|
|
Int64sToStrings([]int64{1, 4, 16, 64, 256}),
|
|
)
|
|
}
|
|
|
|
func TestInt64sToMap(t *testing.T) {
|
|
assert.Equal(t, map[int64]bool{}, Int64sToMap([]int64{}))
|
|
assert.Equal(t,
|
|
map[int64]bool{1: true, 4: true, 16: true},
|
|
Int64sToMap([]int64{1, 4, 16}),
|
|
)
|
|
}
|
|
|
|
func TestInt64sContains(t *testing.T) {
|
|
assert.Equal(t, map[int64]bool{}, Int64sToMap([]int64{}))
|
|
assert.Equal(t, true, Int64sContains([]int64{6, 44324, 4324, 32, 1, 2323}, 1))
|
|
assert.Equal(t, true, Int64sContains([]int64{2323}, 2323))
|
|
assert.Equal(t, false, Int64sContains([]int64{6, 44324, 4324, 32, 1, 2323}, 232))
|
|
}
|
|
|
|
func TestIsLetter(t *testing.T) {
|
|
assert.True(t, IsLetter('a'))
|
|
assert.True(t, IsLetter('e'))
|
|
assert.True(t, IsLetter('q'))
|
|
assert.True(t, IsLetter('z'))
|
|
assert.True(t, IsLetter('A'))
|
|
assert.True(t, IsLetter('E'))
|
|
assert.True(t, IsLetter('Q'))
|
|
assert.True(t, IsLetter('Z'))
|
|
assert.True(t, IsLetter('_'))
|
|
assert.False(t, IsLetter('-'))
|
|
assert.False(t, IsLetter('1'))
|
|
assert.False(t, IsLetter('$'))
|
|
assert.False(t, IsLetter(0x00))
|
|
assert.False(t, IsLetter(0x93))
|
|
}
|
|
|
|
func TestDetectContentTypeLongerThanSniffLen(t *testing.T) {
|
|
// Pre-condition: Shorter than sniffLen detects SVG.
|
|
assert.Equal(t, "image/svg+xml", DetectContentType([]byte(`<!-- Comment --><svg></svg>`)))
|
|
// Longer than sniffLen detects something else.
|
|
assert.Equal(t, "text/plain; charset=utf-8", DetectContentType([]byte(`<!--
|
|
Comment Comment Comment Comment Comment Comment Comment Comment Comment Comment
|
|
Comment Comment Comment Comment Comment Comment Comment Comment Comment Comment
|
|
Comment Comment Comment Comment Comment Comment Comment Comment Comment Comment
|
|
Comment Comment Comment Comment Comment Comment Comment Comment Comment Comment
|
|
Comment Comment Comment Comment Comment Comment Comment Comment Comment Comment
|
|
Comment Comment Comment Comment Comment Comment Comment Comment Comment Comment
|
|
Comment Comment Comment --><svg></svg>`)))
|
|
}
|
|
|
|
// IsRepresentableAsText
|
|
|
|
func TestIsTextFile(t *testing.T) {
|
|
assert.True(t, IsTextFile([]byte{}))
|
|
assert.True(t, IsTextFile([]byte("lorem ipsum")))
|
|
}
|
|
|
|
func TestIsImageFile(t *testing.T) {
|
|
png, _ := base64.StdEncoding.DecodeString("iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAG0lEQVQYlWN4+vTpf3SMDTAMBYXYBLFpHgoKAeiOf0SGE9kbAAAAAElFTkSuQmCC")
|
|
assert.True(t, IsImageFile(png))
|
|
assert.False(t, IsImageFile([]byte("plain text")))
|
|
}
|
|
|
|
func TestIsSVGImageFile(t *testing.T) {
|
|
assert.True(t, IsSVGImageFile([]byte("<svg></svg>")))
|
|
assert.True(t, IsSVGImageFile([]byte(" <svg></svg>")))
|
|
assert.True(t, IsSVGImageFile([]byte(`<svg width="100"></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte("<svg/>")))
|
|
assert.True(t, IsSVGImageFile([]byte(`<?xml version="1.0" encoding="UTF-8"?><svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<!-- Comment -->
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<!-- Multiple -->
|
|
<!-- Comments -->
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<!-- Multiline
|
|
Comment -->
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1 Basic//EN"
|
|
"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-basic.dtd">
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<?xml version="1.0" encoding="UTF-8"?>
|
|
<!-- Comment -->
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<?xml version="1.0" encoding="UTF-8"?>
|
|
<!-- Multiple -->
|
|
<!-- Comments -->
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<?xml version="1.0" encoding="UTF-8"?>
|
|
<!-- Multline
|
|
Comment -->
|
|
<svg></svg>`)))
|
|
assert.True(t, IsSVGImageFile([]byte(`<?xml version="1.0" encoding="UTF-8"?>
|
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
|
<!-- Multline
|
|
Comment -->
|
|
<svg></svg>`)))
|
|
assert.False(t, IsSVGImageFile([]byte{}))
|
|
assert.False(t, IsSVGImageFile([]byte("svg")))
|
|
assert.False(t, IsSVGImageFile([]byte("<svgfoo></svgfoo>")))
|
|
assert.False(t, IsSVGImageFile([]byte("text<svg></svg>")))
|
|
assert.False(t, IsSVGImageFile([]byte("<html><body><svg></svg></body></html>")))
|
|
assert.False(t, IsSVGImageFile([]byte(`<script>"<svg></svg>"</script>`)))
|
|
assert.False(t, IsSVGImageFile([]byte(`<!-- <svg></svg> inside comment -->
|
|
<foo></foo>`)))
|
|
assert.False(t, IsSVGImageFile([]byte(`<?xml version="1.0" encoding="UTF-8"?>
|
|
<!-- <svg></svg> inside comment -->
|
|
<foo></foo>`)))
|
|
}
|
|
|
|
func TestIsPDFFile(t *testing.T) {
|
|
pdf, _ := base64.StdEncoding.DecodeString("JVBERi0xLjYKJcOkw7zDtsOfCjIgMCBvYmoKPDwvTGVuZ3RoIDMgMCBSL0ZpbHRlci9GbGF0ZURlY29kZT4+CnN0cmVhbQp4nF3NPwsCMQwF8D2f4s2CNYk1baF0EHRwOwg4iJt/NsFb/PpevUE4Mjwe")
|
|
assert.True(t, IsPDFFile(pdf))
|
|
assert.False(t, IsPDFFile([]byte("plain text")))
|
|
}
|
|
|
|
func TestIsVideoFile(t *testing.T) {
|
|
mp4, _ := base64.StdEncoding.DecodeString("AAAAGGZ0eXBtcDQyAAAAAGlzb21tcDQyAAEI721vb3YAAABsbXZoZAAAAADaBlwX2gZcFwAAA+gA")
|
|
assert.True(t, IsVideoFile(mp4))
|
|
assert.False(t, IsVideoFile([]byte("plain text")))
|
|
}
|
|
|
|
func TestIsAudioFile(t *testing.T) {
|
|
mp3, _ := base64.StdEncoding.DecodeString("SUQzBAAAAAABAFRYWFgAAAASAAADbWFqb3JfYnJhbmQAbXA0MgBUWFhYAAAAEQAAA21pbm9yX3Zl")
|
|
assert.True(t, IsAudioFile(mp3))
|
|
assert.False(t, IsAudioFile([]byte("plain text")))
|
|
}
|
|
|
|
// TODO: Test EntryIcon
|
|
|
|
func TestSetupGiteaRoot(t *testing.T) {
|
|
_ = os.Setenv("GITEA_ROOT", "test")
|
|
assert.EqualValues(t, "test", SetupGiteaRoot())
|
|
_ = os.Setenv("GITEA_ROOT", "")
|
|
assert.NotEqual(t, "test", SetupGiteaRoot())
|
|
}
|
|
|
|
func TestFormatNumberSI(t *testing.T) {
|
|
assert.Equal(t, "125", FormatNumberSI(int(125)))
|
|
assert.Equal(t, "1.3k", FormatNumberSI(int64(1317)))
|
|
assert.Equal(t, "21.3M", FormatNumberSI(21317675))
|
|
assert.Equal(t, "45.7G", FormatNumberSI(45721317675))
|
|
assert.Equal(t, "", FormatNumberSI("test"))
|
|
}
|