From: Felix Dörre Date: Sun, 15 Nov 2015 22:47:51 +0000 (+0100) Subject: add: implement a test manager that will succeed all domain pings (for X-Git-Url: https://code.wpia.club/?p=gigi.git;a=commitdiff_plain;h=e5556cd3746047fd46bded4571a923f6b5795432 add: implement a test manager that will succeed all domain pings (for now) --- diff --git a/util-testing/org/cacert/gigi/pages/Manager.java b/util-testing/org/cacert/gigi/pages/Manager.java index 8f77afbd..30daa4d0 100644 --- a/util-testing/org/cacert/gigi/pages/Manager.java +++ b/util-testing/org/cacert/gigi/pages/Manager.java @@ -21,13 +21,17 @@ import java.util.Properties; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import org.cacert.gigi.Gigi; import org.cacert.gigi.GigiApiException; import org.cacert.gigi.crypto.SPKAC; import org.cacert.gigi.database.DatabaseConnection; import org.cacert.gigi.database.GigiPreparedStatement; import org.cacert.gigi.dbObjects.Certificate; import org.cacert.gigi.dbObjects.Certificate.CertificateStatus; +import org.cacert.gigi.dbObjects.CertificateOwner; import org.cacert.gigi.dbObjects.Digest; +import org.cacert.gigi.dbObjects.Domain; +import org.cacert.gigi.dbObjects.DomainPingType; import org.cacert.gigi.dbObjects.EmailAddress; import org.cacert.gigi.dbObjects.Group; import org.cacert.gigi.dbObjects.Name; @@ -37,6 +41,8 @@ import org.cacert.gigi.localisation.Language; import org.cacert.gigi.output.template.IterableDataset; import org.cacert.gigi.output.template.Template; import org.cacert.gigi.pages.account.certs.CertificateRequest; +import org.cacert.gigi.ping.DomainPinger; +import org.cacert.gigi.ping.PingerDaemon; import org.cacert.gigi.util.AuthorizationContext; import org.cacert.gigi.util.Notary; @@ -48,6 +54,8 @@ public class Manager extends Page { Field f; + private static HashMap dps; + private Manager() { super("Test Manager"); try { @@ -58,6 +66,27 @@ public class Manager extends Page { System.out.println("I don't have 'hash', we are working probably in layered mode. Test Manager may not work."); // throw new Error(e); } + + try { + Field gigiInstance = Gigi.class.getDeclaredField("instance"); + gigiInstance.setAccessible(true); + Gigi g = (Gigi) gigiInstance.get(null); + + Field gigiPinger = Gigi.class.getDeclaredField("pinger"); + gigiPinger.setAccessible(true); + PingerDaemon pd = (PingerDaemon) gigiPinger.get(g); + + Field f = PingerDaemon.class.getDeclaredField("pingers"); + f.setAccessible(true); + dps = (HashMap) f.get(pd); + HashMap pingers = new HashMap<>(); + for (DomainPingType dpt : DomainPingType.values()) { + pingers.put(dpt, new PingerFetcher(dpt)); + } + f.set(pd, pingers); + } catch (ReflectiveOperationException e) { + e.printStackTrace(); + } } public User[] getAssurers() { @@ -131,6 +160,22 @@ public class Manager extends Page { } + public static class PingerFetcher extends DomainPinger { + + private DomainPingType dpt; + + public PingerFetcher(DomainPingType dpt) { + this.dpt = dpt; + } + + @Override + public void ping(Domain domain, String configuration, CertificateOwner target, int confId) { + System.out.println("Test: " + domain); + dps.get(dpt).ping(domain, configuration, target, confId); + } + + } + public void batchCreateUsers(String mailPrefix, String domain, int amount, PrintWriter out) { try {