QSslCertificate::toText(): add a file to compare against
With OpenSSL 3.0.5 we see X509_print giving us the text representation not matching any of previous ones - mostly a question of spaces and formatting. Let's add a proper version to compare against and remove useless 0.9.8, 1.0.0, 1.0.1, - we don't support them anymore and thus QSslCertificate::toText() will never give a match. Pick-to: 6.4 6.3 6.2 5.15 Task-number: QTBUG-106017 Change-Id: Ida11321c23e74c7313acc682237ab78408cf2803 Reviewed-by: Mårten Nordheim <marten.nordheim@qt.io>
This commit is contained in:
parent
0206eb137f
commit
0f2397f03d
@ -1,42 +0,0 @@
|
|||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
ce:db:31:28:45:c4:05:40
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
Issuer: C=AU, ST=Some-State, O=Internet Widgits Pty Ltd
|
|
||||||
Validity
|
|
||||||
Not Before: Aug 4 09:53:41 2010 GMT
|
|
||||||
Not After : Aug 29 09:53:41 2051 GMT
|
|
||||||
Subject: C=AU, ST=Some-State, O=Internet Widgits Pty Ltd
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
RSA Public Key: (1024 bit)
|
|
||||||
Modulus (1024 bit):
|
|
||||||
00:cd:aa:db:6f:d6:34:c9:a7:f1:c0:be:e4:41:18:
|
|
||||||
19:e2:02:c9:22:e6:a7:d5:ba:03:2e:9e:28:7a:f4:
|
|
||||||
5f:1a:77:5f:77:a9:11:3b:8f:7e:f0:2e:c6:9e:eb:
|
|
||||||
3a:d9:12:d7:c1:0c:51:e8:24:52:3f:23:c3:42:0c:
|
|
||||||
11:c6:f2:1c:a1:42:fe:b4:c2:69:83:ad:f7:70:b1:
|
|
||||||
18:15:cc:20:28:62:30:f0:2c:15:e6:33:19:af:c3:
|
|
||||||
eb:1c:c0:91:f7:11:68:94:50:f8:49:37:08:32:d7:
|
|
||||||
3e:75:df:a3:bc:69:00:15:de:cd:87:0f:5c:02:6b:
|
|
||||||
82:c8:01:7d:6a:f0:1d:dc:73
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
|
||||||
|
|
||||||
X509v3 Basic Constraints:
|
|
||||||
CA:TRUE
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
a1:74:8e:5d:36:96:2c:05:7e:ea:66:cc:2e:68:c7:3d:93:dc:
|
|
||||||
8c:a3:11:ad:b5:7e:6e:d0:04:c4:09:bd:0a:f9:39:3b:97:d7:
|
|
||||||
f0:bb:0c:09:7b:83:fe:bf:87:b0:47:e8:94:b7:aa:9c:79:ad:
|
|
||||||
71:9e:b7:c4:99:98:6f:1d:38:32:f8:a3:75:38:c4:e5:e7:37:
|
|
||||||
37:21:ec:7b:50:8b:15:b0:97:1e:17:9c:50:17:3c:c1:df:94:
|
|
||||||
55:fb:60:2e:50:40:d1:ea:23:c6:3c:21:6f:97:8c:06:16:a5:
|
|
||||||
82:72:c1:63:14:64:86:eb:d7:ff:72:f6:09:f5:6d:e6:04:13:
|
|
||||||
7a:6a
|
|
@ -1,42 +0,0 @@
|
|||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number:
|
|
||||||
ce:db:31:28:45:c4:05:40
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
Issuer: C=AU, ST=Some-State, O=Internet Widgits Pty Ltd
|
|
||||||
Validity
|
|
||||||
Not Before: Aug 4 09:53:41 2010 GMT
|
|
||||||
Not After : Aug 29 09:53:41 2051 GMT
|
|
||||||
Subject: C=AU, ST=Some-State, O=Internet Widgits Pty Ltd
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (1024 bit)
|
|
||||||
Modulus:
|
|
||||||
00:cd:aa:db:6f:d6:34:c9:a7:f1:c0:be:e4:41:18:
|
|
||||||
19:e2:02:c9:22:e6:a7:d5:ba:03:2e:9e:28:7a:f4:
|
|
||||||
5f:1a:77:5f:77:a9:11:3b:8f:7e:f0:2e:c6:9e:eb:
|
|
||||||
3a:d9:12:d7:c1:0c:51:e8:24:52:3f:23:c3:42:0c:
|
|
||||||
11:c6:f2:1c:a1:42:fe:b4:c2:69:83:ad:f7:70:b1:
|
|
||||||
18:15:cc:20:28:62:30:f0:2c:15:e6:33:19:af:c3:
|
|
||||||
eb:1c:c0:91:f7:11:68:94:50:f8:49:37:08:32:d7:
|
|
||||||
3e:75:df:a3:bc:69:00:15:de:cd:87:0f:5c:02:6b:
|
|
||||||
82:c8:01:7d:6a:f0:1d:dc:73
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
|
||||||
|
|
||||||
X509v3 Basic Constraints:
|
|
||||||
CA:TRUE
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
a1:74:8e:5d:36:96:2c:05:7e:ea:66:cc:2e:68:c7:3d:93:dc:
|
|
||||||
8c:a3:11:ad:b5:7e:6e:d0:04:c4:09:bd:0a:f9:39:3b:97:d7:
|
|
||||||
f0:bb:0c:09:7b:83:fe:bf:87:b0:47:e8:94:b7:aa:9c:79:ad:
|
|
||||||
71:9e:b7:c4:99:98:6f:1d:38:32:f8:a3:75:38:c4:e5:e7:37:
|
|
||||||
37:21:ec:7b:50:8b:15:b0:97:1e:17:9c:50:17:3c:c1:df:94:
|
|
||||||
55:fb:60:2e:50:40:d1:ea:23:c6:3c:21:6f:97:8c:06:16:a5:
|
|
||||||
82:72:c1:63:14:64:86:eb:d7:ff:72:f6:09:f5:6d:e6:04:13:
|
|
||||||
7a:6a
|
|
@ -1,41 +0,0 @@
|
|||||||
Certificate:
|
|
||||||
Data:
|
|
||||||
Version: 3 (0x2)
|
|
||||||
Serial Number: 14905561440751715648 (0xcedb312845c40540)
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
Issuer: C=AU, ST=Some-State, O=Internet Widgits Pty Ltd
|
|
||||||
Validity
|
|
||||||
Not Before: Aug 4 09:53:41 2010 GMT
|
|
||||||
Not After : Aug 29 09:53:41 2051 GMT
|
|
||||||
Subject: C=AU, ST=Some-State, O=Internet Widgits Pty Ltd
|
|
||||||
Subject Public Key Info:
|
|
||||||
Public Key Algorithm: rsaEncryption
|
|
||||||
Public-Key: (1024 bit)
|
|
||||||
Modulus:
|
|
||||||
00:cd:aa:db:6f:d6:34:c9:a7:f1:c0:be:e4:41:18:
|
|
||||||
19:e2:02:c9:22:e6:a7:d5:ba:03:2e:9e:28:7a:f4:
|
|
||||||
5f:1a:77:5f:77:a9:11:3b:8f:7e:f0:2e:c6:9e:eb:
|
|
||||||
3a:d9:12:d7:c1:0c:51:e8:24:52:3f:23:c3:42:0c:
|
|
||||||
11:c6:f2:1c:a1:42:fe:b4:c2:69:83:ad:f7:70:b1:
|
|
||||||
18:15:cc:20:28:62:30:f0:2c:15:e6:33:19:af:c3:
|
|
||||||
eb:1c:c0:91:f7:11:68:94:50:f8:49:37:08:32:d7:
|
|
||||||
3e:75:df:a3:bc:69:00:15:de:cd:87:0f:5c:02:6b:
|
|
||||||
82:c8:01:7d:6a:f0:1d:dc:73
|
|
||||||
Exponent: 65537 (0x10001)
|
|
||||||
X509v3 extensions:
|
|
||||||
X509v3 Subject Key Identifier:
|
|
||||||
8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
|
||||||
X509v3 Authority Key Identifier:
|
|
||||||
keyid:8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
|
||||||
|
|
||||||
X509v3 Basic Constraints:
|
|
||||||
CA:TRUE
|
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
|
||||||
a1:74:8e:5d:36:96:2c:05:7e:ea:66:cc:2e:68:c7:3d:93:dc:
|
|
||||||
8c:a3:11:ad:b5:7e:6e:d0:04:c4:09:bd:0a:f9:39:3b:97:d7:
|
|
||||||
f0:bb:0c:09:7b:83:fe:bf:87:b0:47:e8:94:b7:aa:9c:79:ad:
|
|
||||||
71:9e:b7:c4:99:98:6f:1d:38:32:f8:a3:75:38:c4:e5:e7:37:
|
|
||||||
37:21:ec:7b:50:8b:15:b0:97:1e:17:9c:50:17:3c:c1:df:94:
|
|
||||||
55:fb:60:2e:50:40:d1:ea:23:c6:3c:21:6f:97:8c:06:16:a5:
|
|
||||||
82:72:c1:63:14:64:86:eb:d7:ff:72:f6:09:f5:6d:e6:04:13:
|
|
||||||
7a:6a
|
|
@ -27,11 +27,11 @@ Certificate:
|
|||||||
X509v3 Subject Key Identifier:
|
X509v3 Subject Key Identifier:
|
||||||
8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
||||||
X509v3 Authority Key Identifier:
|
X509v3 Authority Key Identifier:
|
||||||
keyid:8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
8A:6E:19:E7:97:9B:8F:D9:7F:B3:BB:01:4F:E8:6A:2F:52:95:0D:D9
|
||||||
|
|
||||||
X509v3 Basic Constraints:
|
X509v3 Basic Constraints:
|
||||||
CA:TRUE
|
CA:TRUE
|
||||||
Signature Algorithm: sha1WithRSAEncryption
|
Signature Algorithm: sha1WithRSAEncryption
|
||||||
|
Signature Value:
|
||||||
a1:74:8e:5d:36:96:2c:05:7e:ea:66:cc:2e:68:c7:3d:93:dc:
|
a1:74:8e:5d:36:96:2c:05:7e:ea:66:cc:2e:68:c7:3d:93:dc:
|
||||||
8c:a3:11:ad:b5:7e:6e:d0:04:c4:09:bd:0a:f9:39:3b:97:d7:
|
8c:a3:11:ad:b5:7e:6e:d0:04:c4:09:bd:0a:f9:39:3b:97:d7:
|
||||||
f0:bb:0c:09:7b:83:fe:bf:87:b0:47:e8:94:b7:aa:9c:79:ad:
|
f0:bb:0c:09:7b:83:fe:bf:87:b0:47:e8:94:b7:aa:9c:79:ad:
|
@ -970,35 +970,19 @@ void tst_QSslCertificate::toText()
|
|||||||
QCOMPARE(certList.size(), 1);
|
QCOMPARE(certList.size(), 1);
|
||||||
const QSslCertificate &cert = certList.at(0);
|
const QSslCertificate &cert = certList.at(0);
|
||||||
|
|
||||||
// Openssl's cert dump method changed slightly between 0.9.8, 1.0.0 and 1.01 versions, so we want it to match any output
|
// Openssl's cert dump method changed slightly between 1.1.1 and 3.0.5 versions, so we want it to match any output
|
||||||
|
|
||||||
QFile f098(testDataDir + "more-certificates/cert-large-expiration-date.txt.0.9.8");
|
|
||||||
QVERIFY(f098.open(QIODevice::ReadOnly | QFile::Text));
|
|
||||||
QByteArray txt098 = f098.readAll();
|
|
||||||
|
|
||||||
QFile f100(testDataDir + "more-certificates/cert-large-expiration-date.txt.1.0.0");
|
|
||||||
QVERIFY(f100.open(QIODevice::ReadOnly | QFile::Text));
|
|
||||||
QByteArray txt100 = f100.readAll();
|
|
||||||
|
|
||||||
QFile f101(testDataDir + "more-certificates/cert-large-expiration-date.txt.1.0.1");
|
|
||||||
QVERIFY(f101.open(QIODevice::ReadOnly | QFile::Text));
|
|
||||||
QByteArray txt101 = f101.readAll();
|
|
||||||
|
|
||||||
QFile f101c(testDataDir + "more-certificates/cert-large-expiration-date.txt.1.0.1c");
|
|
||||||
QVERIFY(f101c.open(QIODevice::ReadOnly | QFile::Text));
|
|
||||||
QByteArray txt101c = f101c.readAll();
|
|
||||||
|
|
||||||
QFile f111(testDataDir + "more-certificates/cert-large-expiration-date.txt.1.1.1");
|
QFile f111(testDataDir + "more-certificates/cert-large-expiration-date.txt.1.1.1");
|
||||||
QVERIFY(f111.open(QIODevice::ReadOnly | QFile::Text));
|
QVERIFY(f111.open(QIODevice::ReadOnly | QFile::Text));
|
||||||
QByteArray txt111 = f111.readAll();
|
QByteArray txt111 = f111.readAll();
|
||||||
|
|
||||||
|
QFile f305(testDataDir + "more-certificates/cert-large-expiration-date.txt.3.0.5");
|
||||||
|
QVERIFY(f305.open(QIODevice::ReadOnly | QFile::Text));
|
||||||
|
QByteArray txt305 = f305.readAll();
|
||||||
|
|
||||||
QString txtcert = cert.toText();
|
QString txtcert = cert.toText();
|
||||||
|
|
||||||
QVERIFY(QString::fromLatin1(txt098) == txtcert ||
|
QVERIFY(QString::fromLatin1(txt111) == txtcert ||
|
||||||
QString::fromLatin1(txt100) == txtcert ||
|
QString::fromLatin1(txt305) == txtcert);
|
||||||
QString::fromLatin1(txt101) == txtcert ||
|
|
||||||
QString::fromLatin1(txt101c) == txtcert ||
|
|
||||||
QString::fromLatin1(txt111) == txtcert );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void tst_QSslCertificate::multipleCommonNames()
|
void tst_QSslCertificate::multipleCommonNames()
|
||||||
|
Loading…
Reference in New Issue
Block a user