-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Recovery Validity Change (eu-digital-green-certificates#40)
* Test Cases added and Recoverystatement Validity added. * Test Cases added and Recoverystatement Validity added. * Recoverystatement fixed * Checkup function added * Updated logic for test * Added recovery validation logic Co-authored-by: Oleksandr Sarapulov <[email protected]>
- Loading branch information
1 parent
6494cb8
commit 9dc485e
Showing
6 changed files
with
269 additions
and
3 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
57 changes: 57 additions & 0 deletions
57
decoder/src/test/java/dgca/verifier/app/decoder/CertificateCheckTest.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
package dgca.verifier.app.decoder | ||
|
||
import dgca.verifier.app.decoder.model.RecoveryStatement | ||
import org.junit.Assert | ||
import org.junit.Test | ||
|
||
class CertificateCheckTest { | ||
@Test | ||
fun TestTestValidity() { | ||
val test = dgca.verifier.app.decoder.model.Test( | ||
"12", | ||
"", | ||
"", | ||
"", | ||
"2021-02-20T12:34:56Z", | ||
"", | ||
"260415000", | ||
"", | ||
"", | ||
"", | ||
"" | ||
) | ||
Assert.assertTrue(test.isDateInThePast()) | ||
Assert.assertTrue(test.isResultNegative()) | ||
} | ||
|
||
@Test | ||
fun testIsCertificateNotValidAnymore() { | ||
var recovery = RecoveryStatement("", "", "", "", "", "2021-03-04", "") | ||
Assert.assertTrue(recovery.isCertificateNotValidAnymore()!!) | ||
recovery = RecoveryStatement("", "", "", "", "", "2030-02-04", "") | ||
Assert.assertTrue(!recovery.isCertificateNotValidAnymore()!!) | ||
recovery = RecoveryStatement("", "", "", "", "", "2021-02-20T12:34:56Z", "") | ||
Assert.assertTrue(recovery.isCertificateNotValidAnymore()!!) | ||
recovery = RecoveryStatement("", "", "", "", "", "2007-12-03T10:15:30+01:00", "") | ||
Assert.assertTrue(recovery.isCertificateNotValidAnymore()!!) | ||
} | ||
|
||
@Test | ||
fun testIsCertificateNotValidSoFar() { | ||
var recovery = RecoveryStatement("", "", "", "", "2100-03-04", "", "") | ||
Assert.assertTrue(recovery.isCertificateNotValidSoFar()!!) | ||
recovery = RecoveryStatement("", "", "", "", "2000-02-04", "", "") | ||
Assert.assertTrue(!recovery.isCertificateNotValidSoFar()!!) | ||
recovery = RecoveryStatement("", "", "", "", "2100-02-20T12:34:56Z", "", "") | ||
Assert.assertTrue(recovery.isCertificateNotValidSoFar()!!) | ||
recovery = RecoveryStatement("", "", "", "", "2100-12-03T10:15:30+01:00", "", "") | ||
Assert.assertTrue(recovery.isCertificateNotValidSoFar()!!) | ||
} | ||
|
||
@Test | ||
fun testCertificateValidity() { | ||
val recovery = RecoveryStatement("", "", "", "", "", "", "") | ||
Assert.assertNull(recovery.isCertificateNotValidSoFar()) | ||
Assert.assertNull(recovery.isCertificateNotValidAnymore()) | ||
} | ||
} |
139 changes: 139 additions & 0 deletions
139
decoder/src/test/java/dgca/verifier/app/decoder/QrCodeTests.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,139 @@ | ||
package dgca.verifier.app.decoder; | ||
|
||
import org.junit.Assert; | ||
import org.junit.Test; | ||
import android.util.Base64; | ||
|
||
import java.io.ByteArrayInputStream; | ||
import java.io.InputStream; | ||
import java.security.cert.CertificateFactory; | ||
import java.security.cert.X509Certificate; | ||
|
||
import dgca.verifier.app.decoder.base45.Base45Decoder; | ||
import dgca.verifier.app.decoder.base45.Base45Service; | ||
import dgca.verifier.app.decoder.base45.DefaultBase45Service; | ||
import dgca.verifier.app.decoder.cbor.CborService; | ||
import dgca.verifier.app.decoder.cbor.DefaultCborService; | ||
import dgca.verifier.app.decoder.compression.CompressorService; | ||
import dgca.verifier.app.decoder.compression.DefaultCompressorService; | ||
import dgca.verifier.app.decoder.cose.CoseService; | ||
import dgca.verifier.app.decoder.cose.CryptoService; | ||
import dgca.verifier.app.decoder.cose.DefaultCoseService; | ||
import dgca.verifier.app.decoder.cose.VerificationCryptoService; | ||
import dgca.verifier.app.decoder.model.CoseData; | ||
import dgca.verifier.app.decoder.model.GreenCertificate; | ||
import dgca.verifier.app.decoder.model.VerificationResult; | ||
import dgca.verifier.app.decoder.prefixvalidation.DefaultPrefixValidationService; | ||
import dgca.verifier.app.decoder.prefixvalidation.PrefixValidationService; | ||
import dgca.verifier.app.decoder.schema.DefaultSchemaValidator; | ||
import dgca.verifier.app.decoder.schema.SchemaValidator; | ||
|
||
public class QrCodeTests { | ||
|
||
X509Certificate toCertificate(String pubKey) throws java.security.cert.CertificateException | ||
{ | ||
byte[] in = java.util.Base64.getDecoder().decode(pubKey); | ||
InputStream inputStream = new ByteArrayInputStream(in); | ||
return (X509Certificate) CertificateFactory.getInstance("X.509").generateCertificate(inputStream); | ||
} | ||
|
||
boolean Verify(String prefix,String PublicKey) | ||
{ | ||
VerificationResult result = new VerificationResult(); | ||
Base45Service b45Service = new DefaultBase45Service(); | ||
PrefixValidationService prefService = new DefaultPrefixValidationService(); | ||
CompressorService compressorService = new DefaultCompressorService(); | ||
SchemaValidator validator = new DefaultSchemaValidator(); | ||
CoseService coseservice = new DefaultCoseService(); | ||
CborService cborservice = new DefaultCborService(); | ||
|
||
String base45=prefService.decode(prefix,result); | ||
byte[] compressed = b45Service.decode(base45,result); | ||
byte[] cose = compressorService.decode(compressed,result); | ||
CoseData cbor = coseservice.decode(cose,result); | ||
|
||
GreenCertificate greenCertificate= cborservice.decode(cbor.getCbor(),result); | ||
|
||
boolean schemaresult = validator.validate(cbor.getCbor(),result); | ||
|
||
CryptoService cryptoService = new VerificationCryptoService(); | ||
X509Certificate cert = null; | ||
try { | ||
cert = toCertificate(PublicKey); | ||
} | ||
catch (Exception ex) | ||
{ | ||
return false; | ||
} | ||
|
||
cryptoService.validate(cose,cert,result); | ||
|
||
return result.isValid(); | ||
} | ||
|
||
|
||
@Test | ||
public void testPLCode() | ||
{ | ||
String hCert = "HC1:6BFOXN%TS3DH1QG9WA6H98BRPRHO DJS4F3S-%2LXKQGLAVDQ81LO2-36/X0X6BMF6.UCOMIN6R%E5UX4795:/6N9R%EPXCROGO3HOWGOKEQBKL/645YPL$R-ROM47E.K6K8I115DL-9C1QD+82D8C+ CH8CV9CA$DPN0NTICZU80LZW4Z*AK.GNNVR*G0C7PHBO33/X086BTTTCNB*UJHMJ8J3HONNQN09B5PNVNNWGJZ730DNHMJSLJ*E3G23B/S7-SN2H N37J3 QTULJ7CB3ZC6.27AL4%IY.IQH5YRT5*K51T 1DT 456L X4CZKHKB-43.E3KD3OAJ/9TL4T1C9 UP IPGTUI7FKQU2N1L8VFLU9WU.B9 UPYR181A0+P8V7/JA--J/XTQWE/PEBLEH-BY.CECH$6KJEM*PC9JAU-BZ8ERJCS0DUMQI+O1-ST*QGTA4W7.Y7G+SB.V Q5NN9TJ1TM8554.8EW E2NS6F9$J3-MQPSUB*H1EI+TUN73 39EX4165ABSXFB487V*K9J8UJC08H3N7T:DAIJC8K8T3TCF*6P.OB9Q721UJ+K.OJ4EW/S1*13PNG"; | ||
Base45Decoder base45Decoder= new dgca.verifier.app.decoder.base45.Base45Decoder(); | ||
DefaultCertificateDecoder decoder = new DefaultCertificateDecoder(base45Decoder); | ||
CertificateDecodingResult result = decoder.decodeCertificate(hCert); | ||
Assert.assertTrue(result instanceof CertificateDecodingResult.Success); | ||
|
||
String pubkey= "MIICnDCCAkKgAwIBAgIIJr8oA/3jYAQwCgYIKoZIzj0EAwIwUDEkMCIGA1UEAwwbUG9sYW5kIERHQyBSb290Q1NDQSAxIEFDQyBTMRswGQYDVQQKDBJNaW5pc3RyeSBvZiBIZWFsdGgxCzAJBgNVBAYTAlBMMB4XDTIxMDUyNDExMTgxNloXDTIzMDUyNDExMTgxNlowcjEtMCsGA1UEAwwkUG9sYW5kIFZhY2NpbmF0aW9uIERHQyBTZXJ2aWNlIDMgQUNDMRcwFQYDVQQLDA5lSGVhbHRoIENlbnRlcjEbMBkGA1UECgwSTWluaXN0cnkgb2YgSGVhbHRoMQswCQYDVQQGEwJQTDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABBb5V0Rbo5Qc1yAVxRyXaLt/QjmI4WG3qsXf81WoH6L2Uf4oj5iGnAuem1TSotax+FUgvn+GbcUg7BTrL+ePAQSjgeMwgeAwHwYDVR0jBBgwFoAUqc15HwkAJgfQl/0DpjHxRVJ9E28wFgYDVR0lBA8wDQYLKwYBBAGON49lAQIwTAYDVR0fBEUwQzBBoD+gPYY7aHR0cDovL2FjYy1wMS5lemRyb3dpZS5nb3YucGwvY2NwMS9jcmwvREdDUm9vdENTQ0ExQUNDUy5jcmwwHQYDVR0OBBYEFAenLsHAhybxn8MjzWYLq+xrD8iYMCsGA1UdEAQkMCKADzIwMjEwNTI0MTExODE2WoEPMjAyMjA1MjQxMTE4MTZaMAsGA1UdDwQEAwIHgDAKBggqhkjOPQQDAgNIADBFAiEAw17oXs3K8q+VorcGq014/zCZAnxqRIQ6fCkHGCENJWQCIB3hvpk+NdLphX7aokerbhsF6xuJ7hT6DnD67SFgLI/9"; | ||
|
||
Assert.assertTrue(Verify(hCert,pubkey)); | ||
} | ||
|
||
@Test | ||
public void testBgCode() | ||
{ | ||
String hCert="HC1:NCFOXN*TS0BI$ZDYSHIAL*ECH 8S021091JDNDC3LE84DIJ9CIE7-78WA46VGOU:ZH6I1%4JF 2K%5PK9CZLEQ56SP.E5BQ95ZM3763LED6N%ZEXE6%HULAV**M82F93I6*6 %6PK9B/0MCIMMISVDG8C5DL-9C1QDW33C8C0U09B91*KEDC6J0GJ4JXGHHBIWB.80XUTKQS7DS2*N.SSBNKA.G.P6A8IM%OVNIA KZ*U0I1-I0*OC6H0UWM2NISGH*BSPRAFTI/T1A.PECGX%EN+P.Y0/9TL4T.B9GYPNIN:EWD QZQHU*PH86DROI%KXYNYKTKK1Y R/03YVBO7L.CCP7A+5S*T08JFHAIN95+Y5 P4KDO+*OH:7SA7G6MS/5U*O3DRE6P6/QVHPOVQJT5FT5D75W9AV88G64KE809KV+EYMOL61I/JTYJJP66IL/XCBJBJ3DJGOBIG2%5AM4T/JKATN5NN7TA9QB.PY38PMKIQJ8:P-TVS L$W8LOAFXUWWLP-RO1E550%/OE5"; | ||
Base45Decoder base45Decoder= new dgca.verifier.app.decoder.base45.Base45Decoder(); | ||
DefaultCertificateDecoder decoder = new DefaultCertificateDecoder(base45Decoder); | ||
CertificateDecodingResult result = decoder.decodeCertificate(hCert); | ||
Assert.assertTrue(result instanceof CertificateDecodingResult.Success); | ||
|
||
String pubkey= "MIICpDCCAkugAwIBAgIUCQqeQIDhCUErUgTaGLQWtpazE0wwCgYIKoZIzj0EAwIwbDELMAkGA1UEBhMCQkcxGzAZBgNVBAoMEk1pbmlzdHJ5IG9mIEhlYWx0aDEiMCAGA1UECwwZSGVhbHRoIEluZm9ybWF0aW9uIFN5c3RlbTEcMBoGA1UEAwwTQnVsZ2FyaWEgREdDIENTQ0EgMTAeFw0yMTA1MTExMzM1NDFaFw0yMzA1MTExMzM1NDFaMHIxCzAJBgNVBAYTAkJHMQ4wDAYDVQQHDAVTb2ZpYTEbMBkGA1UECgwSTWluaXN0cnkgb2YgSGVhbHRoMSIwIAYDVQQLDBlIZWFsdGggSW5mb3JtYXRpb24gU3lzdGVtMRIwEAYDVQQDDAlER0MgRFNDIDEwWTATBgcqhkjOPQIBBggqhkjOPQMBBwNCAATKS3U1ssyUkLU8/l+N4WLHBJtJv7EfhhHSCS4sIDmxC1IEvSDNeWGBNRAd0y4c2qvk3mggEWTvXl4EemFOI4LCo4HEMIHBMAwGA1UdEwEB/wQCMAAwLAYDVR0fBCUwIzAhoB+gHYYbaHR0cDovL2NybC5oaXMuYmcvY3NjYTEuY3JsMB8GA1UdIwQYMBaAFCquB6sY+uzcJ1Q7ebdy5EPK5zMLMB0GA1UdDgQWBBSZ1xpVCsU4Ccmz1cn4cK+Af0o3gTAOBgNVHQ8BAf8EBAMCB4AwMwYDVR0lBCwwKgYMKwYBBAEAjjePZQEBBgwrBgEEAQCON49lAQIGDCsGAQQBAI43j2UBAzAKBggqhkjOPQQDAgNHADBEAiAZG+XA04EByYpauBQIaGiv6Jy7Y/N7FTmYscaQ4NeKJwIga1u+9Pq8+63QeU6gsCkf+jIKppr58EQMA6UF1I11VDE="; | ||
Assert.assertTrue(Verify(hCert,pubkey)); | ||
} | ||
|
||
@Test | ||
public void testDECode() | ||
{ | ||
String hCert="HC1:6BFR%BH:7*I0PS33NUA9HWP5PZ2CLJ*GH7WV-UNA1VZJKZ6HX.A/5R..9*CV6+LJ*F.UN7A2BT8B+6B897S69R48S1.R1VJO9Q1ZZO+CC$A9%T5X7RI25A8S57D JK-PQ+JR*FDTW3+1EC1JXLOQ58+KFL49ZMENAO.YOWR75PAH0HD6AIHCPWHJTF.RJ*JCSKEHL1N31HWEO67KJH8TIX-B3QB-+9*LCU:C:P2QEEQ7KF$V--4CW7JWILDWU%Q%IO0LAK70J$KW2JW56.KO8E2RHPH60ILI8T0N/7OEPD7P3+3IH9VZIVWP.44FX87QH5I97ZK0MK8OIGC3 3CQ6WO+9P9ECRSV%72M4L65 KAVKE*YPRHSIF1 89*4NDZ7FU6:F6NPJ1PHL059BGBB1%/C/J91R75Z5I7CWV0TREWYSY8ULK5HWPGEP$SI5B1$8HDOCH3JEBCL*8SE2AZT9SC+84JVGR39:2V*TR:KBW/4S:FK DOHF-1789MQ.18CV2C3YCN79OR176:1U:0CQVNGDJ0GUPO%CRT+QC/O$:D/WQY$3*5UR2M4YPFXK$DH"; | ||
Base45Decoder base45Decoder= new dgca.verifier.app.decoder.base45.Base45Decoder(); | ||
DefaultCertificateDecoder decoder = new DefaultCertificateDecoder(base45Decoder); | ||
CertificateDecodingResult result = decoder.decodeCertificate(hCert); | ||
Assert.assertTrue(result instanceof CertificateDecodingResult.Success); | ||
} | ||
|
||
@Test | ||
public void testNOCode(){ | ||
|
||
String hCert= "HC1:NCF780+80T9WTWGSLKC 4J9965QTH121L3LCFBB*A3*70M+9FN03DCZSJWY0JAC4+UD97TK0F90KECTHGWJC0FDVQ4AIA%G7X+AQB9746VG7W0AV+AWM96X6FCAJY8-F6846W%6V%60ZAKB7UPCBJCR1AFVC*70LVC6JD846Y96A464W5.A6+EDL8F9-98LE* CMEDM-DXC9 QE-ED8%EDZCX3E$34Z$EXVD-NC%69AECAWE.JCBECB1A-:8$966469L6OF6VX6Q$D.UDRYA 96NF6L/5SW6Y57KQEPD09WEQDD+Q6TW6FA7C466KCN9E%961A6DL6FA7D46JPCT3E5JDMA7346D463W5Z57..DX%DZJC7/DCWO3/DTVDD5D9-K3VCI3DU2DGECUGDK MLPCG/D2SDUWGR095Y8DWO0IAMPCG/DU2DRB8SE9VXI$PC5$CUZCZ$5Y$527B0DR-NGD9R696*KOX$N3E5G-ER 5ZOHMLQW4O-1M1I0OHE1SVLZNT361*ED+E7ICER5-HMV*47OO$5J+%Q8KU7+G275H7TDX9R+GZWG"; | ||
Base45Decoder base45Decoder= new dgca.verifier.app.decoder.base45.Base45Decoder(); | ||
DefaultCertificateDecoder decoder = new DefaultCertificateDecoder(base45Decoder); | ||
CertificateDecodingResult result = decoder.decodeCertificate(hCert); | ||
Assert.assertTrue(result instanceof CertificateDecodingResult.Success); | ||
|
||
String pubkey= "MIICKTCCAc+gAwIBAgITewAAAB77yzK1mZYu7QAAAAAAHjAKBggqhkjOPQQDAjA/MQswCQYDVQQGEwJOTzEbMBkGA1UEChMSTm9yc2sgaGVsc2VuZXR0IFNGMRMwEQYDVQQDEwpDU0NBIE5PIHYxMB4XDTIxMDYwNzA1NTY0MloXDTIzMDYwNzA2MDY0MlowUjELMAkGA1UEBhMCTk8xLTArBgNVBAoTJE5vcndlZ2lhbiBJbnN0aXR1dGUgb2YgUHVibGljIEhlYWx0aDEUMBIGA1UEAxMLRFNDIEhOIEVVIDIwWTATBgcqhkjOPQIBBggqhkjOPQMBBwNCAAR0UprGbSmy5WsMAyb0GXbzemkLRvmUNswy1lBGavDjHW7CTYPd+7yG/OGaXetTnboH0jDJeL1vVQvOr12T4+teo4GWMIGTMA4GA1UdDwEB/wQEAwIHgDAzBgNVHSUELDAqBgwrBgEEAQCON49lAQEGDCsGAQQBAI43j2UBAgYMKwYBBAEAjjePZQEDMB0GA1UdDgQWBBT1z+dhLhI7/AUOAdFiK4oqzEAlrzAfBgNVHSMEGDAWgBRBY3L2ecPBcffxgRI2UhCjJQp0JzAMBgNVHRMBAf8EAjAAMAoGCCqGSM49BAMCA0gAMEUCIDnEDlot8V1hen18ra7Xjv2bGL1mdz7453ItRdx4ubllAiEAkZZKE14rprcfPW6lKcS+SwQr7IWCrMYb/nZdhecUAHM="; | ||
|
||
Assert.assertTrue(Verify(hCert,pubkey)); | ||
} | ||
|
||
@Test | ||
public void testNormalCode() | ||
{ | ||
String hCert= "HC1:NCFOXNEG2NBJ5*H:QO-.OMBN+XQ99N*6RFS5*TCVWBM*4ODMS0NSRHAL9.4I92P*AVAN9I6T5XH4PIQJAZGA2:UG%U:PI/E2$4JY/KB1TFTJ:0EPLNJ58G/1W-26ALD-I2$VFVVE.80Z0 /KY.SKZC*0K5AFP7T/MV*MNY$N.R6 7P45AHJSP$I/XK$M8TH1PZB*L8/G9HEDCHJ4OIMEDTJCJKDLEDL9CVTAUPIAK29VCN 1UTKFYJZJAPEDI.C$JC7KDF9CFVAPUB1VCSWC%PDMOLHTC$JC3EC66CTS89B9F$8H.OOLI7R3Y+95AF3J6FB5R8QMA70Z37244FKG6T$FJ7CQRB0R%5 47:W0UFJU.UOJ98J93DI+C0UEE-JEJ36VLIWQHH$QIZB%+N+Y2AW2OP6OH6XO9IE5IVU$P26J6 L6/E2US2CZU:80I7JM7JHOJKYJPGK:H3J1D1I3-*TW CXBD+$3PY2C725SS+TDM$SF*SHVT:5D79U+GC5QS+3TAQS:FLU+34IU*9VY-Q9P9SEW-AB+2Q2I56L916CO8T C609O1%NXDU-:R4TICQA.0F2HFLXLLWI8ZU53BMQ2N U:VQQ7RWY91SV2A7N3WQ9J9OAZ00RKLB2"; | ||
Base45Decoder base45Decoder= new dgca.verifier.app.decoder.base45.Base45Decoder(); | ||
DefaultCertificateDecoder decoder = new DefaultCertificateDecoder(base45Decoder); | ||
CertificateDecodingResult result = decoder.decodeCertificate(hCert); | ||
Assert.assertTrue(result instanceof CertificateDecodingResult.Success); | ||
|
||
String pubkey= "MIIBzDCCAXGgAwIBAgIUDN8nWnn8gBmlWgL3stwhoinVD5MwCgYIKoZIzj0EAwIwIDELMAkGA1UEBhMCR1IxETAPBgNVBAMMCGdybmV0LmdyMB4XDTIxMDUxMjExMjY1OFoXDTIzMDUxMjExMjY1OFowIDELMAkGA1UEBhMCR1IxETAPBgNVBAMMCGdybmV0LmdyMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEBcc6ApRZrh9/qCuMnxIRpUujI19bKkG+agj/6rPOiX8VyzfWvhptzV0149AFRWdSoF/NVuQyFcrBoNBqL9zCAqOBiDCBhTAOBgNVHQ8BAf8EBAMCB4AwHQYDVR0OBBYEFN6ZiC57J/yRqTJ/Tg2eRspLCHDhMB8GA1UdIwQYMBaAFNU5HfWNY37TbdZjvsvO+1y1LPJYMDMGA1UdJQQsMCoGDCsGAQQBAI43j2UBAQYMKwYBBAEAjjePZQECBgwrBgEEAQCON49lAQMwCgYIKoZIzj0EAwIDSQAwRgIhAN6rDdE4mtTt2ZuffpZ242/B0lmyvdd+Wy6VuX+J/b01AiEAvME52Y4zqkQDuj2kbfCfs+h3uwYFOepoBP14X+Rd/VM="; | ||
|
||
Assert.assertTrue(Verify(hCert,pubkey)); | ||
} | ||
} |