/* * Copyright (c) 2016 TethrNet Technology Co.Ltd and others. All rights reserved. * Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.tsdr.syslogs; import com.google.common.base.Optional; import com.google.common.util.concurrent.CheckedFuture; import org.junit.Assert; import org.junit.Before; import org.junit.Test; import org.opendaylight.controller.md.sal.binding.api.DataBroker; import org.opendaylight.controller.md.sal.binding.api.ReadOnlyTransaction; import org.opendaylight.controller.md.sal.binding.api.WriteTransaction; import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType; import org.opendaylight.controller.md.sal.common.api.data.ReadFailedException; import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException; import org.opendaylight.tsdr.syslogs.server.datastore.MessageFilter; import org.opendaylight.tsdr.syslogs.server.datastore.SyslogDatastoreManager; import org.opendaylight.tsdr.syslogs.server.decoder.Message; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.SyslogDispatcher; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.SyslogFilter; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.SyslogFilterBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.SyslogFilterKey; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.syslog.filter.FilterEntity; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.syslog.filter.FilterEntityBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.syslog.filter.Listener; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.syslog.dispatcher.syslog.filter.ListenerBuilder; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import java.util.ArrayList; import java.util.List; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; /** * This is the test of DatastoreWorkerThread. * @author Wei Lai(weilai@tetthrnet.com) */ public class DatastoreWorkerThreadTest { private int coreThreadPoolSize = 5; private int maxThreadPoolSize = 10; private long keepAliveTime = 10L; private int queueSize = 10; private SyslogDatastoreManager manager = SyslogDatastoreManager.getInstance(coreThreadPoolSize, maxThreadPoolSize, keepAliveTime, queueSize); private DataBroker dataBroker = mock(DataBroker.class); private WriteTransaction writeTransaction = mock(WriteTransaction.class); private CheckedFuture<Void, TransactionCommitFailedException> checkedFuture = mock(CheckedFuture.class); private Message message = Message.MessageBuilder.create() .applicationName(".*") .facility(null) .hostname(".*") .processId(".*") .severity(null) .sequenceId(".*") .content("cisco") .build(); private ReadOnlyTransaction readOnlyTransaction = mock(ReadOnlyTransaction.class); private CheckedFuture<Optional<SyslogDispatcher>, ReadFailedException> readFuture = mock(CheckedFuture.class);; private SyslogDispatcher syslogDispatcher = mock(SyslogDispatcher.class); private List<SyslogFilter> syslogFilters = new ArrayList<>(); private Optional<SyslogDispatcher> optional = Optional.of(syslogDispatcher); private ReadFailedException readFailedException = mock(ReadFailedException.class); private FilterEntity filterEntity = new FilterEntityBuilder() .setContent("cisco") .setApplication(".*") .setFacility(null) .setHost(".*") .setPid(".*") .setSeverity(null) .setSid(".*") .build(); private MessageFilter messageFilter = mock(MessageFilter.class); private CheckedFuture<Optional<SyslogFilter>, ReadFailedException> checkedReadFilterFuture = mock(CheckedFuture.class); @Before public void mockSetUp() { when(dataBroker.newWriteOnlyTransaction()).thenReturn(writeTransaction); when(writeTransaction.submit()).thenReturn(checkedFuture); manager.setDataBroker(dataBroker); when(dataBroker.newReadOnlyTransaction()).thenReturn(readOnlyTransaction); InstanceIdentifier<SyslogDispatcher> iid = InstanceIdentifier.create(SyslogDispatcher.class); when(readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION, iid)).thenReturn(readFuture); when(syslogDispatcher.getSyslogFilter()).thenReturn(syslogFilters); } @Test public void testWorkerThreadGetFilterswithReadFailedException() throws IllegalAccessException, InstantiationException { try { when(readFuture.checkedGet()).thenThrow(readFailedException); } catch (ReadFailedException e) { e.printStackTrace(); } manager.execute("10.0.0.1",message); } @Test public void testWorkerThread() { Listener listener = new ListenerBuilder().setListenerId("321").build(); List<Listener> listeners = new ArrayList<>(); listeners.add(listener); SyslogFilter syslogFilter = new SyslogFilterBuilder() .setFilterId("123") .setFilterEntity(filterEntity) .setCallbackUrl("http://localhost:9001/server") .setListener(listeners) .build(); syslogFilters.add(syslogFilter); InstanceIdentifier<SyslogFilter> iid = InstanceIdentifier.create(SyslogDispatcher.class) .child(SyslogFilter.class, new SyslogFilterKey(syslogFilter.getFilterId())); when(readOnlyTransaction.read(LogicalDatastoreType.CONFIGURATION,iid) ).thenReturn(checkedReadFilterFuture); Optional<SyslogFilter> syslogFilterOptional = Optional.of(syslogFilter); try { when(readFuture.checkedGet()).thenReturn(optional); } catch (ReadFailedException e) { e.printStackTrace(); } try { when(checkedReadFilterFuture.checkedGet()).thenReturn(syslogFilterOptional); } catch (ReadFailedException e) { e.printStackTrace(); } manager.execute("10.0.0.1",message); Assert.assertEquals("321",syslogFilterOptional.get().getListener().get(0).getListenerId()); } }