mirror of
https://github.com/mjl-/mox.git
synced 2025-01-15 01:46:26 +03:00
78 lines
2.6 KiB
Go
78 lines
2.6 KiB
Go
|
package imapserver
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/mjl-/mox/imapclient"
|
||
|
)
|
||
|
|
||
|
func TestAppend(t *testing.T) {
|
||
|
defer mockUIDValidity()()
|
||
|
|
||
|
tc := start(t) // note: with switchboard because this connection stays alive unlike tc2.
|
||
|
defer tc.close()
|
||
|
|
||
|
tc2 := startNoSwitchboard(t) // note: without switchboard because this connection will break during tests.
|
||
|
defer tc2.close()
|
||
|
|
||
|
tc3 := startNoSwitchboard(t)
|
||
|
defer tc3.close()
|
||
|
|
||
|
tc2.client.Login("mjl@mox.example", "testtest")
|
||
|
tc2.client.Select("inbox")
|
||
|
tc.client.Login("mjl@mox.example", "testtest")
|
||
|
tc.client.Select("inbox")
|
||
|
tc3.client.Login("mjl@mox.example", "testtest")
|
||
|
|
||
|
tc2.transactf("bad", "append") // Missing params.
|
||
|
tc2.transactf("bad", `append inbox`) // Missing message.
|
||
|
tc2.transactf("bad", `append inbox "test"`) // Message must be literal.
|
||
|
|
||
|
// Syntax error for line ending in literal causes connection abort.
|
||
|
tc2.transactf("bad", "append inbox (\\Badflag) {1+}\r\nx") // Unknown flag.
|
||
|
tc2 = startNoSwitchboard(t)
|
||
|
defer tc2.close()
|
||
|
tc2.client.Login("mjl@mox.example", "testtest")
|
||
|
tc2.client.Select("inbox")
|
||
|
|
||
|
tc2.transactf("bad", "append inbox () \"bad time\" {1+}\r\nx") // Bad time.
|
||
|
tc2 = startNoSwitchboard(t)
|
||
|
defer tc2.close()
|
||
|
tc2.client.Login("mjl@mox.example", "testtest")
|
||
|
tc2.client.Select("inbox")
|
||
|
|
||
|
tc2.transactf("no", "append nobox (\\Seen) \" 1-Jan-2022 10:10:00 +0100\" {1}")
|
||
|
tc2.xcode("TRYCREATE")
|
||
|
|
||
|
tc2.transactf("ok", "append inbox (\\Seen) \" 1-Jan-2022 10:10:00 +0100\" {1+}\r\nx")
|
||
|
tc2.xuntagged(imapclient.UntaggedExists(1))
|
||
|
tc2.xcodeArg(imapclient.CodeAppendUID{UIDValidity: 1, UID: 1})
|
||
|
|
||
|
tc.transactf("ok", "noop")
|
||
|
uid1 := imapclient.FetchUID(1)
|
||
|
flagsSeen := imapclient.FetchFlags{`\Seen`}
|
||
|
tc.xuntagged(imapclient.UntaggedExists(1), imapclient.UntaggedFetch{Seq: 1, Attrs: []imapclient.FetchAttr{uid1, flagsSeen}})
|
||
|
tc3.transactf("ok", "noop")
|
||
|
tc3.xuntagged() // Inbox is not selected, nothing to report.
|
||
|
|
||
|
tc2.transactf("ok", "append inbox (\\Seen) \" 1-Jan-2022 10:10:00 +0100\" UTF8 ({34+}\r\ncontent-type: text/plain;;\r\n\r\ntest)")
|
||
|
tc2.xuntagged(imapclient.UntaggedExists(2))
|
||
|
tc2.xcodeArg(imapclient.CodeAppendUID{UIDValidity: 1, UID: 2})
|
||
|
|
||
|
// Messages that we cannot parse are marked as application/octet-stream. Perhaps
|
||
|
// the imap client knows how to deal with them.
|
||
|
tc2.transactf("ok", "uid fetch 2 body")
|
||
|
uid2 := imapclient.FetchUID(2)
|
||
|
xbs := imapclient.FetchBodystructure{
|
||
|
RespAttr: "BODY",
|
||
|
Body: imapclient.BodyTypeBasic{
|
||
|
MediaType: "APPLICATION",
|
||
|
MediaSubtype: "OCTET-STREAM",
|
||
|
BodyFields: imapclient.BodyFields{
|
||
|
Octets: 4,
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
tc2.xuntagged(imapclient.UntaggedFetch{Seq: 2, Attrs: []imapclient.FetchAttr{uid2, xbs}})
|
||
|
}
|