Package org.springframework.data.gemfire.config

Source Code of org.springframework.data.gemfire.config.GemfireV7GatewayNamespaceTest$TestAsyncEventListener

/*
* Copyright 2010-2013 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.springframework.data.gemfire.config;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertSame;
import static org.junit.Assert.assertTrue;

import java.io.File;
import java.io.FilenameFilter;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.List;

import org.junit.AfterClass;
import org.junit.Before;
import org.junit.Test;
import org.springframework.data.gemfire.GemfireUtils;
import org.springframework.data.gemfire.RecreatingContextTest;
import org.springframework.data.gemfire.RegionFactoryBean;
import org.springframework.data.gemfire.TestUtils;
import org.springframework.data.gemfire.test.GemfireTestBeanPostProcessor;
import org.springframework.data.gemfire.wan.GatewaySenderFactoryBean;

import com.gemstone.gemfire.cache.Region;
import com.gemstone.gemfire.cache.asyncqueue.AsyncEvent;
import com.gemstone.gemfire.cache.asyncqueue.AsyncEventListener;
import com.gemstone.gemfire.cache.asyncqueue.AsyncEventQueue;
import com.gemstone.gemfire.cache.util.Gateway.OrderPolicy;
import com.gemstone.gemfire.cache.wan.GatewayEventFilter;
import com.gemstone.gemfire.cache.wan.GatewayQueueEvent;
import com.gemstone.gemfire.cache.wan.GatewayReceiver;
import com.gemstone.gemfire.cache.wan.GatewaySender;
import com.gemstone.gemfire.cache.wan.GatewayTransportFilter;

/**
* This test is only valid for GF 7.0 and above
*
* @author David Turanski
* @author John Blum
*/
@SuppressWarnings("unused")
public class GemfireV7GatewayNamespaceTest extends RecreatingContextTest {

  /*
   * (non-Javadoc)
   * @see org.springframework.data.gemfire.RecreatingContextTest#location()
   */
  @Override
  protected String location() {
    return "/org/springframework/data/gemfire/config/gateway-v7-ns.xml";
  }

  @Override
  protected void configureContext() {
    ctx.getBeanFactory().addBeanPostProcessor(new GemfireTestBeanPostProcessor());
  }

  @Before
  @Override
  public void createCtx() {
    if (GemfireUtils.isGemfireVersion7OrAbove()) {
      super.createCtx();
    }
  }

  @AfterClass
  public static void tearDown() {
    for (String name : new File(".").list(new FilenameFilter() {
      @Override
      public boolean accept(File file, String filename) {
        return filename.startsWith("BACKUP");
      }
    })) {
      new File(name).delete();
    }
  }

  @Test
  public void testAsyncEventQueue() {
    AsyncEventQueue asyncEventQueue = ctx.getBean("async-event-queue", AsyncEventQueue.class);

    assertNotNull(asyncEventQueue);
    assertTrue(asyncEventQueue.isBatchConflationEnabled());
    assertEquals(10, asyncEventQueue.getBatchSize());
    assertEquals(3, asyncEventQueue.getBatchTimeInterval());
    assertEquals("diskstore", asyncEventQueue.getDiskStoreName());
    assertTrue(asyncEventQueue.isDiskSynchronous());
    assertEquals(50, asyncEventQueue.getMaximumQueueMemory());
    assertEquals(OrderPolicy.KEY, asyncEventQueue.getOrderPolicy());
    assertFalse(asyncEventQueue.isParallel());
    assertTrue(asyncEventQueue.isPersistent());
  }

  @Test
  public void testGatewaySender() throws Exception {
    GatewaySenderFactoryBean gatewaySenderFactoryBean = ctx.getBean("&gateway-sender", GatewaySenderFactoryBean.class);

    assertNotNull(gatewaySenderFactoryBean);
    assertNotNull(TestUtils.readField("cache", gatewaySenderFactoryBean));
    assertEquals(2, TestUtils.readField("remoteDistributedSystemId", gatewaySenderFactoryBean));
    assertEquals(10, TestUtils.readField("alertThreshold", gatewaySenderFactoryBean));
    assertTrue(Boolean.TRUE.equals(TestUtils.readField("batchConflationEnabled", gatewaySenderFactoryBean)));
    assertEquals(11, TestUtils.readField("batchSize", gatewaySenderFactoryBean));
    assertEquals(12, TestUtils.readField("dispatcherThreads", gatewaySenderFactoryBean));
    assertEquals(false, TestUtils.readField("diskSynchronous", gatewaySenderFactoryBean));
    assertEquals(true, TestUtils.readField("manualStart", gatewaySenderFactoryBean));

    List<GatewayEventFilter> eventFilters = TestUtils.readField("eventFilters", gatewaySenderFactoryBean);

    assertNotNull(eventFilters);
    assertEquals(2, eventFilters.size());
    assertTrue(eventFilters.get(0) instanceof TestEventFilter);

    List<GatewayTransportFilter> transportFilters = TestUtils.readField("transportFilters", gatewaySenderFactoryBean);

    assertNotNull(transportFilters);
    assertEquals(2, transportFilters.size());
    assertTrue(transportFilters.get(0) instanceof TestTransportFilter);
  }

  @Test
  @SuppressWarnings("rawtypes")
  public void testInnerGatewaySender() throws Exception {
    Region<?, ?> region = ctx.getBean("region-inner-gateway-sender", Region.class);

    assertNotNull(region.getAttributes().getGatewaySenderIds());
    assertEquals(2, region.getAttributes().getGatewaySenderIds().size());

    RegionFactoryBean regionFactoryBean = ctx.getBean("&region-inner-gateway-sender", RegionFactoryBean.class);

    Object[] gatewaySenders = TestUtils.readField("gatewaySenders", regionFactoryBean);

    assertNotNull(gatewaySenders);
    assertEquals(2, gatewaySenders.length);

    GatewaySender gatewaySender = (GatewaySender) gatewaySenders[0];

    assertNotNull(gatewaySender);
    assertEquals(1, gatewaySender.getRemoteDSId());
    assertEquals(false, gatewaySender.isManualStart());
    assertEquals(true, gatewaySender.isRunning());
    assertEquals(10, gatewaySender.getAlertThreshold());
    assertEquals(11, gatewaySender.getBatchSize());
    assertEquals(3000, gatewaySender.getBatchTimeInterval());
    assertEquals(2, gatewaySender.getDispatcherThreads());
    assertEquals("diskstore", gatewaySender.getDiskStoreName());
    assertEquals(true, gatewaySender.isDiskSynchronous());
    assertTrue(gatewaySender.isBatchConflationEnabled());
    assertEquals(50, gatewaySender.getMaximumQueueMemory());
    assertEquals(OrderPolicy.THREAD, gatewaySender.getOrderPolicy());
    assertTrue(gatewaySender.isPersistenceEnabled());
    assertFalse(gatewaySender.isParallel());
    assertEquals(16536, gatewaySender.getSocketBufferSize());
    assertEquals(3000, gatewaySender.getSocketReadTimeout());

    List<GatewayEventFilter> eventFilters = gatewaySender.getGatewayEventFilters();

    assertNotNull(eventFilters);
    assertEquals(1, eventFilters.size());
    assertTrue(eventFilters.get(0) instanceof TestEventFilter);

    List<GatewayTransportFilter> transportFilters = gatewaySender.getGatewayTransportFilters();

    assertNotNull(transportFilters);
    assertEquals(1, transportFilters.size());
    assertTrue(transportFilters.get(0) instanceof TestTransportFilter);
  }

  @Test
  public void testGatewaySenderWithEventTransportFilterRefs() throws Exception {
    GatewaySenderFactoryBean gatewaySenderFactoryBean = ctx.getBean("&gateway-sender-with-event-transport-filter-refs",
      GatewaySenderFactoryBean.class);

    assertNotNull(gatewaySenderFactoryBean);
    assertNotNull(TestUtils.readField("cache", gatewaySenderFactoryBean));
    assertEquals(3, TestUtils.readField("remoteDistributedSystemId", gatewaySenderFactoryBean));
    assertTrue(Boolean.TRUE.equals(TestUtils.readField("batchConflationEnabled", gatewaySenderFactoryBean)));
    assertEquals(50, TestUtils.readField("batchSize", gatewaySenderFactoryBean));
    assertEquals(10, TestUtils.readField("dispatcherThreads", gatewaySenderFactoryBean));
    assertEquals(true, TestUtils.readField("manualStart", gatewaySenderFactoryBean));

    List<GatewayEventFilter> eventFilters = TestUtils.readField("eventFilters", gatewaySenderFactoryBean);

    assertNotNull(eventFilters);
    assertEquals(1, eventFilters.size());
    assertTrue(eventFilters.get(0) instanceof TestEventFilter);
    assertSame(ctx.getBean("event-filter"), eventFilters.get(0));

    List<GatewayTransportFilter> transportFilters = TestUtils.readField("transportFilters", gatewaySenderFactoryBean);

    assertNotNull(transportFilters);
    assertEquals(1, transportFilters.size());
    assertTrue(transportFilters.get(0) instanceof TestTransportFilter);
    assertSame(ctx.getBean("transport-filter"), transportFilters.get(0));
  }

  @Test
  public void testGatewayReceiver() {
    GatewayReceiver gatewayReceiver = ctx.getBean("gateway-receiver", GatewayReceiver.class);

    assertNotNull(gatewayReceiver);
    assertEquals("192.168.0.1", gatewayReceiver.getBindAddress());
    assertEquals(12345, gatewayReceiver.getStartPort());
    assertEquals(23456, gatewayReceiver.getEndPort());
    assertEquals(3000, gatewayReceiver.getMaximumTimeBetweenPings());
    assertEquals(16536, gatewayReceiver.getSocketBufferSize());
  }

  @SuppressWarnings("rawtypes")
  public static class TestEventFilter implements GatewayEventFilter {

    @Override
    public void close() {
    }

    @Override
    public void afterAcknowledgement(GatewayQueueEvent arg0) {
    }

    @Override
    public boolean beforeEnqueue(GatewayQueueEvent arg0) {
      return false;
    }

    @Override
    public boolean beforeTransmit(GatewayQueueEvent arg0) {
      return false;
    }
  }

  public static class TestTransportFilter implements GatewayTransportFilter {

    @Override
    public void close() {
    }

    @Override
    public InputStream getInputStream(InputStream arg0) {
      return null;
    }

    @Override
    public OutputStream getOutputStream(OutputStream arg0) {
      return null;
    }
  }

  @SuppressWarnings("rawtypes")
  public static class TestAsyncEventListener implements AsyncEventListener {

    @Override
    public void close() {
    }

    @Override
    public boolean processEvents(List<AsyncEvent> arg0) {
      return false;
    }
  }

}
TOP

Related Classes of org.springframework.data.gemfire.config.GemfireV7GatewayNamespaceTest$TestAsyncEventListener

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.