summaryrefslogtreecommitdiff
path: root/internal/util/puny_test.go
diff options
context:
space:
mode:
authorLibravatar kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com>2025-01-14 14:23:18 +0000
committerLibravatar GitHub <noreply@github.com>2025-01-14 14:23:18 +0000
commite77c7e16b6700cdaddef3a0d8b16579173505436 (patch)
tree2b99a7bc0df2ed6f00581581bf99f39862b44303 /internal/util/puny_test.go
parent[chore]: Bump mvdan.cc/xurls/v2 from 2.5.0 to 2.6.0 (#3643) (diff)
downloadgotosocial-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.go101
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))
-}