Create NetconfDataTreeService with base and additional operations for netconf
[netconf.git] / netconf / sal-netconf-connector / src / test / java / org / opendaylight / netconf / sal / connect / netconf / sal / MountInstanceTest.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.netconf.sal.connect.netconf.sal;
9
10 import static org.mockito.ArgumentMatchers.any;
11 import static org.mockito.Mockito.verify;
12 import static org.mockito.Mockito.when;
13
14 import java.net.InetSocketAddress;
15 import org.junit.Assert;
16 import org.junit.Before;
17 import org.junit.BeforeClass;
18 import org.junit.Test;
19 import org.mockito.Mock;
20 import org.mockito.MockitoAnnotations;
21 import org.opendaylight.binding.runtime.spi.BindingRuntimeHelpers;
22 import org.opendaylight.mdsal.dom.api.DOMDataBroker;
23 import org.opendaylight.mdsal.dom.api.DOMMountPoint;
24 import org.opendaylight.mdsal.dom.api.DOMMountPointService;
25 import org.opendaylight.mdsal.dom.api.DOMNotification;
26 import org.opendaylight.mdsal.dom.api.DOMNotificationService;
27 import org.opendaylight.mdsal.dom.api.DOMRpcService;
28 import org.opendaylight.netconf.dom.api.NetconfDataTreeService;
29 import org.opendaylight.netconf.sal.connect.util.RemoteDeviceId;
30 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.IetfNetconfService;
31 import org.opendaylight.yangtools.concepts.ObjectRegistration;
32 import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
33 import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
34 import org.slf4j.Logger;
35 import org.slf4j.LoggerFactory;
36
37 public class MountInstanceTest {
38     private static final Logger LOG = LoggerFactory.getLogger(MountInstanceTest.class);
39
40     private static EffectiveModelContext SCHEMA_CONTEXT;
41
42     @Mock
43     private DOMMountPointService service;
44     @Mock
45     private DOMDataBroker broker;
46     @Mock
47     private NetconfDataTreeService netconfService;
48     @Mock
49     private DOMRpcService rpcService;
50     @Mock
51     private NetconfDeviceNotificationService notificationService;
52     @Mock
53     private DOMMountPointService.DOMMountPointBuilder mountPointBuilder;
54     @Mock
55     private ObjectRegistration<DOMMountPoint> registration;
56     @Mock
57     private DOMNotification notification;
58
59     private NetconfDeviceSalProvider.MountInstance mountInstance;
60
61     @BeforeClass
62     public static void suiteSetUp() throws Exception {
63         SCHEMA_CONTEXT = BindingRuntimeHelpers.createEffectiveModel(IetfNetconfService.class);
64     }
65
66     @Before
67     public void setUp() throws Exception {
68         MockitoAnnotations.initMocks(this);
69         when(service.createMountPoint(any(YangInstanceIdentifier.class))).thenReturn(mountPointBuilder);
70
71         when(mountPointBuilder.register()).thenReturn(registration);
72         mountInstance = new NetconfDeviceSalProvider.MountInstance(
73                 service, new RemoteDeviceId("device-1", InetSocketAddress.createUnresolved("localhost", 17830)));
74     }
75
76
77     @Test
78     public void testOnTopologyDeviceConnected() {
79         mountInstance.onTopologyDeviceConnected(SCHEMA_CONTEXT, broker, rpcService, notificationService);
80         verify(mountPointBuilder).addInitialSchemaContext(SCHEMA_CONTEXT);
81         verify(mountPointBuilder).addService(DOMDataBroker.class, broker);
82         verify(mountPointBuilder).addService(DOMRpcService.class, rpcService);
83         verify(mountPointBuilder).addService(DOMNotificationService.class, notificationService);
84     }
85
86     @Test
87     public void testOnTopologyDeviceConnectedWithNetconfService() {
88         mountInstance.onTopologyDeviceConnected(SCHEMA_CONTEXT, null, netconfService, rpcService,
89                 notificationService, null);
90         verify(mountPointBuilder).addInitialSchemaContext(SCHEMA_CONTEXT);
91         verify(mountPointBuilder).addService(NetconfDataTreeService.class, netconfService);
92         verify(mountPointBuilder).addService(DOMRpcService.class, rpcService);
93         verify(mountPointBuilder).addService(DOMNotificationService.class, notificationService);
94     }
95
96     @Test
97     public void testOnTopologyDeviceDisconnected() throws Exception {
98         mountInstance.onTopologyDeviceConnected(SCHEMA_CONTEXT, broker, rpcService, notificationService);
99         mountInstance.onTopologyDeviceDisconnected();
100         verify(registration).close();
101         try {
102             mountInstance.onTopologyDeviceConnected(SCHEMA_CONTEXT, broker, rpcService, notificationService);
103         } catch (final IllegalStateException e) {
104             LOG.warn("Operation failed.", e);
105             Assert.fail("Topology registration still present after disconnect ");
106         }
107     }
108
109     @Test
110     public void testClose() throws Exception {
111         mountInstance.onTopologyDeviceConnected(SCHEMA_CONTEXT, broker, rpcService, notificationService);
112         mountInstance.close();
113         verify(registration).close();
114     }
115
116     @Test
117     public void testPublishNotification() throws Exception {
118         mountInstance.onTopologyDeviceConnected(SCHEMA_CONTEXT, broker, rpcService, notificationService);
119         verify(mountPointBuilder).addInitialSchemaContext(SCHEMA_CONTEXT);
120         verify(mountPointBuilder).addService(DOMNotificationService.class, notificationService);
121         mountInstance.publish(notification);
122         verify(notificationService).publishNotification(notification);
123     }
124
125
126 }