Skip to content

webpkiπŸ”—

webpki::aki::root-with-aki-missing-keyidentifierπŸ”—

Produces the following invalid chain:

root -> EE

The root cert incudes the authorityKeyIdentifier extension but without the keyIdentifier field, which is required under CABF:

7.1.2.1.3 Root CA Authority Key Identifier Field Description ... keyIdentifier MUST be present. MUST be identical to the subjectKeyIdentifier field.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: authorityKeyIdentifier must contain keyIdentifier
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::aki::root-with-aki-authoritycertissuerπŸ”—

Produces the following invalid chain:

root -> EE

The root cert includes the authorityKeyIdentifier extension with the authorityCertIssuer field, which is forbidden under CABF:

7.1.2.1.3 Root CA Authority Key Identifier Field Description ... authorityCertIssuer MUST NOT be present

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 ❌ (unexpected success) N/A
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::aki::root-with-aki-authoritycertserialnumberπŸ”—

Produces the following invalid chain:

root -> EE

The root cert includes the authorityKeyIdentifier extension with the authorityCertSerialNumber field, which is forbidden under the [CA/B BR profile]:

7.1.2.1.3 Root CA Authority Key Identifier Field Description ... authorityCertSerialNumber MUST NOT be present

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 ❌ (unexpected success) N/A
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::aki::root-with-aki-all-fieldsπŸ”—

Produces the following invalid chain:

root -> EE

The root cert includes the authorityKeyIdentifier extension with the authorityCertIssuer and authorityCertSerialNumber fields, which is forbidden under CABF:

7.1.2.1.3 Root CA Authority Key Identifier Field Description ... authorityCertIssuer MUST NOT be present authorityCertSerialNumber MUST NOT be present

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 ❌ (unexpected success) N/A
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::aki::root-with-aki-ski-mismatchπŸ”—

Produces the following invalid chain:

root -> EE

The root cert is self-signed contains an authorityKeyIdentifier, but the keyIdentifier field doesn't match the subjectKeyIdentifier field as required under CABF.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicitly unsupported case)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::eku::ee-anyekuπŸ”—

Produces the following invalid chain:

root -> EE

This chain is correctly constructed, but the EE cert contains an Extended Key Usage extension that contains anyExtendedKeyUsage, which is explicitly forbidden under CABF 7.1.2.7.10.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-eku undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 🚧 custom EKUs not yet supported
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::eku::ee-critical-ekuπŸ”—

Produces the following invalid chain:

root -> EE

This chain is correctly constructed, but the EE has an extKeyUsage extension marked as critical, which is forbidden per CABF 7.1.2.7.6.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-eku undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 🚧 custom EKUs not yet supported
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::eku::ee-without-ekuπŸ”—

Produces the following invalid chain:

root -> EE

This chain is correctly constructed, but the EE does not have the extKeyUsage extension, which is required per CABF 7.1.2.7.6.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-eku undetermined rfc5280::eku::ee-without-eku PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::eku::root-has-ekuπŸ”—

Produces the following invalid chain:

root -> EE

The root cert includes the extKeyUsage extension, which is forbidden under CABF:

7.1.2.1.2 Root CA Extensions Extension Presence Critical ... extKeyUsage MUST NOT N

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-eku undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 🚧 custom EKUs not yet supported
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::nc::permitted-dns-match-noncriticalπŸ”—

Produces the following valid chain:

root -> leaf

The root contains a NameConstraints extension with a permitted dNSName of "example.com", matching the leaf's SubjectAlternativeName. The NameConstraints extension is marked as non-critical, which would be a violation of RFC 5280, but CABF explicitly permits this as an exception to RFC 5280:

As an explicit exception from RFC 5280, this extension SHOULD be marked critical, but MAY be marked non-critical if compatibility with certain legacy applications that do not support Name Constraints is necessary.

Expected result Validation kind Validation time Features Importance Conflicts Download
SUCCESS SERVER N/A N/A undetermined rfc5280::nc::permitted-dns-match-noncritical PEM bundle
Harness Result Context
rustls-webpki βœ… N/A
openssl-1.1 βœ… N/A
openssl-3.0.15 βœ… N/A
openssl-3.4.0 βœ… N/A
openssl-3.3.2 βœ… N/A
openssl-3.1.7 βœ… N/A
gnutls-certtool-3.8.3 βœ… Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… N/A
rust-webpki ❌ (unexpected failure) UnknownIssuer
pyca-cryptography-44.0.0 βœ… N/A
certvalidator-0.11.1 βœ… N/A

webpki::nc::intermediate-permitted-excluded-subtrees-both-nullπŸ”—

Produces the following invalid chain:

root -> intermediate -> leaf

The intermediate contains a NameConstraints extension with ASN.1 NULL for both permittedSubtrees and excludedSubtrees, which is forbidden under CABF 7.1.2.5.2.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: nameConstraints must have non-empty permittedSubtrees or excludedSubtrees
certvalidator-0.11.1 βœ… The path could not be validated because intermediate certificate 1 contains the following unsupported critical extension: name_constraints

webpki::nc::intermediate-permitted-excluded-subtrees-both-empty-sequencesπŸ”—

Produces the following invalid chain:

root -> intermediate -> leaf

The intermediate contains a NameConstraints extension with empty sequences for both permittedSubtrees and excludedSubtrees, which is forbidden under CABF 7.1.2.5.2.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki βœ… UnknownIssuer
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: nameConstraints must have non-empty permittedSubtrees or excludedSubtrees
certvalidator-0.11.1 βœ… The path could not be validated because intermediate certificate 1 contains the following unsupported critical extension: name_constraints

webpki::nc::nc-permits-dns-san-patternπŸ”—

Produces the following valid graph:

root -> ICA (permit: foo.com) -> EE (SAN: *.foo.com)

CABF does not specify how Name Constraints and SAN patterns compose (the latter is not specified at all), but their compatibility is a logical conclusion of the following rules:

  1. A DNS Name Constraint matches name as well as zero or more sublabels
  2. A DNS SAN pattern of *.name matches exactly one sublabel
  3. Therefore, any DNS NC of name will always match all *.name SANs
Expected result Validation kind Validation time Features Importance Conflicts Download
SUCCESS SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… N/A
openssl-1.1 βœ… N/A
openssl-3.0.15 βœ… N/A
openssl-3.4.0 βœ… N/A
openssl-3.3.2 βœ… N/A
openssl-3.1.7 βœ… N/A
gnutls-certtool-3.8.3 ❌ (unexpected failure) Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… N/A
rust-webpki ❌ (unexpected failure) UnknownIssuer
pyca-cryptography-44.0.0 ❌ (unexpected failure) validation failed: candidates exhausted: unsatisfiable DNS name constraint: malformed SAN *.example.com
certvalidator-0.11.1 ❌ (unexpected failure) The path could not be validated because intermediate certificate 1 contains the following unsupported critical extension: name_constraints

webpki::san::exact-dns-sanπŸ”—

Produces a chain with a valid EE cert for example.com.

This EE cert contains a Subject Alternative Name with the dNSName "example.com". This should verify successfully against the domain "example.com", per RFC 6125 6.4.1.

Expected result Validation kind Validation time Features Importance Conflicts Download
SUCCESS SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… N/A
openssl-1.1 βœ… N/A
openssl-3.0.15 βœ… N/A
openssl-3.4.0 βœ… N/A
openssl-3.3.2 βœ… N/A
openssl-3.1.7 βœ… N/A
gnutls-certtool-3.8.3 βœ… Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… N/A
rust-webpki βœ… N/A
pyca-cryptography-44.0.0 βœ… N/A
certvalidator-0.11.1 βœ… N/A

webpki::san::exact-localhost-ip-sanπŸ”—

Produces a chain with a valid EE cert, for IP 127.0.0.1, i.e. localhost.

Expected result Validation kind Validation time Features Importance Conflicts Download
SUCCESS SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… N/A
openssl-1.1 βœ… N/A
openssl-3.0.15 βœ… N/A
openssl-3.4.0 βœ… N/A
openssl-3.3.2 βœ… N/A
openssl-3.1.7 βœ… N/A
gnutls-certtool-3.8.3 βœ… Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… N/A
rust-webpki 🚧 implementation requires DNS peer names
pyca-cryptography-44.0.0 βœ… N/A
certvalidator-0.11.1 βœ… N/A

webpki::san::mismatch-domain-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName example.com. This should fail to verify against the domain example2.com, per RFC 6125 6.4.1.

Each label MUST match in order for the names to be considered to match, except as supplemented by the rule about checking of wildcard labels.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for example2.com. Valid hostnames include: example.com

webpki::san::mismatch-subdomain-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName abc.example.com. This should fail to verify against the domain def.example.com, per RFC 6125 6.4.1.

Each label MUST match in order for the names to be considered to match, except as supplemented by the rule about checking of wildcard labels.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for def.example.com. Valid hostnames include: abc.example.com

webpki::san::mismatch-subdomain-apex-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName example.com. This should fail to verify against the domain abc.example.com, per RFC 6125 6.4.1.

Each label MUST match in order for the names to be considered to match, except as supplemented by the rule about checking of wildcard labels.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for abc.example.com. Valid hostnames include: example.com

webpki::san::mismatch-apex-subdomain-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName abc.example.com. This should fail to verify against the domain example.com, per RFC 6125 6.4.1.

Each label MUST match in order for the names to be considered to match, except as supplemented by the rule about checking of wildcard labels.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for example.com. Valid hostnames include: abc.example.com

webpki::san::public-suffix-wildcard-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative name with the dNSName *.com. Conformant CAs should not issue such a certificate, according to CABF:

If the FQDN portion of any Wildcard Domain Name is β€œregistry‐controlled” or is a β€œpublic suffix”, CAs MUST refuse issuance unless the Applicant proves its rightful control of the entire Domain Namespace.

While the Baseline Requirements do not specify how clients should behave when given such a certificate, it is generally safe to assume that wildcard certificates spanning a gTLD are malicious, and clients should reject them.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-public-suffix-wildcard undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::san::leftmost-wildcard-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName *.example.com. This should verify successfully against the domain foo.example.com, per RFC 6125 6.4.3.

Expected result Validation kind Validation time Features Importance Conflicts Download
SUCCESS SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… N/A
openssl-1.1 βœ… N/A
openssl-3.0.15 βœ… N/A
openssl-3.4.0 βœ… N/A
openssl-3.3.2 βœ… N/A
openssl-3.1.7 βœ… N/A
gnutls-certtool-3.8.3 βœ… Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… N/A
rust-webpki βœ… N/A
pyca-cryptography-44.0.0 βœ… N/A
certvalidator-0.11.1 βœ… N/A

webpki::san::wildcard-embedded-leftmost-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName ba*.example.com. This should fail to verify against the domain baz.example.com, per CABF.

Wildcard Domain Name: A string starting with β€œ*.” (U+002A ASTERISK, U+002E FULL STOP) immediately followed by a Fully-Qualified Domain Name.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::san::wildcard-not-in-leftmost-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName foo.*.example.com. This should fail to verify against the domain foo.bar.example.com, per RFC 6125 6.4.3.

The client SHOULD NOT attempt to match a presented identifier in which the wildcard character comprises a label other than the left-most label (e.g., do not match bar.*.example.net).

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for foo.bar.example.com. Valid hostnames include: foo.*.example.com

webpki::san::wildcard-match-across-labels-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName *.example.com. This should fail to verify against the domain foo.bar.example.com, per RFC 6125 6.4.3.

If the wildcard character is the only character of the left-most label in the presented identifier, the client SHOULD NOT compare against anything but the left-most label of the reference identifier (e.g., *.example.com would match foo.example.com but not bar.foo.example.com or example.com).

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for foo.bar.example.com. Valid hostnames include: *.example.com

webpki::san::wildcard-embedded-ulabel-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName xn--*-1b3c148a.example.com. This should fail to verify against the domain xn--bliss-1b3c148a.example.com, per RFC 6125 6.4.3:

... the client SHOULD NOT attempt to match a presented identifier where the wildcard character is embedded within an A-label or U-label [IDNA-DEFS] of an internationalized domain name [IDNA-PROTO].

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for xn--bliss-1b3c148a.example.com. Valid hostnames include: *痛苦.example.com

webpki::san::unicode-emoji-sanπŸ”—

Produces a chain with an EE cert.

This EE cert contains a Subject Alternative Name with the dNSName 😜.example.com, This should fail to verify against the domain xn--628h.example.com, per RFC 5280 7.2:

IA5String is limited to the set of ASCII characters. To accommodate internationalized domain names in the current structure, conforming implementations MUST convert internationalized domain names to the ASCII Compatible Encoding (ACE) format as specified in Section 4 of RFC 3490 before storage in the dNSName field.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… 'ascii' codec can't decode byte 0xf0 in position 0: ordinal not in range(128)

webpki::san::no-sanπŸ”—

Produces the following invalid chain:

root -> EE

The chain is correctly constructed, but the EE cert does not have a Subject Alternative Name, which is required. This is invalid even when the Subject contains a valid domain name in its Common Name component.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: Certificate is missing required extension (encountered processing , ...)>)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::san::san-critical-with-nonempty-subjectπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert includes a critical subjectAlternativeName extension, which is forbidden under CABF when the subject is non-empty:

If the subject field of the certificate is an empty SEQUENCE, this extension MUST be marked critical, as specified in RFC 5280, Section 4.2.1.6. Otherwise, this extension MUST NOT be marked critical.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 βœ… validation failed: EE subjectAltName MUST NOT be critical when subject is nonempty (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The path could not be validated because the end-entity certificate contains the following unsupported critical extension: subject_alt_name

webpki::san::san-wildcard-onlyπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert contains a SAN of just DNS:*, which should be rejected.

The reason for this is subtle: CABF 3.2.2.6 notes that certs with wildcards on public suffixes should not be issued, and . (i.e. the DNS root) is effectively a public suffix. This is true even though the DNS root is not itself on the PSL.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for example.com. Valid hostnames include: *

webpki::san::san-wildcard-only-tldπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert contains a SAN of just DNS:*, which should be rejected.

The reason for this is subtle: CABF 3.2.2.6 notes that certs with wildcards on public suffixes should not be issued, and . (i.e. the DNS root) is effectively a public suffix. This is true even though the DNS root is not itself on the PSL.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… subject name validation failed
openssl-1.1 βœ… Hostname mismatch
openssl-3.0.15 βœ… hostname mismatch
openssl-3.4.0 βœ… hostname mismatch
openssl-3.3.2 βœ… hostname mismatch
openssl-3.1.7 βœ… hostname mismatch
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The name in the certificate does not match the expected.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… hostname mismatch
rust-webpki βœ… DNS name validation failed
pyca-cryptography-44.0.0 βœ… validation failed: leaf certificate has no matching subjectAltName (encountered processing , ...)>)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::explicit-curveπŸ”—

Produces the following invalid chain:

root -> EE

Both root and EE convey EC keys using the "explicit" curve encoding, which is forbidden under CABF 7.1.3.1.2:

The CA SHALL indicate an ECDSA key using the id‐ecPublicKey (OID: 1.2.840.10045.2.1) algorithm identifier. The parameters MUST use the namedCurve encoding.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER 2024-03-13T00:00:00+00:00 N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… UnsupportedSignatureAlgorithmForPublicKey
openssl-1.1 βœ… Certificate public key has explicit ECC parameters
openssl-3.0.15 βœ… Certificate public key has explicit ECC parameters
openssl-3.4.0 βœ… Certificate public key has explicit ECC parameters
openssl-3.3.2 βœ… Certificate public key has explicit ECC parameters
openssl-3.1.7 βœ… Certificate public key has explicit ECC parameters
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… Certificate public key has explicit ECC parameters
rust-webpki βœ… UnknownIssuer
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: Forbidden public key algorithm: AlgorithmIdentifier { oid: DefinedByMarker(PhantomData), params: Ec(SpecifiedCurve(Sequence { data: [2, 1, 1, 48, 44, 6, 7, 42, 134, 72, 206, 61, 1, 1, 2, 33, 0, 255, 255, 255, 255, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 48, 91, 4, 32, 255, 255, 255, 255, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 252, 4, 32, 90, 198, 53, 216, 170, 58, 147, 231, 179, 235, 189, 85, 118, 152, 134, 188, 101, 29, 6, 176, 204, 83, 176, 246, 59, 206, 60, 62, 39, 210, 96, 75, 3, 21, 0, 196, 157, 54, 8, 134, 231, 4, 147, 106, 102, 120, 225, 19, 157, 38, 183, 129, 159, 126, 144, 4, 65, 4, 107, 23, 209, 242, 225, 44, 66, 71, 248, 188, 230, 229, 99, 164, 64, 242, 119, 3, 125, 129, 45, 235, 51, 160, 244, 161, 57, 69, 216, 152, 194, 150, 79, 227, 66, 226, 254, 26, 127, 155, 142, 231, 235, 74, 124, 15, 158, 22, 43, 206, 51, 87, 107, 49, 94, 206, 203, 182, 64, 104, 55, 191, 81, 245, 2, 33, 0, 255, 255, 255, 255, 0, 0, 0, 0, 255, 255, 255, 255, 255, 255, 255, 255, 188, 230, 250, 173, 167, 23, 158, 132, 243, 185, 202, 194, 252, 99, 37, 81, 2, 1, 1] })) }
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::cryptographydotio-chainπŸ”—

Verifies against a saved copy of cryptography.io's chain. This should trivially succeed.

Expected result Validation kind Validation time Features Importance Conflicts Download
SUCCESS SERVER 2023-07-10T00:00:00+00:00 N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki 🚧 key_usage not supported yet
openssl-1.1 βœ… N/A
openssl-3.0.15 βœ… N/A
openssl-3.4.0 βœ… N/A
openssl-3.3.2 βœ… N/A
openssl-3.1.7 βœ… N/A
gnutls-certtool-3.8.3 🚧 custom key usages not supported
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… N/A
rust-webpki 🚧 key_usage not supported yet
pyca-cryptography-44.0.0 βœ… N/A
certvalidator-0.11.1 βœ… N/A

webpki::cryptographydotio-chain-missing-intermediateπŸ”—

Verifies against a saved copy of cryptography.io's chain, but without its intermediates. This should trivially fail.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER 2023-07-10T00:00:00+00:00 N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki 🚧 key_usage not supported yet
openssl-1.1 βœ… unable to get local issuer certificate
openssl-3.0.15 βœ… unable to get local issuer certificate
openssl-3.4.0 βœ… unable to get local issuer certificate
openssl-3.3.2 βœ… unable to get local issuer certificate
openssl-3.1.7 βœ… unable to get local issuer certificate
gnutls-certtool-3.8.3 🚧 custom key usages not supported
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… unable to get local issuer certificate
rust-webpki 🚧 key_usage not supported yet
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: all candidates exhausted with no interior errors
certvalidator-0.11.1 βœ… Unable to build a validation path for the certificate "Common Name: cryptography.io" - no issuer matching "Common Name: R3, Organization: Let's Encrypt, Country: US" was found

webpki::malformed-aiaπŸ”—

Produces a chain with an EE cert.

This EE cert contains an Authority Information Access extension with malformed contents. This is invalid per CABF.

The AuthorityInfoAccessSyntax MUST contain one or more AccessDescriptions.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 βœ… validation failed: ASN.1 parsing error: short data (needed at least 90 additional bytes) (encountered processing , ...)>)
certvalidator-0.11.1 βœ… Insufficient data - 97 bytes requested but only 7 available
while parsing asn1crypto.core.ParsableOctetString
while parsing asn1crypto.x509.Extension

webpki::forbidden-p192-rootπŸ”—

Produces the following invalid chain:

root -> EE

The root cert conveys a P-192 key and signs for the EE with it, which is not permitted under the CABF's key or signature types.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… UnsupportedSignatureAlgorithmForPublicKey
openssl-1.1 βœ… CA certificate key too weak
openssl-3.0.15 βœ… CA certificate key too weak
openssl-3.4.0 βœ… CA certificate key too weak
openssl-3.3.2 βœ… CA certificate key too weak
openssl-3.1.7 βœ… CA certificate key too weak
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… CA certificate key too weak
rust-webpki βœ… UnknownIssuer
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: Forbidden public key algorithm: AlgorithmIdentifier { oid: DefinedByMarker(PhantomData), params: Ec(NamedCurve(ObjectIdentifier { oid: 1.2.840.10045.3.1.1 })) }
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-p192-leafπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert conveys a P-192 key, which is not one of the permitted public keys under CABF.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-subscriber-key undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 βœ… EE certificate key too weak
openssl-3.0.15 βœ… EE certificate key too weak
openssl-3.4.0 βœ… EE certificate key too weak
openssl-3.3.2 βœ… EE certificate key too weak
openssl-3.1.7 βœ… EE certificate key too weak
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 βœ… EE certificate key too weak
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-dsa-rootπŸ”—

Produces the following invalid chain:

root -> EE

The root cert conveys a DSA-30272 key and signs for the EE with it, which is not permitted under the CABF's key or signature types.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… UnsupportedSignatureAlgorithm
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki βœ… UnknownIssuer
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: Forbidden public key algorithm: AlgorithmIdentifier { oid: DefinedByMarker(PhantomData), params: Dsa(DssParams { p: BigUint { data: [0, 157, 6, 251, 215, 184, 80, 122, 138, 222, 176, 126, 25, 167, 68, 75, 112, 250, 255, 199, 207, 175, 29, 238, 9, 208, 84, 198, 30, 147, 97, 52, 174, 111, 30, 176, 106, 247, 105, 88, 56, 175, 184, 221, 159, 253, 162, 172, 244, 171, 12, 26, 100, 226, 244, 93, 185, 239, 173, 213, 76, 60, 155, 202, 77, 83, 172, 129, 2, 246, 91, 117, 142, 247, 121, 207, 145, 63, 162, 51, 10, 235, 89, 55, 131, 29, 239, 82, 79, 73, 31, 117, 72, 184, 57, 225, 20, 5, 7, 250, 67, 194, 111, 20, 223, 41, 189, 15, 42, 25, 98, 219, 206, 73, 32, 149, 147, 110, 109, 9, 117, 183, 10, 159, 122, 4, 139, 252, 240, 155, 113, 4, 53, 110, 239, 200, 69, 204, 27, 20, 59, 62, 137, 39, 80, 180, 41, 48, 61, 103, 129, 25, 39, 81, 105, 165, 46, 198, 232, 6, 86, 178, 23, 124, 211, 108, 55, 17, 12, 220, 98, 100, 71, 196, 254, 66, 2, 199, 21, 80, 60, 126, 164, 110, 101, 226, 213, 198, 79, 84, 13, 247, 163, 119, 30, 23, 8, 24, 17, 83, 168, 68, 143, 168, 245, 66, 124, 18, 130, 233, 135, 49, 242, 42, 79, 106, 5, 223, 222, 211, 195, 119, 91, 183, 160, 172, 82, 174, 104, 83, 85, 68, 139, 132, 15, 210, 91, 66, 100, 95, 124, 12, 208, 41, 134, 234, 194, 63, 18, 191, 247, 44, 202, 72, 3, 242, 160, 98, 1, 74, 232, 38, 90, 163, 111, 254, 151, 136, 80, 249, 67, 24, 77, 79, 180, 172, 202, 20, 162, 198, 11, 16, 189, 2, 166, 221, 12, 2, 39, 69, 177, 34, 96, 32, 161, 148, 20, 160, 210, 251, 157, 219, 76, 63, 106, 206, 14, 114, 124, 218, 74, 201, 194, 203, 202, 171, 11, 5, 216, 226, 87, 124, 199, 106, 91, 22, 149, 183, 24, 88, 221, 20, 206, 248, 46, 74, 47, 141, 252, 35, 88, 133, 225, 121, 161, 162, 45, 204, 200, 195, 254, 225, 95, 246, 108, 20, 215, 241, 73, 72, 188, 221, 206, 59, 139, 116, 151, 61, 227, 38, 129, 218, 83, 146, 49, 110, 159, 70, 229, 54, 54, 189, 110, 237, 229] }, q: BigUint { data: [0, 133, 61, 82, 7, 143, 76, 151, 206, 24, 29, 141, 112, 116, 117, 223, 233, 156, 138, 219, 214, 31, 144, 50, 146, 196, 172, 216, 148, 196, 106, 178, 113] }, g: BigUint { data: [47, 160, 55, 162, 100, 71, 31, 218, 50, 233, 155, 44, 124, 64, 80, 2, 211, 156, 33, 146, 81, 199, 90, 150, 115, 95, 226, 172, 202, 240, 57, 240, 220, 23, 68, 30, 71, 73, 74, 212, 190, 143, 165, 239, 188, 186, 220, 203, 255, 168, 225, 70, 227, 134, 165, 59, 34, 146, 248, 62, 126, 206, 111, 74, 13, 136, 224, 111, 159, 54, 87, 122, 154, 178, 175, 200, 192, 78, 46, 96, 188, 54, 157, 129, 211, 205, 250, 72, 185, 0, 14, 1, 187, 248, 13, 36, 63, 222, 12, 174, 194, 108, 189, 8, 160, 132, 72, 1, 233, 219, 224, 14, 131, 12, 94, 45, 100, 57, 11, 53, 196, 180, 250, 122, 57, 10, 153, 126, 193, 79, 249, 69, 31, 24, 99, 47, 72, 167, 138, 159, 163, 234, 77, 11, 51, 248, 223, 207, 209, 21, 28, 96, 188, 85, 177, 191, 14, 138, 217, 255, 65, 133, 234, 188, 164, 58, 182, 177, 61, 5, 236, 91, 86, 200, 202, 36, 101, 39, 224, 72, 31, 197, 50, 198, 130, 124, 90, 177, 84, 178, 216, 202, 43, 203, 187, 55, 170, 203, 237, 219, 47, 248, 145, 33, 25, 122, 220, 12, 210, 78, 185, 84, 148, 9, 174, 69, 134, 211, 111, 52, 64, 160, 16, 105, 26, 188, 146, 117, 58, 0, 214, 21, 9, 109, 49, 176, 87, 85, 58, 38, 150, 120, 108, 123, 14, 121, 233, 46, 68, 141, 45, 86, 11, 38, 117, 135, 59, 13, 240, 36, 138, 237, 13, 128, 29, 16, 125, 208, 236, 27, 115, 194, 179, 197, 47, 46, 217, 249, 78, 16, 194, 137, 143, 232, 79, 140, 31, 81, 43, 199, 16, 63, 207, 125, 27, 37, 97, 224, 184, 123, 91, 8, 224, 43, 28, 45, 241, 34, 161, 247, 191, 112, 185, 27, 223, 234, 124, 109, 163, 179, 75, 31, 210, 227, 121, 61, 158, 68, 95, 240, 177, 76, 227, 76, 14, 59, 206, 113, 100, 143, 223, 195, 77, 11, 96, 130, 168, 127, 206, 85, 80, 211, 100, 33, 11, 25, 241, 81, 198, 12, 236, 174, 134, 255, 145, 155, 212, 33, 129, 178, 108, 35, 90, 66, 236, 39, 85, 91, 5, 243, 5, 0, 82, 148] } }) }
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-dsa-leafπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert conveys a DSA key, which is not one of the permitted public keys under CABF.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-subscriber-key undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-weak-rsa-key-in-rootπŸ”—

Produces the following invalid chain:

root -> EE

The root cert is signed with and conveys an RSA-1024 key, which is below the security margin (2048) required under CABF 6.1.5.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… InvalidSignatureForPublicKey
openssl-1.1 βœ… CA certificate key too weak
openssl-3.0.15 βœ… CA certificate key too weak
openssl-3.4.0 βœ… CA certificate key too weak
openssl-3.3.2 βœ… CA certificate key too weak
openssl-3.1.7 βœ… CA certificate key too weak
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 βœ… CA certificate key too weak
rust-webpki βœ… UnknownIssuer
pyca-cryptography-44.0.0 βœ… validation failed: candidates exhausted: RSA key is too weak
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-weak-rsa-in-leafπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert conveys an RSA 1024 key, which is below the security margin (2048) required under CABF 6.1.5.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-subscriber-key undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 βœ… EE certificate key too weak
openssl-3.0.15 βœ… EE certificate key too weak
openssl-3.4.0 βœ… EE certificate key too weak
openssl-3.3.2 βœ… EE certificate key too weak
openssl-3.1.7 βœ… EE certificate key too weak
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 βœ… EE certificate key too weak
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-rsa-not-divisable-by-8-in-rootπŸ”—

Produces the following invalid chain:

root -> EE

The root cert is signed with and conveys an RSA-2052 key, which is above the security margin (2048) but not divisible by 8, as is required under CABF 6.1.5.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicitly unsupported case)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::forbidden-rsa-key-not-divisable-by-8-in-leafπŸ”—

Produces the following invalid chain:

root -> EE

The EE cert conveys an RSA-2052 key, which is above the security margin (2048) but not divisible by 8, as is required under CABF 6.1.5.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A pedantic-webpki-subscriber-key undetermined N/A PEM bundle
Harness Result Context
rustls-webpki ❌ (unexpected success) N/A
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 βœ… Chain verification output: Not verified. The certificate is NOT trusted. The certificate chain uses insecure algorithm.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki ❌ (unexpected success) N/A
pyca-cryptography-44.0.0 🚧 testcase skipped (explicit unsupported feature)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::v1-certπŸ”—

Produces the following invalid chain:

root -> EE

This chain is correctly constructed, but the EE cert is marked with version 2 (ordinal 1) rather than version 3 (ordinal 2). This is invalid, per CABF 7.1.1:

Certificates MUST be of type X.509 v3.

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… leaf cert: X.509 parse failed
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 βœ… N/A
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki βœ… leaf cert: X.509 parse failed
pyca-cryptography-44.0.0 βœ… validation failed: certificate must be an X509v3 certificate (encountered processing , ...)>)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::ee-basicconstraints-caπŸ”—

Produces the following invalid chain:

root -> EE

The EE certificate has keyUsage.keyCertSign=FALSE but basicConstraints.cA=TRUE, which is explicitly forbidden under CABF 7.1.2.7.8:

cA MUST be FALSE

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined N/A PEM bundle
Harness Result Context
rustls-webpki βœ… CaUsedAsEndEntity
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki βœ… CaUsedAsEndEntity
pyca-cryptography-44.0.0 βœ… validation failed: basicConstraints.cA must not be asserted in an EE certificate (encountered processing , ...)>)
certvalidator-0.11.1 ❌ (unexpected success) N/A

webpki::ca-as-leafπŸ”—

Produces the following invalid chain:

root -> ICA

The ICA is in leaf position, despite being a CA certificate, which is explicitly forbidden under CABF 7.1.2.7.11 (keyUsage.keyCertSign must NOT be permitted) and 7.1.2.7.8 (basicConstraints.cA MUST be false).

Expected result Validation kind Validation time Features Importance Conflicts Download
FAILURE SERVER N/A N/A undetermined rfc5280::ca-as-leaf PEM bundle
Harness Result Context
rustls-webpki βœ… CaUsedAsEndEntity
openssl-1.1 ❌ (unexpected success) N/A
openssl-3.0.15 ❌ (unexpected success) N/A
openssl-3.4.0 ❌ (unexpected success) N/A
openssl-3.3.2 ❌ (unexpected success) N/A
openssl-3.1.7 ❌ (unexpected success) N/A
gnutls-certtool-3.8.3 ❌ (unexpected success) Chain verification output: Verified. The certificate is trusted.
gocryptox509-go1.23.4 ❌ (unexpected success) validation: chain built
openssl-3.2.3 ❌ (unexpected success) N/A
rust-webpki βœ… CaUsedAsEndEntity
pyca-cryptography-44.0.0 βœ… validation failed: basicConstraints.cA must not be asserted in an EE certificate (encountered processing , ...)>)
certvalidator-0.11.1 βœ… The X.509 certificate provided is not valid for securing TLS connections