diff --git a/typeparams/normalize_test.go b/typeparams/normalize_test.go index dd47b57c2..98f7ec46c 100644 --- a/typeparams/normalize_test.go +++ b/typeparams/normalize_test.go @@ -9,6 +9,7 @@ import ( "go/parser" "go/token" "go/types" + "regexp" "strings" "testing" @@ -36,7 +37,7 @@ func TestNormalTerms(t *testing.T) { {"package emptyintersection; type T[P interface{ ~int; string }] int", "", "empty type set"}, {"package embedded0; type T[P interface{ I }] int; type I interface { int }", "int", ""}, - {"package embedded1; type T[P interface{ I | string }] int; type I interface{ int | ~string }", "int|~string", ""}, + {"package embedded1; type T[P interface{ I | string }] int; type I interface{ int | ~string }", "int ?\\| ?~string", ""}, {"package embedded2; type T[P interface{ I; string }] int; type I interface{ int | ~string }", "string", ""}, {"package named; type T[P C] int; type C interface{ ~int|int }", "~int", ""}, @@ -50,7 +51,7 @@ type B interface{ int|string } type C interface { ~string|~int } type T[P interface{ A|B; C }] int -`, "~string|int", ""}, +`, "~string ?\\| ?int", ""}, } for _, test := range tests { @@ -94,8 +95,9 @@ type T[P interface{ A|B; C }] int qf := types.RelativeTo(pkg) got = types.TypeString(NewUnion(terms), qf) } - if got != test.want { - t.Errorf("StructuralTerms(%s) = %q, want %q", T, got, test.want) + want := regexp.MustCompile(test.want) + if !want.MatchString(got) { + t.Errorf("NormalTerms(%s) = %q, want matching %q", T, got, test.want) } }) }