mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
crypto/tls: better error messages when PEM inputs are switched.
This change causes the types of skipped PEM blocks to be recorded when no certificate or private-key data is found in a PEM input. This allows for better error messages to be return in the case of common errors like switching the certifiate and key inputs to X509KeyPair. Fixes #11092 Change-Id: Ifc155a811cdcddd93b5787fe16a84c972011f2f7 Reviewed-on: https://go-review.googlesource.com/14054 Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org> Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
This commit is contained in:
parent
2801bd2c2d
commit
324b8cea11
2 changed files with 55 additions and 4 deletions
32
tls_test.go
32
tls_test.go
|
@ -104,6 +104,38 @@ func TestX509KeyPair(t *testing.T) {
|
|||
}
|
||||
}
|
||||
|
||||
func TestX509KeyPairErrors(t *testing.T) {
|
||||
_, err := X509KeyPair([]byte(rsaKeyPEM), []byte(rsaCertPEM))
|
||||
if err == nil {
|
||||
t.Fatalf("X509KeyPair didn't return an error when arguments were switched")
|
||||
}
|
||||
if subStr := "been switched"; !strings.Contains(err.Error(), subStr) {
|
||||
t.Fatalf("Expected %q in the error when switching arguments to X509KeyPair, but the error was %q", subStr, err)
|
||||
}
|
||||
|
||||
_, err = X509KeyPair([]byte(rsaCertPEM), []byte(rsaCertPEM))
|
||||
if err == nil {
|
||||
t.Fatalf("X509KeyPair didn't return an error when both arguments were certificates")
|
||||
}
|
||||
if subStr := "certificate"; !strings.Contains(err.Error(), subStr) {
|
||||
t.Fatalf("Expected %q in the error when both arguments to X509KeyPair were certificates, but the error was %q", subStr, err)
|
||||
}
|
||||
|
||||
const nonsensePEM = `
|
||||
-----BEGIN NONSENSE-----
|
||||
Zm9vZm9vZm9v
|
||||
-----END NONSENSE-----
|
||||
`
|
||||
|
||||
_, err = X509KeyPair([]byte(nonsensePEM), []byte(nonsensePEM))
|
||||
if err == nil {
|
||||
t.Fatalf("X509KeyPair didn't return an error when both arguments were nonsense")
|
||||
}
|
||||
if subStr := "NONSENSE"; !strings.Contains(err.Error(), subStr) {
|
||||
t.Fatalf("Expected %q in the error when both arguments to X509KeyPair were nonsense, but the error was %q", subStr, err)
|
||||
}
|
||||
}
|
||||
|
||||
func TestX509MixedKeyPair(t *testing.T) {
|
||||
if _, err := X509KeyPair([]byte(rsaCertPEM), []byte(ecdsaKeyPEM)); err == nil {
|
||||
t.Error("Load of RSA certificate succeeded with ECDSA private key")
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue