X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=system%2Fgeneral%2Fsrc%2Ftest%2Fjava%2Forg%2Fwamblee%2Fsystem%2Fcore%2FEnvironment.java;h=c202d1ab23d317e83701bd8ba71d90e555466810;hb=0d8d8f24656e585ee75558cfd6a4c661f8f14985;hp=2fa1c4cf374471412837905cfa76ffe30bf676d9;hpb=4845c677310814de4c98e22aad483e49b9dfc594;p=utils diff --git a/system/general/src/test/java/org/wamblee/system/core/Environment.java b/system/general/src/test/java/org/wamblee/system/core/Environment.java index 2fa1c4cf..c202d1ab 100644 --- a/system/general/src/test/java/org/wamblee/system/core/Environment.java +++ b/system/general/src/test/java/org/wamblee/system/core/Environment.java @@ -12,7 +12,7 @@ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. - */ + */ package org.wamblee.system.core; import javax.sql.DataSource; @@ -23,43 +23,70 @@ import org.wamblee.system.core.ProvidedInterface; import org.wamblee.system.core.RequiredInterface; import org.wamblee.test.EventTracker; +public class Environment extends AbstractComponent { -public class Environment extends AbstractComponent { - - private static final ProvidedInterface[] provided() { - return new ProvidedInterface[] { - new DefaultProvidedInterface("datasource", DataSource.class), - new DefaultProvidedInterface("integer", Integer.class) - }; + private static final ProvidedInterface[] provided(String aPrefix) { + return new ProvidedInterface[] { + new DefaultProvidedInterface(aPrefix + "datasource", String.class), + new DefaultProvidedInterface(aPrefix + "integer", Integer.class) }; } - private EventTracker _tracker; - - public Environment() { - super("environment", provided(), new RequiredInterface[0]); + private static int COUNT = 0; + + private EventTracker tracker; + private double random; + private int integer; + + public Environment() { + this("environment"); } - public Environment(EventTracker aTracker) { + public Environment(String aName) { + this(aName, ""); + } + + public Environment(String aName, String aPrefix) { + super(aName, provided(aPrefix), new RequiredInterface[0]); + random = Math.random(); + integer = COUNT++; + } + + + + public Environment(EventTracker aTracker) { this(); - _tracker = aTracker; + tracker = aTracker; } - + + public Integer getInteger() { + return integer; + } + + public String getString() { + return getName() + ".hello"; + } + @Override - protected void doStart() { - addService(getProvidedServices()[0], new Integer(1)); - addService(getProvidedServices()[1], new Integer(2)); - track("start." + getName()); + protected Object doStart(Scope aScope) { + addInterface(getProvidedInterfaces().get(0), getString(), aScope); + addInterface(getProvidedInterfaces().get(1), getInteger(), aScope); + track("start." + getName()); + return random; } @Override - protected void doStop() { + 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) { - if ( _tracker == null ) { - return; + if (tracker == null) { + return; } - _tracker.eventOccurred(aString); + tracker.eventOccurred(aString); } }