[svn r325] some cleaning, adding speed improvements !!, and started on junit tests.
This commit is contained in:
parent
21f99c5634
commit
7c57017fff
28 changed files with 266 additions and 483 deletions
|
|
@ -1,7 +1,7 @@
|
|||
|
||||
foei.context_name=TEST-0
|
||||
|
||||
foei.event_thread_listeners=tests.TestEventThreadListener
|
||||
foei.event_thread_listeners=com.idcanet.foei.TestEventThreadListener
|
||||
|
||||
foei.event_executor_manager.pool_core_size=5
|
||||
foei.event_executor_manager.pool_max_size=10
|
||||
|
|
@ -1,8 +1,47 @@
|
|||
|
||||
/*
|
||||
* Copyright 2004-2008 IDCA. All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
|
||||
* following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and
|
||||
* the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions
|
||||
* and the following disclaimer in the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY IDCA AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL IDCA OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
* The views and conclusions contained in the software and documentation are those of the authors and
|
||||
* should not be interpreted as representing official policies, either expressed or implied, of IDCA.
|
||||
*/
|
||||
|
||||
package com.idcanet.foei;
|
||||
|
||||
import java.io.InputStream;
|
||||
import java.util.Date;
|
||||
import java.util.Properties;
|
||||
|
||||
import com.idcanet.foei.components.lang.DummyOutputPort;
|
||||
import com.idcanet.foei.components.lang.Filter;
|
||||
import com.idcanet.foei.core.FoeiConfigurator;
|
||||
import com.idcanet.foei.core.FoeiContext;
|
||||
import com.idcanet.foei.core.FoeiProcess;
|
||||
import com.idcanet.foei.event.AbstractEventInput;
|
||||
import com.idcanet.foei.event.EventPort;
|
||||
import com.idcanet.foei.event.IllegalEventPortNameException;
|
||||
import com.idcanet.foei.server.FoeiContextManager;
|
||||
import com.idcanet.foei.server.FoeiContextManagerFactory;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
/**
|
||||
*
|
||||
|
|
@ -10,5 +49,119 @@ package com.idcanet.foei;
|
|||
* @author Willem Cazander
|
||||
* @version 1.0 Jul 27, 2006
|
||||
*/
|
||||
public class SimpleFoeiTests {
|
||||
public class SimpleFoeiTests extends TestCase {
|
||||
|
||||
private static FoeiContext test0 = null;
|
||||
|
||||
private void start() throws Exception {
|
||||
if (test0!=null) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Creates FoeiContextManager
|
||||
FoeiContextManager foeiContextManager = new FoeiContextManager();
|
||||
FoeiContextManagerFactory.setFoeiContextManager(foeiContextManager);
|
||||
|
||||
InputStream foeiProperties = this.getClass().getResourceAsStream("/META-INF/test-foei.properties");
|
||||
Properties properties = new Properties();
|
||||
properties.load(foeiProperties);
|
||||
foeiProperties.close();
|
||||
properties.put(FoeiConfigurator.ROOT_PATH,"/tmp");
|
||||
foeiContextManager.createFoeiContext(properties);
|
||||
|
||||
test0 = foeiContextManager.getFoeiContext("TEST-0");
|
||||
}
|
||||
|
||||
public void testStartup() throws Exception {
|
||||
start();
|
||||
assertNotNull(test0);
|
||||
}
|
||||
|
||||
public void testFoeiProcessLife() throws Exception {
|
||||
start();
|
||||
FoeiProcess proc = test0.getFoeiProcessManager().createFoeiProcess("testProces",test0);
|
||||
assertNotNull(proc);
|
||||
test0.getFoeiProcessManager().destroyFoeiProcess("testProces");
|
||||
assertNull(test0.getFoeiProcessManager().getFoeiProcess("testProces"));
|
||||
}
|
||||
|
||||
|
||||
|
||||
public void testSimpleSpeed() throws Exception {
|
||||
start();
|
||||
FoeiProcess proc = test0.getFoeiProcessManager().createFoeiProcess("testSpeed0",test0);
|
||||
assertNotNull(proc);
|
||||
|
||||
DummyOutputPort in = new DummyOutputPort();
|
||||
Filter f1 = new Filter();
|
||||
Filter f2 = new Filter();
|
||||
Filter f3 = new Filter();
|
||||
SpeedTestPort out = new SpeedTestPort();
|
||||
|
||||
//in.getOutputPort(EventPort.OUTPUT).setImmediate(true);
|
||||
|
||||
// saves 300ms on 100k records
|
||||
f1.getOutputPort(EventPort.PASS).setImmediate(true);
|
||||
f2.getOutputPort(EventPort.PASS).setImmediate(true);
|
||||
f3.getOutputPort(EventPort.PASS).setImmediate(true);
|
||||
|
||||
// has no effect !!
|
||||
//out.getInputPort(EventPort.INPUT).setImmediate(true);
|
||||
|
||||
proc.addBinding(in.getOutputPort(EventPort.OUTPUT), f1.getInputPort(EventPort.INPUT));
|
||||
proc.addBinding(f1.getOutputPort(EventPort.PASS), f2.getInputPort(EventPort.INPUT));
|
||||
proc.addBinding(f2.getOutputPort(EventPort.PASS), f3.getInputPort(EventPort.INPUT));
|
||||
proc.addBinding(f3.getOutputPort(EventPort.PASS), out.getInputPort(EventPort.INPUT));
|
||||
|
||||
long startTime = System.currentTimeMillis();
|
||||
for (int i=0;i<100000;i++) {
|
||||
SpeedModel m = new SpeedModel();
|
||||
|
||||
// IN FOEI it is;
|
||||
//proc.executeEvent(in.getOutputPort(EventPort.OUTPUT), m);
|
||||
|
||||
// running outside foei context thread use;
|
||||
proc.getFoeiContext().getEventExecutorManager().executeEvent(in.getOutputPort(EventPort.OUTPUT), m, proc);
|
||||
}
|
||||
proc.getFoeiContext().getEventExecutorManager().executeEvent(in.getOutputPort(EventPort.OUTPUT), new Date(), proc);
|
||||
long endTime = System.currentTimeMillis();
|
||||
System.out.println("Done sending in: "+(endTime-startTime)+" ms.");
|
||||
Thread.sleep(50000); // todo: create destory context on end of event que
|
||||
System.out.println("End speedtest");
|
||||
test0.getFoeiProcessManager().destroyFoeiProcess("testSpeed0");
|
||||
}
|
||||
|
||||
}
|
||||
class SpeedModel {
|
||||
Date dateCreated = new Date();
|
||||
Date dateDone = null;
|
||||
}
|
||||
class SpeedTestPort extends AbstractEventInput {
|
||||
|
||||
/** v1.0 */
|
||||
static final long serialVersionUID = 10l;
|
||||
Date startTime = new Date();
|
||||
|
||||
|
||||
/**
|
||||
* Creates the output port
|
||||
*/
|
||||
public SpeedTestPort() {
|
||||
addInputPort(EventPort.INPUT,Object.class);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see com.idcanet.foei.event.AbstractEventInput#doEvent(com.idcanet.foei.event.EventPort, java.lang.Object)
|
||||
*/
|
||||
@Override
|
||||
public void doEvent(EventPort eventPort, Object object) throws IllegalEventPortNameException {
|
||||
if (object instanceof SpeedModel) {
|
||||
SpeedModel m = (SpeedModel)object;
|
||||
m.dateDone=new Date();
|
||||
return;
|
||||
}
|
||||
// other object == end of test
|
||||
long endTime = System.currentTimeMillis();
|
||||
System.out.println("End of test: "+(endTime-startTime.getTime())+" ms.");
|
||||
}
|
||||
}
|
||||
|
|
@ -1,3 +1,28 @@
|
|||
/*
|
||||
* Copyright 2004-2008 IDCA. All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
|
||||
* following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and
|
||||
* the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions
|
||||
* and the following disclaimer in the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY IDCA AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL IDCA OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
* The views and conclusions contained in the software and documentation are those of the authors and
|
||||
* should not be interpreted as representing official policies, either expressed or implied, of IDCA.
|
||||
*/
|
||||
|
||||
package com.idcanet.foei;
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue