diff options
Diffstat (limited to 'src/net/mail/message_test.go')
-rw-r--r-- | src/net/mail/message_test.go | 40 |
1 files changed, 29 insertions, 11 deletions
diff --git a/src/net/mail/message_test.go b/src/net/mail/message_test.go index 1e1bb4092f..1f2f62afbf 100644 --- a/src/net/mail/message_test.go +++ b/src/net/mail/message_test.go @@ -385,8 +385,11 @@ func TestAddressParsingError(t *testing.T) { 13: {"group not closed: null@example.com", "expected comma"}, 14: {"group: first@example.com, second@example.com;", "group with multiple addresses"}, 15: {"john.doe", "missing '@' or angle-addr"}, - 16: {"john.doe@", "no angle-addr"}, + 16: {"john.doe@", "missing '@' or angle-addr"}, 17: {"John Doe@foo.bar", "no angle-addr"}, + 18: {" group: null@example.com; (asd", "misformatted parenthetical comment"}, + 19: {" group: ; (asd", "misformatted parenthetical comment"}, + 20: {`(John) Doe <jdoe@machine.example>`, "missing word in phrase:"}, } for i, tc := range mustErrTestCases { @@ -436,24 +439,19 @@ func TestAddressParsing(t *testing.T) { Address: "john.q.public@example.com", }}, }, - { - `"John (middle) Doe" <jdoe@machine.example>`, - []*Address{{ - Name: "John (middle) Doe", - Address: "jdoe@machine.example", - }}, - }, + // Comment in display name { `John (middle) Doe <jdoe@machine.example>`, []*Address{{ - Name: "John (middle) Doe", + Name: "John Doe", Address: "jdoe@machine.example", }}, }, + // Display name is quoted string, so comment is not a comment { - `John !@M@! Doe <jdoe@machine.example>`, + `"John (middle) Doe" <jdoe@machine.example>`, []*Address{{ - Name: "John !@M@! Doe", + Name: "John (middle) Doe", Address: "jdoe@machine.example", }}, }, @@ -788,6 +786,26 @@ func TestAddressParsing(t *testing.T) { }, }, }, + // Comment in group display name + { + `group (comment:): a@example.com, b@example.com;`, + []*Address{ + { + Address: "a@example.com", + }, + { + Address: "b@example.com", + }, + }, + }, + { + `x(:"):"@a.example;("@b.example;`, + []*Address{ + { + Address: `@a.example;(@b.example`, + }, + }, + }, } for _, test := range tests { if len(test.exp) == 1 { |