jointest.java

来自「JGRoups源码」· Java 代码 · 共 128 行

JAVA
128
字号
package org.jgroups.tests;

import junit.framework.Test;
import junit.framework.TestCase;
import junit.framework.TestSuite;
import org.jgroups.*;
import org.jgroups.util.Util;

import java.util.List;
import java.util.LinkedList;


/**
 * @author Bela Ban
 * @version $Id: JoinTest.java,v 1.2 2006/10/25 12:23:55 belaban Exp $
 */
public class JoinTest extends TestCase {
    Channel c1, c2;
    static String STACK="udp.xml";


    public JoinTest(String name) {
        super(name);
    }


    public void setUp() throws Exception {
        super.setUp();
        STACK=System.getProperty("stack", STACK);
        c1=new JChannel(STACK);
        c2=new JChannel(STACK);
    }


    protected void tearDown() throws Exception {
        super.tearDown();
        if(c1 != null)
            c1.close();
        if(c2 != null)
            c2.close();
    }

    public void testSingleJoin() throws ChannelException {
        c1.connect("X");
        View v=c1.getView();
        assertNotNull(v);
        assertEquals(1, v.size());
    }


    /**
     * Tests that immediately after a connect(), a getView() returns the correct view
     * @throws ChannelException
     */
    public void testJoinsOnTwoChannels() throws ChannelException {
        c1.connect("X");
        c2.connect("X");
        View v1=c1.getView(), v2=c2.getView();
        System.out.println("v1=" + v1 + ", v2=" + v2);
        assertNotNull(v1);
        assertNotNull(v2);
        assertEquals(2, v1.size());
        assertEquals(2, v2.size());
        assertEquals(v1, v2);
    }


    public void testJoinsOnTwoChannelsAndSend() throws ChannelException {
        MyReceiver r1=new MyReceiver("c1");
        MyReceiver r2=new MyReceiver("c2");
        c1.setReceiver(r1);
        c2.setReceiver(r2);
        Message m1=new Message(null, null, "message-1"), m2=new Message(null, null, "message-2");
        c1.connect("X");
        c2.connect("X");
        c1.send(m1);
        c2.send(m2);

        Util.sleep(200);
        List c1_list=r1.getMsgs(), c2_list=r2.getMsgs();
        System.out.println("c1: " + c1_list.size() + " msgs, c2: " + c2_list.size() + " msgs");
        assertNotNull(c1_list);
        assertNotNull(c2_list);
        assertEquals(2, c1_list.size());
        assertEquals(2, c2_list.size());
        assertTrue(c1_list.contains("message-1"));
        assertTrue(c2_list.contains("message-1"));
        assertTrue(c1_list.contains("message-2"));
        assertTrue(c2_list.contains("message-2"));
    }


    public static Test suite() {
        return new TestSuite(JoinTest.class);
    }

    public static void main(String[] args) {
        junit.textui.TestRunner.run(JoinTest.suite());
    }


    private static class MyReceiver extends ReceiverAdapter {
        String name;
        List msgs=new LinkedList();

        public MyReceiver(String name) {
            this.name=name;
        }

        public List getMsgs() {
            return msgs;
        }

        public void clear() {msgs.clear();}

        public void receive(Message msg) {
            String s=(String)msg.getObject();
            msgs.add(s);
            System.out.println("[" + name + "] received " + s + " from " + msg.getSrc());
        }

        public void viewAccepted(View new_view) {
            System.out.println("[" + name + "] view: " + new_view);
        }

    }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?