public void FailExpired() { DateTime time = new DateTime(2014, 03, 15, 12, 0, 0); var cert = new X509Certificate2("files/expired.crt"); IList<CertificateList> crls = new List<CertificateList>(); IList<BasicOcspResponse> ocps = new List<BasicOcspResponse>(); Chain chain = cert.BuildChain(time, null, ref crls, ref ocps, time); Assert.AreEqual(1, crls.Count); Assert.AreEqual(1, ocps.Count); Assert.AreEqual(1, chain.ChainStatus.Count(x => x.Status == X509ChainStatusFlags.NotTimeValid)); Assert.AreEqual(1, chain.ChainElements[0].ChainElementStatus.Count(x => x.Status == X509ChainStatusFlags.NotTimeValid)); Assert.AreEqual(0, chain.ChainElements[1].ChainElementStatus.Count(x => x.Status != X509ChainStatusFlags.NoError)); Assert.AreEqual(0, chain.ChainElements[2].ChainElementStatus.Count(x => x.Status != X509ChainStatusFlags.NoError)); }
public void Success10() { DateTime time = DateTime.UtcNow; if (time > new DateTime(2019, 3, 19)) Assert.Inconclusive("The cert is (or will very soon be) expired"); var cert = new X509Certificate2("files/foreigner.crt"); var caCert = new X509Certificate2("files/foreigner_ca.crt"); IList<CertificateList> crls = new List<CertificateList>(new CertificateList[] { }); IList<BasicOcspResponse> ocps = new List<BasicOcspResponse>(new BasicOcspResponse[] { }); X509Certificate2Collection inter = new X509Certificate2Collection(caCert); Chain chain = cert.BuildChain(time, inter, ref crls, ref ocps, time, true, new TimeSpan(1, 0, 0)); Assert.AreEqual(1, crls.Count); Assert.AreEqual(1, ocps.Count); Assert.AreEqual(0, chain.ChainStatus.Count(x => x.Status != X509ChainStatusFlags.NoError)); Assert.AreEqual(0, chain.ChainElements[0].ChainElementStatus.Count(x => x.Status != X509ChainStatusFlags.NoError)); Assert.AreEqual(0, chain.ChainElements[1].ChainElementStatus.Count(x => x.Status != X509ChainStatusFlags.NoError)); Assert.AreEqual(0, chain.ChainElements[2].ChainElementStatus.Count(x => x.Status != X509ChainStatusFlags.NoError)); }