Mercurial > hg > RemoteEditor > Eclipse
changeset 162:d96717ca6270
*** empty log message ***
author | kent |
---|---|
date | Tue, 26 Aug 2008 19:46:51 +0900 (2008-08-26) |
parents | 66e9cebce3fa |
children | 34f770c7fd86 |
files | src/pathfinder/mergetest/channels/test/testEditor.java src/pathfinder/mergetest/channels/test/testNetworkSimulator.java src/pathfinder/mergetest/channels/test/testSeMa.java src/pathfinder/mergetest/channels/test/testSeMaSlave.java |
diffstat | 4 files changed, 257 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pathfinder/mergetest/channels/test/testEditor.java Tue Aug 26 19:46:51 2008 +0900 @@ -0,0 +1,34 @@ +package pathfinder.mergetest.channels.test; + +import pathfinder.mergetest.channels.*; + +public class testEditor extends Thread{ + private NetworkSimulator<String> ns; + private int semaIP; + + public testEditor(NetworkSimulator<String> _ns, String name, int _ip){ + super(name); + ns = _ns; + semaIP = _ip; + } + + public void run(){ + ChannelSimulator<String> channel = new ChannelSimulator<String>(ns); + + ns.writeLog(this, "try to connect to SessionManager whose ip is "+semaIP, 1); + while (!channel.connect(semaIP)){ + ns.writeLog(this, "SeMa not listen to socket yet, wait", 1); + Thread.yield(); + } + ns.writeLog(this, "successes to connect", 1); + + channel.write("from "+getName()+": hello"); + ns.writeLog(this, "wrote packet", 1); + + String packet = channel.read(); + + ns.writeLog(this, "gets return string==> `"+packet+"\'", 1); + + ns.writeLog(this, "testEditor exits.", 1); + } +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pathfinder/mergetest/channels/test/testNetworkSimulator.java Tue Aug 26 19:46:51 2008 +0900 @@ -0,0 +1,69 @@ +package pathfinder.mergetest.channels.test; + +import java.util.ArrayList; +import java.util.Random; +import pathfinder.mergetest.channels.NetworkSimulator; + +public class testNetworkSimulator { + private NetworkSimulator<String> ns; + private ArrayList<testSeMa> semaList; + private ArrayList<testSeMaSlave> semasList; + private ArrayList<testEditor> editorList; + private int NoSemaMaster; + private int NoSemaSlave; + private int NoEditor; + + public static void main(String[] args){ + testNetworkSimulator testns = new testNetworkSimulator(3, 10, 50); + + testns.startTest(); + } + + + /** Constructor. */ + public testNetworkSimulator(int sm, int ss,int e){ + //ns = new NetworkSimulator<String>(); + ns = NetworkSimulator.singleton(); + semaList = new ArrayList<testSeMa>(); + semasList = new ArrayList<testSeMaSlave>(); + editorList = new ArrayList<testEditor>(); + NoSemaMaster = sm; + NoSemaSlave = ss; + NoEditor = e; + } + + public void startTest(){ + Random rand = new Random(); + for (int i=0; i<NoSemaMaster; i++){ + testSeMa sm = new testSeMa(ns, "SeMa"+i, i); + semaList.add(sm); + sm.start(); + } + for (int i=0; i<NoSemaSlave; i++){ + testSeMaSlave sm = new testSeMaSlave(ns, "SeMaS"+i, i+NoSemaMaster, rand.nextInt(NoSemaMaster)); + semasList.add(sm); + sm.start(); + } + for (int i=0; i<NoEditor; i++){ + testEditor te = new testEditor(ns, "Editor"+i, rand.nextInt(NoSemaMaster+NoSemaSlave)); + editorList.add(te); + te.start(); + } + + Checker(); + + try { + for (testEditor te: editorList) + te.join(); + ns.writeLog("main: all clients exited.", 1); + + } catch (InterruptedException e) { + e.printStackTrace(); + } + System.exit(0); + } + + public void Checker(){ + + } +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pathfinder/mergetest/channels/test/testSeMa.java Tue Aug 26 19:46:51 2008 +0900 @@ -0,0 +1,60 @@ +package pathfinder.mergetest.channels.test; + +import java.io.IOException; +import java.util.LinkedList; + +import pathfinder.mergetest.channels.*; + + +public class testSeMa extends Thread{ + + int IP; + boolean running=true; + NetworkSimulator<String> ns; + LinkedList<ChannelSimulator<String>> channels; + + public testSeMa(NetworkSimulator<String> _ns, String name, int ip){ + super(name); + IP = ip; + ns = _ns; + channels = new LinkedList<ChannelSimulator<String>>(); + } + public void init(){ + + } + + public void run() { + SelectorSimulator<String> selector = new SelectorSimulator<String>(); + ServerChannelSimulator<String> scs = new ServerChannelSimulator<String>(ns, selector); + scs.bind(IP); + selector.register(scs, SelectionKeySimulator.OP_ACCEPT); + ns.writeLog("SessionManager starts mainroutin.", 1); + + /* Main Loop */ + while(running){ + + try { selector.select(); } + catch (IOException e) { e.printStackTrace();} + + for(SelectionKeySimulator<String> key : selector.selectedKeys()){ + + if(key.isAcceptable()){ + ns.writeLog(this, "gets acceptable channel", 1); + ServerChannelSimulator<String> sc = (ServerChannelSimulator<String>) key.channel(); + ChannelSimulator<String> channel = sc.accept(); + selector.register(channel, SelectionKeySimulator.OP_READ); + ns.writeLog(this, "accepts a client.", 1); + + }else if(key.isReadable()){ + ns.writeLog(this, "gets readable channel", 1); + //SelectableChannelSimulator<String> channel = key.channel(); + ChannelSimulator<String> channel = (ChannelSimulator<String>) key.channel(); + String packet = channel.read(); + ns.writeLog(this, "receives String==> `"+packet+"\'", 1); + channel.write("from SeMa"+this.getName()+": world"); + } + } + } + + } +}
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/pathfinder/mergetest/channels/test/testSeMaSlave.java Tue Aug 26 19:46:51 2008 +0900 @@ -0,0 +1,94 @@ +package pathfinder.mergetest.channels.test; + +import java.io.IOException; +import java.util.LinkedList; + +import pathfinder.mergetest.channels.*; + + +public class testSeMaSlave extends Thread{ + + int ownIP; + int masterIP; + boolean running=true; + NetworkSimulator<String> ns; + LinkedList<ClientInfo> cis; + + public testSeMaSlave(NetworkSimulator<String> _ns, String name, int oIP, int mIP){ + super(name); + ownIP = oIP; + masterIP = mIP; + ns = _ns; + cis = new LinkedList<ClientInfo>(); + } + public void init(){ + + } + + public void run() { + SelectorSimulator<String> selector = new SelectorSimulator<String>(); + + ChannelSimulator<String> masterCH = connectToMaster(selector); + ServerChannelSimulator<String> scs = new ServerChannelSimulator<String>(ns, selector); + scs.bind(ownIP); + + selector.register(scs, SelectionKeySimulator.OP_ACCEPT); + selector.register(masterCH, SelectionKeySimulator.OP_READ); + ns.writeLog("SessionManager starts mainroutin.", 1); + + /* Main Loop */ + while(running){ + + try { selector.select(); } + catch (IOException e) { e.printStackTrace();} + + for(SelectionKeySimulator<String> key : selector.selectedKeys()){ + + if(key.isAcceptable()){ + ns.writeLog(this, "gets acceptable channel", 1); + ServerChannelSimulator<String> sc = (ServerChannelSimulator<String>) key.channel(); + ChannelSimulator<String> channel = sc.accept(); + selector.register(channel, SelectionKeySimulator.OP_READ); + ns.writeLog(this, "accepts a client.", 1); + + }else if(key.isReadable()){ + ns.writeLog(this, "gets readable channel", 1); + ChannelSimulator<String> channel = (ChannelSimulator<String>) key.channel(); + String packet = channel.read(); + if (channel==masterCH){ + ns.writeLog(this, "receives String from master ==> `"+packet+"\'", 1); + for (ClientInfo ci: cis){ + if (!packet.matches(ci.str)) continue; + ci.channel.write("from "+this.getName()+": loopback packet from master ==>`"+packet+"\'"); + } + }else{ + ns.writeLog(this, "receives String==> `"+packet+"\'", 1); + //channel.write("from "+this.getName()+": slave"); + masterCH.write("from "+this.getName()+": receive String==>`"+packet+"\' from editor"); + cis.add(new ClientInfo(packet, channel)); + } + } + } + } + + } + private ChannelSimulator<String> connectToMaster(SelectorSimulator<String> _selector) { + ChannelSimulator<String> channel = new ChannelSimulator<String>(ns, _selector); + ns.writeLog(this, "is connecting to masterSeMa whose ip is"+masterIP, 1); + while(!channel.connect(masterIP)){ + ns.writeLog(this, "SeMa not listen to socket yet, wait", 1); + Thread.yield(); + } + ns.writeLog(this, "connecting was successful.", 1); + + return channel; + } +} +class ClientInfo{ + String str; + ChannelSimulator<String> channel; + ClientInfo(String _str, ChannelSimulator<String> _channel){ + str = _str; + channel = _channel; + } +} \ No newline at end of file