Fixing to have the proper version of go-imap from foxcpp.

This commit is contained in:
2025-12-08 22:52:36 +02:00
parent d8ddb6be71
commit 226c7e6cf0
207 changed files with 15166 additions and 15437 deletions

129
server/cmd_any_test.go Normal file
View File

@@ -0,0 +1,129 @@
package server_test
import (
"bufio"
"io"
"net"
"strings"
"testing"
"github.com/emersion/go-imap/server"
"github.com/emersion/go-sasl"
)
func testServerGreeted(t *testing.T) (s *server.Server, c net.Conn, scanner *bufio.Scanner) {
s, c = testServer(t)
scanner = bufio.NewScanner(c)
scanner.Scan() // Greeting
return
}
func TestCapability(t *testing.T) {
s, c, scanner := testServerGreeted(t)
defer c.Close()
defer s.Close()
io.WriteString(c, "a001 CAPABILITY\r\n")
scanner.Scan()
if scanner.Text() != "* CAPABILITY IMAP4rev1 AUTH=PLAIN" {
t.Fatal("Bad capability:", scanner.Text())
}
scanner.Scan()
if !strings.HasPrefix(scanner.Text(), "a001 OK ") {
t.Fatal("Bad status response:", scanner.Text())
}
}
func TestNoop(t *testing.T) {
s, c, scanner := testServerGreeted(t)
defer c.Close()
defer s.Close()
io.WriteString(c, "a001 NOOP\r\n")
scanner.Scan()
if !strings.HasPrefix(scanner.Text(), "a001 OK ") {
t.Fatal("Bad status response:", scanner.Text())
}
}
func TestLogout(t *testing.T) {
s, c, scanner := testServerGreeted(t)
defer c.Close()
defer s.Close()
io.WriteString(c, "a001 LOGOUT\r\n")
scanner.Scan()
if !strings.HasPrefix(scanner.Text(), "* BYE ") {
t.Fatal("Bad BYE response:", scanner.Text())
}
scanner.Scan()
if !strings.HasPrefix(scanner.Text(), "a001 OK ") {
t.Fatal("Bad status response:", scanner.Text())
}
}
type xnoop struct{}
func (ext *xnoop) Capabilities(server.Conn) []string {
return []string{"XNOOP"}
}
func (ext *xnoop) Command(string) server.HandlerFactory {
return nil
}
func TestServer_Enable(t *testing.T) {
s, c, scanner := testServerGreeted(t)
defer c.Close()
defer s.Close()
s.Enable(&xnoop{})
io.WriteString(c, "a001 CAPABILITY\r\n")
scanner.Scan()
if scanner.Text() != "* CAPABILITY IMAP4rev1 AUTH=PLAIN XNOOP" {
t.Fatal("Bad capability:", scanner.Text())
}
scanner.Scan()
if !strings.HasPrefix(scanner.Text(), "a001 OK ") {
t.Fatal("Bad status response:", scanner.Text())
}
}
type xnoopAuth struct{}
func (ext *xnoopAuth) Next(response []byte) (challenge []byte, done bool, err error) {
done = true
return
}
func TestServer_EnableAuth(t *testing.T) {
s, c, scanner := testServerGreeted(t)
defer c.Close()
defer s.Close()
s.EnableAuth("XNOOP", func(server.Conn) sasl.Server {
return &xnoopAuth{}
})
io.WriteString(c, "a001 CAPABILITY\r\n")
scanner.Scan()
if scanner.Text() != "* CAPABILITY IMAP4rev1 AUTH=PLAIN AUTH=XNOOP" &&
scanner.Text() != "* CAPABILITY IMAP4rev1 AUTH=XNOOP AUTH=PLAIN" {
t.Fatal("Bad capability:", scanner.Text())
}
scanner.Scan()
if !strings.HasPrefix(scanner.Text(), "a001 OK ") {
t.Fatal("Bad status response:", scanner.Text())
}
}