Add changed-leaf-nodes-only subscription extension
[netconf.git] / netconf / netconf-topology / src / test / java / org / opendaylight / netconf / topology / spi / NetconfTopologyRPCProviderTest.java
1 /*
2  * Copyright (c) 2017 Brocade Communication Systems 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.topology.spi;
9
10 import static org.junit.Assert.assertEquals;
11 import static org.junit.Assert.assertTrue;
12 import static org.mockito.Mockito.when;
13
14 import org.junit.Before;
15 import org.junit.Test;
16 import org.junit.runner.RunWith;
17 import org.mockito.Mock;
18 import org.mockito.junit.MockitoJUnitRunner;
19 import org.opendaylight.aaa.encrypt.AAAEncryptionService;
20 import org.opendaylight.mdsal.binding.api.DataBroker;
21 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Host;
22 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.IpAddress;
23 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.Ipv4Address;
24 import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.inet.types.rev130715.PortNumber;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.Credentials;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.credentials.LoginPw;
27 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.credentials.LoginPwBuilder;
28 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.credentials.LoginPwUnencrypted;
29 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.credentials.LoginPwUnencryptedBuilder;
30 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.credentials.login.pw.LoginPasswordBuilder;
31 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.device.rev221225.credentials.credentials.login.pw.unencrypted.LoginPasswordUnencryptedBuilder;
32 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev221225.CreateDeviceInput;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev221225.CreateDeviceInputBuilder;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.netconf.node.topology.rev221225.NetconfNode;
35 import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.NodeId;
36 import org.opendaylight.yangtools.yang.common.Uint16;
37
38 @RunWith(MockitoJUnitRunner.StrictStubs.class)
39 public class NetconfTopologyRPCProviderTest {
40     private static final NodeId NODE_ID = new NodeId("testing-node");
41     private static final String TOPOLOGY_ID = "testing-topology";
42     private static final String TEST_PWD =  "test";
43     private static final String ENC_PWD = "4o9/Hn3Pi4150YrP12N/1g==";
44
45     @Mock
46     private DataBroker dataBroker;
47
48     @Mock
49     private AAAEncryptionService encryptionService;
50
51     private NetconfTopologyRPCProvider rpcProvider;
52
53     @Before
54     public void setUp() {
55         when(encryptionService.encrypt(TEST_PWD)).thenReturn(ENC_PWD);
56         rpcProvider = new NetconfTopologyRPCProvider(dataBroker, encryptionService, TOPOLOGY_ID);
57     }
58
59     @Test
60     public void testEncryptPassword() {
61
62         final NetconfNode encryptedPwNode = rpcProvider.encryptPassword(getInput(true));
63
64         final Credentials credentials = encryptedPwNode.getCredentials();
65         assertTrue(credentials instanceof LoginPw);
66         final LoginPw loginPw = (LoginPw) credentials;
67
68         assertEquals(ENC_PWD, loginPw.getLoginPassword().getPassword());
69     }
70
71     @Test
72     public void testNoEncryption() {
73         final NetconfNode encryptedPwNode = rpcProvider.encryptPassword(getInput(false));
74
75         final Credentials credentials = encryptedPwNode.getCredentials();
76         assertTrue(credentials instanceof LoginPwUnencrypted);
77         final LoginPwUnencrypted loginPw = (LoginPwUnencrypted) credentials;
78
79         assertEquals(TEST_PWD, loginPw.getLoginPasswordUnencrypted().getPassword());
80     }
81
82     private static CreateDeviceInput getInput(final boolean encrypt) {
83         final Credentials credentials;
84         if (encrypt) {
85             credentials = new LoginPwBuilder()
86                 .setLoginPassword(new LoginPasswordBuilder().setUsername("test").setPassword(TEST_PWD).build())
87                 .build();
88         } else {
89             credentials = new LoginPwUnencryptedBuilder()
90                 .setLoginPasswordUnencrypted(new LoginPasswordUnencryptedBuilder()
91                     .setUsername("test")
92                     .setPassword(TEST_PWD)
93                     .build())
94                 .build();
95         }
96
97         return new CreateDeviceInputBuilder()
98             .setCredentials(credentials)
99             .setHost(new Host(new IpAddress(new Ipv4Address("10.18.16.188"))))
100             .setPort(new PortNumber(Uint16.valueOf(830)))
101             .setTcpOnly(Boolean.FALSE)
102             // FIXME: do we really want 'toString()' here?
103             .setNodeId(NODE_ID.toString())
104             .build();
105     }
106 }