// Copyright 2018 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 util import ( "strings" "testing" "code.gitea.io/gitea/modules/setting" "github.com/stretchr/testify/assert" ) func TestURLJoin(t *testing.T) { type test struct { Expected string Base string Elements []string } newTest := func(expected, base string, elements ...string) test { return test{Expected: expected, Base: base, Elements: elements} } for _, test := range []test{ newTest("https://try.gitea.io/a/b/c", "https://try.gitea.io", "a/b", "c"), newTest("https://try.gitea.io/a/b/c", "https://try.gitea.io/", "/a/b/", "/c/"), newTest("https://try.gitea.io/a/c", "https://try.gitea.io/", "/a/./b/", "../c/"), newTest("a/b/c", "a", "b/c/"), newTest("a/b/d", "a/", "b/c/", "/../d/"), newTest("https://try.gitea.io/a/b/c#d", "https://try.gitea.io", "a/b", "c#d"), newTest("/a/b/d", "/a/", "b/c/", "/../d/"), newTest("/a/b/c", "/a", "b/c/"), newTest("/a/b/c#hash", "/a", "b/c#hash"), } { assert.Equal(t, test.Expected, URLJoin(test.Base, test.Elements...)) } } func TestIsExternalURL(t *testing.T) { setting.AppURL = "https://try.gitea.io" type test struct { Expected bool RawURL string } newTest := func(expected bool, rawURL string) test { return test{Expected: expected, RawURL: rawURL} } for _, test := range []test{ newTest(false, "https://try.gitea.io"), newTest(true, "https://example.com/"), newTest(true, "//example.com"), newTest(true, "http://example.com"), newTest(false, "a/"), newTest(false, "https://try.gitea.io/test?param=false"), newTest(false, "test?param=false"), newTest(false, "//try.gitea.io/test?param=false"), newTest(false, "/hey/hey/hey#3244"), } { assert.Equal(t, test.Expected, IsExternalURL(test.RawURL)) } } func TestIsEmptyString(t *testing.T) { cases := []struct { s string expected bool }{ {"", true}, {" ", true}, {" ", true}, {" a", false}, } for _, v := range cases { assert.Equal(t, v.expected, IsEmptyString(v.s)) } } func Test_NormalizeEOL(t *testing.T) { data1 := []string{ "", "This text starts with empty lines", "another", "", "", "", "Some other empty lines in the middle", "more.", "And more.", "Ends with empty lines too.", "", "", "", } data2 := []string{ "This text does not start with empty lines", "another", "", "", "", "Some other empty lines in the middle", "more.", "And more.", "Ends without EOLtoo.", } buildEOLData := func(data []string, eol string) []byte { return []byte(strings.Join(data, eol)) } dos := buildEOLData(data1, "\r\n") unix := buildEOLData(data1, "\n") mac := buildEOLData(data1, "\r") assert.Equal(t, unix, NormalizeEOL(dos)) assert.Equal(t, unix, NormalizeEOL(mac)) assert.Equal(t, unix, NormalizeEOL(unix)) dos = buildEOLData(data2, "\r\n") unix = buildEOLData(data2, "\n") mac = buildEOLData(data2, "\r") assert.Equal(t, unix, NormalizeEOL(dos)) assert.Equal(t, unix, NormalizeEOL(mac)) assert.Equal(t, unix, NormalizeEOL(unix)) assert.Equal(t, []byte("one liner"), NormalizeEOL([]byte("one liner"))) assert.Equal(t, []byte("\n"), NormalizeEOL([]byte("\n"))) assert.Equal(t, []byte("\ntwo liner"), NormalizeEOL([]byte("\ntwo liner"))) assert.Equal(t, []byte("two liner\n"), NormalizeEOL([]byte("two liner\n"))) assert.Equal(t, []byte{}, NormalizeEOL([]byte{})) assert.Equal(t, []byte("mix\nand\nmatch\n."), NormalizeEOL([]byte("mix\r\nand\rmatch\n."))) } upport_to_query_builder Nextcloud server, a safe home for all your data: https://github.com/nextcloud/serverwww-data
summaryrefslogtreecommitdiffstats
path: root/lib/private/Memcache/CADTrait.php
blob: e45e9d28fd1b751147d878c8134b3573f1ab1b11 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54