Package org.rioproject.eventcollector.service

Source Code of org.rioproject.eventcollector.service.EventCollectorITest

/*
* Copyright to the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*      http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.rioproject.eventcollector.service;

import net.jini.core.event.RemoteEventListener;
import net.jini.core.lease.Lease;
import org.junit.Assert;
import org.junit.BeforeClass;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.rioproject.eventcollector.api.EventCollector;
import org.rioproject.eventcollector.api.EventCollectorRegistration;
import org.rioproject.impl.util.FileUtils;
import org.rioproject.test.RioTestRunner;
import org.rioproject.test.SetTestManager;
import org.rioproject.test.TestManager;
import org.rioproject.url.artifact.ArtifactURLStreamHandlerFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.File;
import java.net.URL;

/**
* @author Dennis Reedy
*/
@RunWith(RioTestRunner.class)
public class EventCollectorITest {
    @SetTestManager
    static TestManager testManager;
    private static Logger logger = LoggerFactory.getLogger(EventCollectorITest.class.getName());

    @BeforeClass
    public static void clean() {
        String userDir = System.getProperty("user.dir");
        File eventDir = new File(userDir, "target/events");
        if(eventDir.exists()) {
            FileUtils.remove(eventDir);
        }
    }

    @Test
    public void testEventCollector() throws Exception {
        try {
            URL.setURLStreamHandlerFactory(new ArtifactURLStreamHandlerFactory());
        } catch(Error e) {
            System.out.println("Factory already defined, move along");
        }
        EventCollector eventCollector = (EventCollector)testManager.waitForService(EventCollector.class);
        Assert.assertNotNull(eventCollector);
        EventCollectorRegistration registration1 = eventCollector.register(Lease.ANY);
        EventCollectorRegistration registration2 = eventCollector.register(Lease.ANY);

        BasicEventListener listener1 = new BasicEventListener();
        RemoteEventListener eventListener = listener1.export();
        registration1.enableDelivery(eventListener);

        try {
            logger.info("Deploy ....");
            testManager.deploy(new File("src/test/opstring/outrigger.groovy"));
            logger.info("Wait 3 seconds to get events.... ");
            Thread.sleep(1000*3);

            registration1.disableDelivery();
            Thread.sleep(1000*3);
            testManager.undeploy("Outrigger");

            logger.info("Wait 3 seconds to get events for next client.... ");
            Thread.sleep(1000*3);
            registration1.enableDelivery(eventListener);
            BasicEventListener listener2 = new BasicEventListener();
            registration2.enableDelivery(listener2.export());
            logger.info("Wait 3 seconds to clean up");
            Thread.sleep(1000 * 3);
            log(1, listener1);
            log(2, listener2);
            Assert.assertEquals(listener1.eventCollectionCount(), listener2.eventCollectionCount());
        } catch (Throwable t) {
            t.printStackTrace();
        }
    }

    private void log(int i, BasicEventListener listener) {
        logger.info("\nListener "+i+" reports: "+listener.eventCollectionCount()+"\n"+
                       "==================\n"+listener.printEventCollection());

    }
}
TOP

Related Classes of org.rioproject.eventcollector.service.EventCollectorITest

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.