Ditch blueprint from frm-sync
[openflowplugin.git] / applications / forwardingrules-sync / src / test / java / org / opendaylight / openflowplugin / applications / frsync / impl / ForwardingRulesSyncProviderTest.java
1 /*
2  * Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.openflowplugin.applications.frsync.impl;
9
10 import static org.mockito.ArgumentMatchers.any;
11 import static org.mockito.Mockito.mock;
12 import static org.mockito.Mockito.times;
13 import static org.mockito.Mockito.verify;
14 import static org.mockito.Mockito.when;
15
16 import org.junit.Test;
17 import org.junit.runner.RunWith;
18 import org.mockito.Mock;
19 import org.mockito.junit.MockitoJUnitRunner;
20 import org.opendaylight.mdsal.binding.api.DataBroker;
21 import org.opendaylight.mdsal.binding.api.RpcConsumerRegistry;
22 import org.opendaylight.mdsal.singleton.common.api.ClusterSingletonServiceProvider;
23 import org.opendaylight.yang.gen.v1.urn.opendaylight.flat.batch.service.rev160321.ProcessFlatBatch;
24 import org.opendaylight.yang.gen.v1.urn.opendaylight.table.service.rev131026.UpdateTable;
25
26 /**
27  * Test for {@link ForwardingRulesSyncProvider}.
28  */
29 @RunWith(MockitoJUnitRunner.class)
30 public class ForwardingRulesSyncProviderTest {
31     @Mock
32     private DataBroker dataBroker;
33     @Mock
34     private RpcConsumerRegistry rpcRegistry;
35     @Mock
36     private ClusterSingletonServiceProvider clusterSingletonService;
37
38     @Test
39     public void testInit() {
40         when(rpcRegistry.getRpc(any())).thenAnswer(invocation -> mock(invocation.<Class<?>>getArgument(0)));
41
42         try (var provider = new ForwardingRulesSyncProvider(dataBroker, rpcRegistry, clusterSingletonService)) {
43             verify(rpcRegistry).getRpc(UpdateTable.class);
44             verify(rpcRegistry).getRpc(ProcessFlatBatch.class);
45             verify(dataBroker, times(2)).registerDataTreeChangeListener(any(), any());
46         }
47     }
48 }