diff options
author | 2025-01-14 14:23:18 +0000 | |
---|---|---|
committer | 2025-01-14 14:23:18 +0000 | |
commit | e77c7e16b6700cdaddef3a0d8b16579173505436 (patch) | |
tree | 2b99a7bc0df2ed6f00581581bf99f39862b44303 /internal/util/puny_test.go | |
parent | [chore]: Bump mvdan.cc/xurls/v2 from 2.5.0 to 2.6.0 (#3643) (diff) | |
download | gotosocial-e77c7e16b6700cdaddef3a0d8b16579173505436.tar.xz |
[chore] better dns validation (#3644)
* add seperate PunifyValidate() function for properly validating domain names when converting to punycode
* rename function, strip port from domain validation
Diffstat (limited to 'internal/util/puny_test.go')
-rw-r--r-- | internal/util/puny_test.go | 101 |
1 files changed, 0 insertions, 101 deletions
diff --git a/internal/util/puny_test.go b/internal/util/puny_test.go deleted file mode 100644 index a0ffd30b4..000000000 --- a/internal/util/puny_test.go +++ /dev/null @@ -1,101 +0,0 @@ -// GoToSocial -// Copyright (C) GoToSocial Authors admin@gotosocial.org -// SPDX-License-Identifier: AGPL-3.0-or-later -// -// This program is free software: you can redistribute it and/or modify -// it under the terms of the GNU Affero General Public License as published by -// the Free Software Foundation, either version 3 of the License, or -// (at your option) any later version. -// -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU Affero General Public License for more details. -// -// You should have received a copy of the GNU Affero General Public License -// along with this program. If not, see <http://www.gnu.org/licenses/>. - -package util_test - -import ( - "net/url" - "strconv" - "testing" - - "github.com/stretchr/testify/suite" - "github.com/superseriousbusiness/gotosocial/internal/util" - "github.com/superseriousbusiness/gotosocial/testrig" -) - -type PunyTestSuite struct { - suite.Suite -} - -func (suite *PunyTestSuite) TestMatches() { - for i, testCase := range []struct { - expect *url.URL - actual []*url.URL - match bool - }{ - { - expect: testrig.URLMustParse("https://%D5%A9%D5%B8%D6%82%D5%A9.%D5%B0%D5%A1%D5%B5/@ankap"), - actual: []*url.URL{ - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/users/ankap"), - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/@ankap"), - }, - match: true, - }, - { - expect: testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/@ankap"), - actual: []*url.URL{ - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/users/ankap"), - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/@ankap"), - }, - match: true, - }, - { - expect: testrig.URLMustParse("https://թութ.հայ/@ankap"), - actual: []*url.URL{ - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/users/ankap"), - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/@ankap"), - }, - match: true, - }, - { - expect: testrig.URLMustParse("https://թութ.հայ/@ankap"), - actual: []*url.URL{ - testrig.URLMustParse("https://example.org/users/ankap"), - testrig.URLMustParse("https://%D5%A9%D5%B8%D6%82%D5%A9.%D5%B0%D5%A1%D5%B5/@ankap"), - }, - match: true, - }, - { - expect: testrig.URLMustParse("https://example.org/@ankap"), - actual: []*url.URL{ - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/users/ankap"), - testrig.URLMustParse("https://xn--69aa8bzb.xn--y9a3aq/@ankap"), - }, - match: false, - }, - } { - matches, err := util.URIMatches( - testCase.expect, - testCase.actual..., - ) - if err != nil { - suite.FailNow(err.Error()) - } - - if matches != testCase.match { - suite.Failf( - "case "+strconv.Itoa(i)+" matches not equal expected", - "wanted %t, got %t", - testCase.match, matches, - ) - } - } -} - -func TestPunyTestSuite(t *testing.T) { - suite.Run(t, new(PunyTestSuite)) -} |