public async Task TestChallengeRequestHttp01() { var site = await iisManager.GetIISSiteById(_siteId); Assert.AreEqual(site.Name, testSiteName); var dummyManagedCertificate = new ManagedCertificate { Id = Guid.NewGuid().ToString(), Name = testSiteName, GroupId = site.Id.ToString(), RequestConfig = new CertRequestConfig { PrimaryDomain = testSiteDomain, Challenges = new ObservableCollection <CertRequestChallengeConfig>( new List <CertRequestChallengeConfig> { new CertRequestChallengeConfig { ChallengeType = "http-01" } }), PerformAutoConfig = true, PerformAutomatedCertBinding = true, PerformChallengeFileCopy = true, PerformExtensionlessConfigChecks = true, WebsiteRootPath = testSitePath }, ItemType = ManagedCertificateType.SSL_LetsEncrypt_LocalIIS }; var result = await certifyManager.PerformCertificateRequest(null, dummyManagedCertificate); //ensure cert request was successful Assert.IsTrue(result.IsSuccess, "Certificate Request Not Completed"); //check details of cert, subject alternative name should include domain and expiry must be great than 89 days in the future var managedCertificates = await certifyManager.GetManagedCertificates(); var managedCertificate = managedCertificates.FirstOrDefault(m => m.Id == dummyManagedCertificate.Id); //emsure we have a new managed site Assert.IsNotNull(managedCertificate); //have cert file details Assert.IsNotNull(managedCertificate.CertificatePath); var fileExists = System.IO.File.Exists(managedCertificate.CertificatePath); Assert.IsTrue(fileExists); //check cert is correct var certInfo = CertificateManager.LoadCertificate(managedCertificate.CertificatePath); Assert.IsNotNull(certInfo); var isRecentlyCreated = Math.Abs((DateTime.UtcNow - certInfo.NotBefore).TotalDays) < 2; Assert.IsTrue(isRecentlyCreated); var expiresInFuture = (certInfo.NotAfter - DateTime.UtcNow).TotalDays >= 89; Assert.IsTrue(expiresInFuture); // remove managed site await certifyManager.DeleteManagedCertificate(managedCertificate.Id); }