X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=system%2Fgeneral%2Fsrc%2Ftest%2Fjava%2Forg%2Fwamblee%2Fsystem%2FApplication.java;h=3b84b3cb1788a93eaaef6d88a602dfb6cd2f44d0;hb=0c19405988efb348c1bc1636b8bde49a6776a743;hp=d5a3590db2775b0479a4ac857323e3492e7a66d0;hpb=16504cb35c59542f7817abfe3c852e9fedd870a3;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 d5a3590d..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,24 +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(ServiceRegistry aRegistry) { - super("application", aRegistry, new ServiceDescriptor[0], REQUIRED); + public Application() { + super("application", new ProvidedInterface[0], required()); + } + + public Application(EventTracker aTracker) { + this(); + _tracker = aTracker; } @Override - protected void doStart(String aContext, Service[] aRequiredServices) { - // Empty, no services provided externally. + protected void doStart(String aContext) { + track("start." + getName()); } @Override protected void doStop() { - // Empty. + track("stop." + getName()); + } + + private void track(String aString) { + if ( _tracker == null ) { + return; + } + _tracker.eventOccurred(aString); } }