2021-12-15 21:12:40 +00:00
|
|
|
package util
|
|
|
|
|
|
|
|
import (
|
2022-12-31 21:08:49 +00:00
|
|
|
"io"
|
2022-10-08 02:22:22 +00:00
|
|
|
"net/netip"
|
2022-09-27 16:45:43 +00:00
|
|
|
"os"
|
2021-12-15 21:12:40 +00:00
|
|
|
"path/filepath"
|
2022-12-31 21:08:49 +00:00
|
|
|
"strings"
|
2021-12-15 21:12:40 +00:00
|
|
|
"testing"
|
2022-10-08 02:22:22 +00:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
2021-12-15 21:12:40 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestRandomString(t *testing.T) {
|
|
|
|
s1 := RandomString(10)
|
|
|
|
s2 := RandomString(10)
|
|
|
|
s3 := RandomString(12)
|
|
|
|
require.Equal(t, 10, len(s1))
|
|
|
|
require.Equal(t, 10, len(s2))
|
|
|
|
require.Equal(t, 12, len(s3))
|
|
|
|
require.NotEqual(t, s1, s2)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFileExists(t *testing.T) {
|
|
|
|
filename := filepath.Join(t.TempDir(), "somefile.txt")
|
2022-09-27 16:45:43 +00:00
|
|
|
require.Nil(t, os.WriteFile(filename, []byte{0x25, 0x86}, 0600))
|
2021-12-15 21:12:40 +00:00
|
|
|
require.True(t, FileExists(filename))
|
|
|
|
require.False(t, FileExists(filename+".doesnotexist"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestInStringList(t *testing.T) {
|
|
|
|
s := []string{"one", "two"}
|
2022-10-01 19:50:48 +00:00
|
|
|
require.True(t, Contains(s, "two"))
|
|
|
|
require.False(t, Contains(s, "three"))
|
2021-12-15 21:12:40 +00:00
|
|
|
}
|
2021-12-18 19:43:27 +00:00
|
|
|
|
2021-12-21 20:22:27 +00:00
|
|
|
func TestInStringListAll(t *testing.T) {
|
|
|
|
s := []string{"one", "two", "three", "four"}
|
2022-10-01 19:50:48 +00:00
|
|
|
require.True(t, ContainsAll(s, []string{"two", "four"}))
|
|
|
|
require.False(t, ContainsAll(s, []string{"three", "five"}))
|
2021-12-21 20:22:27 +00:00
|
|
|
}
|
|
|
|
|
2022-10-01 19:50:48 +00:00
|
|
|
func TestContains(t *testing.T) {
|
2021-12-22 22:45:19 +00:00
|
|
|
s := []int{1, 2}
|
2022-10-01 19:50:48 +00:00
|
|
|
require.True(t, Contains(s, 2))
|
|
|
|
require.False(t, Contains(s, 3))
|
2021-12-22 22:45:19 +00:00
|
|
|
}
|
|
|
|
|
2022-10-08 02:22:22 +00:00
|
|
|
func TestContainsIP(t *testing.T) {
|
|
|
|
require.True(t, ContainsIP([]netip.Prefix{netip.MustParsePrefix("fd00::/8"), netip.MustParsePrefix("1.1.0.0/16")}, netip.MustParseAddr("1.1.1.1")))
|
|
|
|
require.True(t, ContainsIP([]netip.Prefix{netip.MustParsePrefix("fd00::/8"), netip.MustParsePrefix("1.1.0.0/16")}, netip.MustParseAddr("fd12:1234:5678::9876")))
|
|
|
|
require.False(t, ContainsIP([]netip.Prefix{netip.MustParsePrefix("fd00::/8"), netip.MustParsePrefix("1.1.0.0/16")}, netip.MustParseAddr("1.2.0.1")))
|
|
|
|
require.False(t, ContainsIP([]netip.Prefix{netip.MustParsePrefix("fd00::/8"), netip.MustParsePrefix("1.1.0.0/16")}, netip.MustParseAddr("fc00::1")))
|
|
|
|
}
|
|
|
|
|
2021-12-21 20:22:27 +00:00
|
|
|
func TestSplitNoEmpty(t *testing.T) {
|
|
|
|
require.Equal(t, []string{}, SplitNoEmpty("", ","))
|
|
|
|
require.Equal(t, []string{}, SplitNoEmpty(",,,", ","))
|
|
|
|
require.Equal(t, []string{"tag1", "tag2"}, SplitNoEmpty("tag1,tag2", ","))
|
|
|
|
require.Equal(t, []string{"tag1", "tag2"}, SplitNoEmpty("tag1,tag2,", ","))
|
|
|
|
}
|
|
|
|
|
2021-12-19 19:27:26 +00:00
|
|
|
func TestParsePriority(t *testing.T) {
|
|
|
|
priorities := []string{"", "1", "2", "3", "4", "5", "min", "LOW", " default ", "HIgh", "max", "urgent"}
|
|
|
|
expected := []int{0, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 5}
|
|
|
|
for i, priority := range priorities {
|
|
|
|
actual, err := ParsePriority(priority)
|
|
|
|
require.Nil(t, err)
|
|
|
|
require.Equal(t, expected[i], actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestParsePriority_Invalid(t *testing.T) {
|
2022-07-01 13:28:42 +00:00
|
|
|
priorities := []string{"-1", "6", "aa", "-", "o=1"}
|
2021-12-19 19:27:26 +00:00
|
|
|
for _, priority := range priorities {
|
|
|
|
_, err := ParsePriority(priority)
|
|
|
|
require.Equal(t, errInvalidPriority, err)
|
|
|
|
}
|
|
|
|
}
|
2021-12-24 23:57:02 +00:00
|
|
|
|
2022-07-01 13:28:42 +00:00
|
|
|
func TestParsePriority_HTTPSpecPriority(t *testing.T) {
|
|
|
|
priorities := []string{"u=1", "u=3", "u=7, i"} // see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-priority
|
|
|
|
for _, priority := range priorities {
|
|
|
|
actual, err := ParsePriority(priority)
|
|
|
|
require.Nil(t, err)
|
|
|
|
require.Equal(t, 3, actual) // Always expect 3!
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-12-24 23:57:02 +00:00
|
|
|
func TestPriorityString(t *testing.T) {
|
2021-12-25 09:35:08 +00:00
|
|
|
priorities := []int{0, 1, 2, 3, 4, 5}
|
2021-12-24 23:57:02 +00:00
|
|
|
expected := []string{"default", "min", "low", "default", "high", "max"}
|
|
|
|
for i, priority := range priorities {
|
|
|
|
actual, err := PriorityString(priority)
|
|
|
|
require.Nil(t, err)
|
|
|
|
require.Equal(t, expected[i], actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPriorityString_Invalid(t *testing.T) {
|
|
|
|
_, err := PriorityString(99)
|
|
|
|
require.Equal(t, err, errInvalidPriority)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestShortTopicURL(t *testing.T) {
|
|
|
|
require.Equal(t, "ntfy.sh/mytopic", ShortTopicURL("https://ntfy.sh/mytopic"))
|
|
|
|
require.Equal(t, "ntfy.sh/mytopic", ShortTopicURL("http://ntfy.sh/mytopic"))
|
|
|
|
require.Equal(t, "lalala", ShortTopicURL("lalala"))
|
|
|
|
}
|
2022-01-06 00:04:56 +00:00
|
|
|
|
|
|
|
func TestParseSize_10GSuccess(t *testing.T) {
|
|
|
|
s, err := ParseSize("10G")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-08 17:14:43 +00:00
|
|
|
require.Equal(t, int64(10*1024*1024*1024), s)
|
2022-01-06 00:04:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseSize_10MUpperCaseSuccess(t *testing.T) {
|
|
|
|
s, err := ParseSize("10M")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-08 17:14:43 +00:00
|
|
|
require.Equal(t, int64(10*1024*1024), s)
|
2022-01-06 00:04:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseSize_10kLowerCaseSuccess(t *testing.T) {
|
|
|
|
s, err := ParseSize("10k")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-08 17:14:43 +00:00
|
|
|
require.Equal(t, int64(10*1024), s)
|
2022-01-06 00:04:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseSize_FailureInvalid(t *testing.T) {
|
|
|
|
_, err := ParseSize("not a size")
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("expected error, but got none")
|
|
|
|
}
|
|
|
|
}
|
2022-04-20 03:26:46 +00:00
|
|
|
|
|
|
|
func TestSplitKV(t *testing.T) {
|
|
|
|
key, value := SplitKV(" key = value ", "=")
|
|
|
|
require.Equal(t, "key", key)
|
|
|
|
require.Equal(t, "value", value)
|
|
|
|
|
|
|
|
key, value = SplitKV(" value ", "=")
|
|
|
|
require.Equal(t, "", key)
|
|
|
|
require.Equal(t, "value", value)
|
|
|
|
|
|
|
|
key, value = SplitKV("mykey=value=with=separator ", "=")
|
|
|
|
require.Equal(t, "mykey", key)
|
|
|
|
require.Equal(t, "value=with=separator", value)
|
|
|
|
}
|
2022-06-16 19:31:09 +00:00
|
|
|
|
|
|
|
func TestLastString(t *testing.T) {
|
|
|
|
require.Equal(t, "last", LastString([]string{"first", "second", "last"}, "default"))
|
|
|
|
require.Equal(t, "default", LastString([]string{}, "default"))
|
|
|
|
}
|
2022-06-21 03:03:16 +00:00
|
|
|
|
|
|
|
func TestQuoteCommand(t *testing.T) {
|
|
|
|
require.Equal(t, `ls -al "Document Folder"`, QuoteCommand([]string{"ls", "-al", "Document Folder"}))
|
|
|
|
require.Equal(t, `rsync -av /home/phil/ root@example.com:/home/phil/`, QuoteCommand([]string{"rsync", "-av", "/home/phil/", "root@example.com:/home/phil/"}))
|
|
|
|
require.Equal(t, `/home/sweet/home "Äöü this is a test" "\a\b"`, QuoteCommand([]string{"/home/sweet/home", "Äöü this is a test", "\\a\\b"}))
|
|
|
|
}
|
2022-12-31 21:08:49 +00:00
|
|
|
|
|
|
|
func TestBasicAuth(t *testing.T) {
|
|
|
|
require.Equal(t, "Basic cGhpbDpwaGls", BasicAuth("phil", "phil"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBearerAuth(t *testing.T) {
|
|
|
|
require.Equal(t, "Bearer sometoken", BearerAuth("sometoken"))
|
|
|
|
}
|
|
|
|
|
|
|
|
type testJSON struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Something int `json:"something"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReadJSON_Success(t *testing.T) {
|
|
|
|
v, err := UnmarshalJSON[testJSON](io.NopCloser(strings.NewReader(`{"name":"some name","something":99}`)))
|
|
|
|
require.Nil(t, err)
|
|
|
|
require.Equal(t, "some name", v.Name)
|
|
|
|
require.Equal(t, 99, v.Something)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReadJSON_Failure(t *testing.T) {
|
|
|
|
_, err := UnmarshalJSON[testJSON](io.NopCloser(strings.NewReader(`{"na`)))
|
|
|
|
require.Equal(t, ErrUnmarshalJSON, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReadJSONWithLimit_Success(t *testing.T) {
|
2023-01-28 04:10:59 +00:00
|
|
|
v, err := UnmarshalJSONWithLimit[testJSON](io.NopCloser(strings.NewReader(`{"name":"some name","something":99}`)), 100, false)
|
2022-12-31 21:08:49 +00:00
|
|
|
require.Nil(t, err)
|
|
|
|
require.Equal(t, "some name", v.Name)
|
|
|
|
require.Equal(t, 99, v.Something)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReadJSONWithLimit_FailureTooLong(t *testing.T) {
|
2023-01-28 04:10:59 +00:00
|
|
|
_, err := UnmarshalJSONWithLimit[testJSON](io.NopCloser(strings.NewReader(`{"name":"some name","something":99}`)), 10, false)
|
2022-12-31 21:08:49 +00:00
|
|
|
require.Equal(t, ErrTooLargeJSON, err)
|
|
|
|
}
|
2023-01-28 04:10:59 +00:00
|
|
|
|
|
|
|
func TestReadJSONWithLimit_AllowEmpty(t *testing.T) {
|
|
|
|
v, err := UnmarshalJSONWithLimit[testJSON](io.NopCloser(strings.NewReader(` `)), 10, true)
|
|
|
|
require.Nil(t, err)
|
|
|
|
require.Equal(t, "", v.Name)
|
|
|
|
require.Equal(t, 0, v.Something)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReadJSONWithLimit_NoAllowEmpty(t *testing.T) {
|
|
|
|
_, err := UnmarshalJSONWithLimit[testJSON](io.NopCloser(strings.NewReader(` `)), 10, false)
|
|
|
|
require.Equal(t, ErrUnmarshalJSON, err)
|
|
|
|
}
|