Rework BaseScheams
[netconf.git] / plugins / netconf-client-mdsal / src / test / java / org / opendaylight / netconf / client / mdsal / spi / NetconfDataTreeServiceImplTest.java
1 /*
2  * Copyright (c) 2020 PANTHEON.tech, s.r.o. 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.client.mdsal.spi;
9
10 import static org.hamcrest.CoreMatchers.containsString;
11 import static org.hamcrest.MatcherAssert.assertThat;
12 import static org.mockito.ArgumentMatchers.any;
13 import static org.mockito.ArgumentMatchers.eq;
14 import static org.mockito.Mockito.doReturn;
15 import static org.mockito.Mockito.verify;
16
17 import com.google.common.util.concurrent.Futures;
18 import java.net.InetSocketAddress;
19 import java.util.List;
20 import java.util.Optional;
21 import java.util.Set;
22 import org.junit.Before;
23 import org.junit.Test;
24 import org.junit.runner.RunWith;
25 import org.mockito.ArgumentCaptor;
26 import org.mockito.Captor;
27 import org.mockito.Mock;
28 import org.mockito.junit.MockitoJUnitRunner;
29 import org.opendaylight.mdsal.binding.runtime.spi.BindingRuntimeHelpers;
30 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
31 import org.opendaylight.mdsal.dom.spi.DefaultDOMRpcResult;
32 import org.opendaylight.netconf.api.CapabilityURN;
33 import org.opendaylight.netconf.api.messages.NetconfMessage;
34 import org.opendaylight.netconf.client.mdsal.AbstractTestModelTest;
35 import org.opendaylight.netconf.client.mdsal.api.NetconfSessionPreferences;
36 import org.opendaylight.netconf.client.mdsal.api.RemoteDeviceId;
37 import org.opendaylight.netconf.client.mdsal.api.RemoteDeviceServices.Rpcs;
38 import org.opendaylight.netconf.client.mdsal.impl.NetconfMessageTransformer;
39 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.Commit;
40 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.DiscardChanges;
41 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.EditConfig;
42 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.Get;
43 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.GetConfig;
44 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.IetfNetconfData;
45 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.Lock;
46 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.netconf.base._1._0.rev110601.Unlock;
47 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.netconf.monitoring.rev101004.NetconfState;
48 import org.opendaylight.yangtools.yang.data.api.schema.ContainerNode;
49 import org.opendaylight.yangtools.yang.data.api.schema.MountPointContext;
50
51 @RunWith(MockitoJUnitRunner.StrictStubs.class)
52 public class NetconfDataTreeServiceImplTest extends AbstractTestModelTest {
53     @Mock
54     private Rpcs.Normalized rpcService;
55     @Captor
56     private ArgumentCaptor<ContainerNode> captor;
57
58     private AbstractNetconfDataTreeService netconService;
59     private NetconfMessageTransformer netconfMessageTransformer;
60
61     @Before
62     public void setUp() {
63         doReturn(Futures.immediateFuture(new DefaultDOMRpcResult())).when(rpcService).invokeNetconf(any(), any());
64         netconService = getNetconService();
65         final var model = BindingRuntimeHelpers.createEffectiveModel(IetfNetconfData.class, NetconfState.class);
66         netconfMessageTransformer = new NetconfMessageTransformer(MountPointContext.of(model), true,
67             BASE_SCHEMAS.baseSchemaForCapabilities(NetconfSessionPreferences.fromStrings(Set.of())));
68     }
69
70     @Test
71     public void lock() {
72         netconService.lock();
73         verify(rpcService).invokeNetconf(eq(Lock.QNAME), any());
74     }
75
76     @Test
77     public void unlock() {
78         netconService.lock();
79         netconService.unlock();
80         verify(rpcService).invokeNetconf(eq(Lock.QNAME), any());
81         verify(rpcService).invokeNetconf(eq(Unlock.QNAME), any());
82     }
83
84     @Test
85     public void discardChanges() {
86         netconService.discardChanges();
87         verify(rpcService).invokeNetconf(eq(DiscardChanges.QNAME), any());
88     }
89
90     @Test
91     public void get() {
92         netconService.get(null);
93         verify(rpcService).invokeNetconf(eq(Get.QNAME), any());
94     }
95
96     @Test
97     public void getConfig() {
98         netconService.getConfig(null);
99         verify(rpcService).invokeNetconf(eq(GetConfig.QNAME), any());
100     }
101
102     @Test
103     public void merge() {
104         netconService.merge(LogicalDatastoreType.CONFIGURATION, TxTestUtils.getLeafId(), TxTestUtils.getLeafNode(),
105                 Optional.empty());
106         verify(rpcService).invokeNetconf(eq(EditConfig.QNAME), captor.capture());
107
108         final NetconfMessage netconfMessage = netconfMessageTransformer.toRpcRequest(
109             EditConfig.QNAME, captor.getValue());
110         assertThat(netconfMessage.toString(), containsString("operation=\"merge\""));
111     }
112
113     @Test
114     public void replace() {
115         netconService.replace(LogicalDatastoreType.CONFIGURATION, TxTestUtils.getLeafId(), TxTestUtils.getLeafNode(),
116                 Optional.empty());
117         verify(rpcService).invokeNetconf(eq(EditConfig.QNAME), captor.capture());
118
119         final NetconfMessage netconfMessage = netconfMessageTransformer.toRpcRequest(
120             EditConfig.QNAME, captor.getValue());
121         assertThat(netconfMessage.toString(), containsString("operation=\"replace\""));
122     }
123
124     @Test
125     public void create() {
126         netconService.create(LogicalDatastoreType.CONFIGURATION, TxTestUtils.getLeafId(), TxTestUtils.getLeafNode(),
127             Optional.empty());
128         verify(rpcService).invokeNetconf(eq(EditConfig.QNAME), captor.capture());
129
130         final NetconfMessage netconfMessage = netconfMessageTransformer.toRpcRequest(
131             EditConfig.QNAME, captor.getValue());
132         assertThat(netconfMessage.toString(), containsString("operation=\"create\""));
133     }
134
135     @Test
136     public void delete() {
137         netconService.delete(LogicalDatastoreType.CONFIGURATION, TxTestUtils.getLeafId().getParent());
138         verify(rpcService).invokeNetconf(eq(EditConfig.QNAME), captor.capture());
139
140         final NetconfMessage netconfMessage = netconfMessageTransformer.toRpcRequest(
141             EditConfig.QNAME, captor.getValue());
142         assertThat(netconfMessage.toString(), containsString("operation=\"delete\""));
143     }
144
145     @Test
146     public void remove() {
147         netconService.remove(LogicalDatastoreType.CONFIGURATION, TxTestUtils.getLeafId().getParent());
148         verify(rpcService).invokeNetconf(eq(EditConfig.QNAME), captor.capture());
149
150         final NetconfMessage netconfMessage = netconfMessageTransformer.toRpcRequest(
151             EditConfig.QNAME, captor.getValue());
152         assertThat(netconfMessage.toString(), containsString("operation=\"remove\""));
153     }
154
155     @Test
156     public void commit() {
157         netconService.commit();
158         verify(rpcService).invokeNetconf(eq(Commit.QNAME), any());
159     }
160
161     private AbstractNetconfDataTreeService getNetconService() {
162         NetconfSessionPreferences prefs = NetconfSessionPreferences.fromStrings(List.of(CapabilityURN.CANDIDATE));
163         final RemoteDeviceId id =
164                 new RemoteDeviceId("device-1", InetSocketAddress.createUnresolved("localhost", 17830));
165         return AbstractNetconfDataTreeService.of(id, MountPointContext.of(SCHEMA_CONTEXT), rpcService, prefs,
166             true);
167     }
168 }