(no commit message)
[utils] / system / general / src / test / java / org / wamblee / system / Environment.java
index 56118ccbb7fb325d1c96616bc017800b9bff4549..d6465d68e3266b0fc60c0e508ac0db118df8a765 100644 (file)
@@ -2,27 +2,45 @@ package org.wamblee.system;
 
 import javax.sql.DataSource;
 
+import org.wamblee.test.EventTracker;
 
-public class Environment extends AbstractSubSystem {
+
+public class Environment extends AbstractComponent {
        
-       private static final ProvidedServiceDescriptor[] PROVIDED = 
-               new ProvidedServiceDescriptor[] { 
-                       new DefaultProvidedServiceDescriptor("datasource", DataSource.class), 
-                       new DefaultProvidedServiceDescriptor("integer", Integer.class)
+       private static final ProvidedInterface[] provided() { 
+               return new ProvidedInterface[] { 
+                       new DefaultProvidedInterface("datasource", DataSource.class), 
+                       new DefaultProvidedInterface("integer", Integer.class)
        };
+       }
+       
+       private EventTracker<String> _tracker; 
        
-       public Environment(ServiceRegistry aRegistry) { 
-               super("environment", aRegistry, PROVIDED, new ServiceDescriptor[0]);
+       public Environment() { 
+               super("environment", provided(), new RequiredInterface[0]);
        }
        
-       @Override
-       protected void doStart(String aContext, Service[] aRequiredServices) {
-           addService(aContext, PROVIDED[0], new Integer(1));
-           addService(aContext, PROVIDED[1], new Integer(2));
+       public Environment(EventTracker aTracker) { 
+               this();
+               _tracker = aTracker; 
        }
        
+       @Override
+       protected void doStart(String aContext) {
+           addService(aContext, getProvidedServices()[0], new Integer(1));
+           addService(aContext, getProvidedServices()[1], new Integer(2));
+           track("start." + getName());
+       }
+
        @Override
        protected void doStop() {
-               // Empty.       
+               track("stop." + getName());
+       }
+       
+       private void track(String aString) {
+               if ( _tracker == null ) { 
+                       return; 
+               }
+               _tracker.eventOccurred(aString);
        }
 }