X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=system%2Fgeneral%2Fsrc%2Ftest%2Fjava%2Forg%2Fwamblee%2Fsystem%2FApplication.java;h=3b84b3cb1788a93eaaef6d88a602dfb6cd2f44d0;hb=0c19405988efb348c1bc1636b8bde49a6776a743;hp=77c76cb3120413b71163ad7af6a670b13480ec9e;hpb=4c7e63f11337abfaa6ea13eab4b6ca11891f4977;p=utils diff --git a/system/general/src/test/java/org/wamblee/system/Application.java b/system/general/src/test/java/org/wamblee/system/Application.java index 77c76cb3..3b84b3cb 100644 --- a/system/general/src/test/java/org/wamblee/system/Application.java +++ b/system/general/src/test/java/org/wamblee/system/Application.java @@ -2,20 +2,42 @@ package org.wamblee.system; import javax.sql.DataSource; -public class Application extends AbstractSubSystem { - private static final ServiceDescriptor[] REQUIRED = - new ServiceDescriptor[] { - new DefaultServiceDescriptor(DataSource.class), - new DefaultServiceDescriptor(Integer.class) +import org.wamblee.test.EventTracker; + +public class Application extends AbstractComponent { + private static RequiredInterface[] required() { + return + new RequiredInterface[] { + new DefaultRequiredInterface("datasource", DataSource.class), + new DefaultRequiredInterface("integer", Integer.class) }; + } + + private EventTracker _tracker; public Application() { - super("application", new ServiceDescriptor[0], REQUIRED); + super("application", new ProvidedInterface[0], required()); + } + + public Application(EventTracker aTracker) { + this(); + _tracker = aTracker; } @Override - protected void doStart(String aContext, ServiceRegistry aRegistry, Service[] aRequiredServices) { - // Empty, no services provided externally. + protected void doStart(String aContext) { + track("start." + getName()); + } + + @Override + protected void doStop() { + track("stop." + getName()); + } + + private void track(String aString) { + if ( _tracker == null ) { + return; + } + _tracker.eventOccurred(aString); } - }