forked from FluuxIO/go-xmpp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathauth_test.go
More file actions
32 lines (28 loc) · 1.01 KB
/
auth_test.go
File metadata and controls
32 lines (28 loc) · 1.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
package xmpp
import "testing"
func TestParseSCRAMFieldsRejectsDuplicateAttributes(t *testing.T) {
if _, err := parseSCRAMFields("r=nonce,s=salt,r=again"); err == nil {
t.Fatal("expected duplicate SCRAM attribute to fail")
}
}
func TestSCRAMDowngradeString(t *testing.T) {
got, err := scramDowngradeString(
[]string{"PLAIN", "SCRAM-SHA-512", "SCRAM-SHA-1"},
[]string{"tls-exporter", "tls-server-end-point"},
)
if err != nil {
t.Fatalf("scramDowngradeString returned error: %v", err)
}
want := "PLAIN\x1eSCRAM-SHA-1\x1eSCRAM-SHA-512\x1ftls-exporter\x1etls-server-end-point"
if got != want {
t.Fatalf("scramDowngradeString() = %q, want %q", got, want)
}
}
func TestSCRAMDowngradeStringRejectsInvalidNames(t *testing.T) {
if _, err := scramDowngradeString([]string{"plain"}, nil); err == nil {
t.Fatal("expected invalid SASL mechanism name to fail")
}
if _, err := scramDowngradeString([]string{"PLAIN"}, []string{"tls_exporter"}); err == nil {
t.Fatal("expected invalid channel binding name to fail")
}
}