Huge refactoring.
[utils] / system / general / src / test / java / org / wamblee / system / core / Application.java
index 16d1f36f0187b273810ae010dfaa8f77fb994b1c..07857aee2b7510fa05e87a056676b805b360ace8 100644 (file)
@@ -27,15 +27,19 @@ public class Application extends AbstractComponent {
        public static RequiredInterface[] required(boolean aOptional) {
                return
                new RequiredInterface[] { 
-                       new DefaultRequiredInterface("datasource", DataSource.class, aOptional), 
+                       new DefaultRequiredInterface("string", String.class, aOptional), 
                        new DefaultRequiredInterface("integer", Integer.class, aOptional)
        };
        }
 
        private EventTracker<String> _tracker;
+       private String _string; 
+       private Integer _integer;
+       private double _random; 
        
        public Application() {
-               super("application", new ProvidedInterface[0], required(false)); 
+               super("application", new ProvidedInterface[0], required(false));
+               _random = Math.random();
        }
        
        public Application(boolean aIsOptinal) { 
@@ -48,13 +52,28 @@ public class Application extends AbstractComponent {
        }
 
        @Override
-       protected void doStart() {
-               track("start." + getName()); 
+       protected Object doStart(Scope aScope) {
+               track("start." + getName());
+               _string = aScope.retrieveInterfaceImplementation(getRequiredInterfaces()[0].getProvider(), String.class);
+           _integer = aScope.retrieveInterfaceImplementation(getRequiredInterfaces()[1].getProvider(), Integer.class);
+           return _random; 
+       }
+       
+       public String getString() {
+               return _string;
+       }
+       
+       public Integer getInteger() {
+               return _integer;
        }
        
        @Override
-       protected void doStop() {
-               track("stop." + getName());     
+       protected void doStop(Object aRuntime) {
+               track("stop." + getName());
+               if ( _random != (Double)aRuntime) { 
+                       throw new IllegalArgumentException("Wrong runtime: expected " + _random + " but got " +
+                                       aRuntime);
+               }
        }
        
        private void track(String aString) {