/* * 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.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.WriteTransaction; import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException; import org.opendaylight.tsdr.syslogs.server.datastore.RegisteredListener; import org.opendaylight.tsdr.syslogs.server.datastore.SyslogDatastoreManager; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.tsdr.syslog.collector.rev151007.*; import org.opendaylight.yangtools.yang.common.RpcResult; import java.util.HashMap; import java.util.Map; import java.util.UUID; import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; /** * This is the test of DatastoreDeleteRegistedFilter. * @author Wei Lai(weilai@tetthrnet.com) */ public class DatastoreDeleteRegistedFilterTest { 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 Map<String, String> registerMap = new HashMap<>(); private Map<String, RegisteredListener> listenerMap = new HashMap<>(); private RegisteredListener newRegisteredListener = mock(RegisteredListener.class); private String filterID = UUID.randomUUID().toString(); private String listenerID = UUID.randomUUID().toString(); private DeleteRegisteredFilterInput input; @Before public void mockSetUp() { when(dataBroker.newWriteOnlyTransaction()).thenReturn(writeTransaction); when(writeTransaction.submit()).thenReturn(checkedFuture); manager.setDataBroker(dataBroker); input = new DeleteRegisteredFilterInputBuilder() .setFilterId(filterID) .build(); registerMap.put(filterID,listenerID); listenerMap.put(listenerID,newRegisteredListener); when(newRegisteredListener.close()).thenReturn(false); manager.setRegisterMap(registerMap); manager.setListenerMap(listenerMap); } @Test public void testDeleteRegistedFilterWithCloseRegistrationException() { when(newRegisteredListener.close()).thenReturn(false); Future<RpcResult<DeleteRegisteredFilterOutput>> future =manager.deleteRegisteredFilter(input); try { Assert.assertEquals("listener registration close failed",future.get().getResult().getResult()); } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } } @Test public void testDeleteRegistedFilterSuccessful() { when(newRegisteredListener.close()).thenReturn(true); Future<RpcResult<DeleteRegisteredFilterOutput>> future =manager.deleteRegisteredFilter(input); try { Assert.assertEquals("filter delete successfully",future.get().getResult().getResult()); } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } } }