test.tck.msgflow.callflows.router.AbstractRouterTestCase Maven / Gradle / Ivy
/*
* Conditions Of Use
*
* This software was developed by employees of the National Institute of
* Standards and Technology (NIST), and others.
* This software is has been contributed to the public domain.
* As a result, a formal license is not needed to use the software.
*
* This software is provided "AS IS."
* NIST MAKES NO WARRANTY OF ANY KIND, EXPRESS, IMPLIED
* OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTY OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT
* AND DATA ACCURACY. NIST does not warrant or make any representations
* regarding the use of the software or the results thereof, including but
* not limited to the correctness, accuracy, reliability or usefulness of
* the software.
*
*
*/
package test.tck.msgflow.callflows.router;
import javax.sip.SipListener;
import javax.sip.SipProvider;
import org.apache.log4j.Appender;
import org.apache.log4j.ConsoleAppender;
import org.apache.log4j.Logger;
import org.apache.log4j.SimpleLayout;
import test.tck.msgflow.callflows.NonSipUriRouter;
import test.tck.msgflow.callflows.ScenarioHarness;
/**
*
* Implements common setup and tearDown sequence for Router test
*
* @author M. Ranganathan
*
*/
public abstract class AbstractRouterTestCase extends ScenarioHarness implements
SipListener {
protected Shootist shootist;
protected Shootme shootme;
private static Logger logger = Logger.getLogger("test.tck");
static {
if (!logger.isAttached(console)) {
logger.addAppender(console);
}
}
public AbstractRouterTestCase() {
super("routeteluri", true);
}
public void setUp() throws Exception {
try {
super.setUp();
logger.info("RouterTest: setup()");
shootist = new Shootist(getTiProtocolObjects());
SipProvider shootistProvider = shootist.createProvider();
providerTable.put(shootistProvider, shootist);
shootme = new Shootme(getRiProtocolObjects());
SipProvider shootmeProvider = shootme.createProvider();
providerTable.put(shootmeProvider, shootme);
shootistProvider.addSipListener(this);
shootmeProvider.addSipListener(this);
if (getTiProtocolObjects() != getRiProtocolObjects())
getTiProtocolObjects().start();
getRiProtocolObjects().start();
} catch (Exception ex) {
logger.error("unexpected excecption ", ex);
fail("unexpected exception");
}
}
public void tearDown() throws Exception {
try {
Thread.sleep(2000);
this.shootist.checkState();
this.shootme.checkState();
assertTrue("Router was not consulted", NonSipUriRouter.routerWasConsulted);
NonSipUriRouter.routerWasConsulted = false;
super.tearDown();
Thread.sleep(1000);
this.providerTable.clear();
logTestCompleted();
} catch (Exception ex) {
logger.error("unexpected exception", ex);
fail("unexpected exception ");
}
super.tearDown();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy