X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=system%2Fgeneral%2Fsrc%2Ftest%2Fjava%2Forg%2Fwamblee%2Fsystem%2Fcore%2FEnvironment.java;h=901801bca0173a606dbb0c4b02b2ebd26fc73b71;hb=dec278a67997ea8e85d10662e31548afd8890ed3;hp=9ee40e3972306514a1e999172f50cef3f9dbf263;hpb=8a6ee427cf3de42d9dd9d8fea09ee9fd059ee53e;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 9ee40e39..901801bc 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 @@ -1,5 +1,5 @@ /* - * Copyright 2007 the original author or authors. + * Copyright 2005-2010 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -15,53 +15,94 @@ */ package org.wamblee.system.core; -import javax.sql.DataSource; - -import org.wamblee.system.core.AbstractComponent; -import org.wamblee.system.core.DefaultProvidedInterface; -import org.wamblee.system.core.ProvidedInterface; -import org.wamblee.system.core.RequiredInterface; import org.wamblee.test.EventTracker; +/** + * + * @author $author$ + * @version $Revision$ + */ +public class Environment extends AbstractComponent { + private static int COUNT = 0; + + private EventTracker tracker; + + private double random; + + private int integer; + + /** + * Creates a new Environment object. + */ + public Environment() { + this("environment"); + } + + /** + * Creates a new Environment object. + * + */ + public Environment(String aName) { + this(aName, ""); + } + + /** + * Creates a new Environment object. + * + */ + public Environment(String aName, String aPrefix) { + super(aName, provided(aPrefix), new RequiredInterface[0]); + random = Math.random(); + integer = COUNT++; + } + + /** + * Creates a new Environment object. + * + */ + public Environment(EventTracker aTracker) { + this(); + tracker = aTracker; + } + + private static final ProvidedInterface[] provided(String aPrefix) { + return new ProvidedInterface[] { + new DefaultProvidedInterface(aPrefix + "datasource", String.class), + new DefaultProvidedInterface(aPrefix + "integer", Integer.class) }; + } + + public Integer getInteger() { + return integer; + } + + public String getString() { + return getName() + ".hello"; + } + + @Override + 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(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; + } -public class Environment extends AbstractComponent { - - private static final ProvidedInterface[] provided() { - return new ProvidedInterface[] { - new DefaultProvidedInterface("datasource", DataSource.class), - new DefaultProvidedInterface("integer", Integer.class) - }; - } - - private EventTracker _tracker; - - public Environment() { - super("environment", provided(), new RequiredInterface[0]); - } - - public Environment(EventTracker aTracker) { - this(); - _tracker = aTracker; - } - - @Override - protected void doStart() { - addInterface(getProvidedInterfaces()[0], new Integer(1)); - addInterface(getProvidedInterfaces()[1], new Integer(2)); - track("start." + getName()); - } - - @Override - protected void doStop() { - track("stop." + getName()); - removeInterface(getProvidedInterfaces()[0]); - removeInterface(getProvidedInterfaces()[1]); - } - - private void track(String aString) { - if ( _tracker == null ) { - return; - } - _tracker.eventOccurred(aString); - } + tracker.eventOccurred(aString); + } }