Example #1
0
        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));
        }
Example #2
0
        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));
        }