Package org.jgroups.tests

Source Code of org.jgroups.tests.LargeStateTransferTest$Provider

package org.jgroups.tests;

import java.io.IOException;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.OutputStream;

import junit.framework.Test;
import junit.framework.TestCase;
import junit.framework.TestSuite;
import org.jgroups.ChannelException;
import org.jgroups.ExtendedReceiverAdapter;
import org.jgroups.JChannel;
import org.jgroups.util.Promise;
import org.jgroups.util.Util;

/**
* Tests transfer of large states (http://jira.jboss.com/jira/browse/JGRP-225)
* @author Bela Ban
* @version $Id: LargeStateTransferTest.java,v 1.4 2006/10/11 14:31:52 belaban Exp $
*/
public class LargeStateTransferTest extends TestCase {
    JChannel provider, requester;
    Promise p=new Promise();
    String props="udp.xml";
    long start, stop;
    final static int SIZE_1=100000, SIZE_2=1000000, SIZE_3=5000000, SIZE_4=10000000;




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


    protected void setUp() throws Exception {
        super.setUp();
        props = System.getProperty("props",props);  
        log("Using configuration file " + props);
        provider=new JChannel(props);
        requester=new JChannel(props);
    }

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


    public void testStateTransfer1() throws ChannelException {
        _testStateTransfer(SIZE_1);
    }

    public void testStateTransfer2() throws ChannelException {
        _testStateTransfer(SIZE_2);
    }

    public void testStateTransfer3() throws ChannelException {
        _testStateTransfer(SIZE_3);
    }

    public void testStateTransfer4() throws ChannelException {
        _testStateTransfer(SIZE_4);
    }



    public void _testStateTransfer(int size) throws ChannelException {
        provider.setReceiver(new Provider(size));
        provider.connect("X");
        p.reset();
        requester.setReceiver(new Requester(p));
        requester.connect("X");
        log("requesting state of " + size + " bytes");
        start=System.currentTimeMillis();
        requester.getState(null, 20000);
        Object result=p.getResult(10000);
        stop=System.currentTimeMillis();
        log("result=" + result + " bytes (in " + (stop-start) + "ms)");
        assertNotNull(result);
        assertEquals(result, new Integer(size));
    }



    static void log(String msg) {
        System.out.println(Thread.currentThread() + " -- "+ msg);
    }

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

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


    private static class Provider extends ExtendedReceiverAdapter {
        byte[] state;

        public Provider(int size) {
            state=new byte[size];
        }

        public byte[] getState() {
            return state;
        }
       
        public void getState(OutputStream ostream){     
            ObjectOutputStream oos =null;
            try{
               oos=new ObjectOutputStream(ostream);
               oos.writeInt(state.length);
               oos.write(state);
            }
            catch (IOException e){}
            finally{
               Util.close(ostream);
            }
        }
        public void setState(byte[] state) {
            throw new UnsupportedOperationException("not implemented by provider");
        }
    }


    private static class Requester extends ExtendedReceiverAdapter {
        Promise p;

        public Requester(Promise p) {
            this.p=p;
        }

        public byte[] getState() {
            throw new UnsupportedOperationException("not implemented by requester");
        }

        public void setState(byte[] state) {
            p.setResult(new Integer(state.length));
        }
        public void setState(InputStream istream) {
            ObjectInputStream ois=null;
            int size=0;
            try{
               ois= new ObjectInputStream(istream);
               size = ois.readInt();
               byte []stateReceived= new byte[size];
               ois.read(stateReceived);
            }
            catch (IOException e){                        }
            finally{
               Util.close(ois);
            }
            p.setResult(new Integer(size));
        }
    }

}
TOP

Related Classes of org.jgroups.tests.LargeStateTransferTest$Provider

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.