Search in sources :

Example 1 with NetconfHelloMessageAdditionalHeader

use of org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader in project netconf by opendaylight.

the class NetconfServerSessionTest method testToManagementSessionIpv6.

@Test
public void testToManagementSessionIpv6() throws Exception {
    final NetconfHelloMessageAdditionalHeader header = new NetconfHelloMessageAdditionalHeader(USER, "::1", PORT, SSH_TRANSPORT, SESSION_ID);
    final EmbeddedChannel ch = new EmbeddedChannel();
    final NetconfServerSession tcpSession = new NetconfServerSession(listener, ch, 1L, header);
    tcpSession.sessionUp();
    final Session managementSession = tcpSession.toManagementSession();
    assertEquals("::1", managementSession.getSourceHost().getIpAddress().getIpv6Address().getValue());
    assertEquals(managementSession.getUsername(), USER);
    assertEquals(managementSession.getSessionId().toString(), SESSION_ID);
    assertEquals(managementSession.getTransport(), NetconfSsh.class);
}
Also used : NetconfHelloMessageAdditionalHeader(org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader) EmbeddedChannel(io.netty.channel.embedded.EmbeddedChannel) Session(org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.netconf.monitoring.rev101004.netconf.state.sessions.Session) Test(org.junit.Test)

Example 2 with NetconfHelloMessageAdditionalHeader

use of org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader in project netconf by opendaylight.

the class AdditionalHeaderParserTest method testParsing.

@Test
public void testParsing() throws Exception {
    String message = "[netconf;10.12.0.102:48528;ssh;;;;;;]";
    NetconfHelloMessageAdditionalHeader header = NetconfHelloMessageAdditionalHeader.fromString(message);
    assertEquals("netconf", header.getUserName());
    assertEquals("10.12.0.102", header.getAddress());
    assertEquals("ssh", header.getTransport());
}
Also used : NetconfHelloMessageAdditionalHeader(org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader) Test(org.junit.Test)

Example 3 with NetconfHelloMessageAdditionalHeader

use of org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader in project netconf by opendaylight.

the class CallHomeMountDispatcherTest method someConfiguration.

NetconfClientConfiguration someConfiguration(final InetSocketAddress address) {
    // NetconfClientConfiguration has mostly final methods, making it un-mock-able
    final NetconfClientConfiguration.NetconfClientProtocol protocol = NetconfClientConfiguration.NetconfClientProtocol.SSH;
    final NetconfHelloMessageAdditionalHeader additionalHeader = mock(NetconfHelloMessageAdditionalHeader.class);
    final NetconfClientSessionListener sessionListener = mock(NetconfClientSessionListener.class);
    final ReconnectStrategy reconnectStrategy = mock(ReconnectStrategy.class);
    final AuthenticationHandler authHandler = mock(AuthenticationHandler.class);
    return NetconfClientConfigurationBuilder.create().withProtocol(protocol).withAddress(address).withConnectionTimeoutMillis(0).withAdditionalHeader(additionalHeader).withSessionListener(sessionListener).withReconnectStrategy(reconnectStrategy).withAuthHandler(authHandler).build();
}
Also used : NetconfClientSessionListener(org.opendaylight.netconf.client.NetconfClientSessionListener) NetconfHelloMessageAdditionalHeader(org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader) ReconnectStrategy(org.opendaylight.netconf.nettyutil.ReconnectStrategy) NetconfClientConfiguration(org.opendaylight.netconf.client.conf.NetconfClientConfiguration) AuthenticationHandler(org.opendaylight.netconf.nettyutil.handler.ssh.authentication.AuthenticationHandler)

Example 4 with NetconfHelloMessageAdditionalHeader

use of org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader in project netconf by opendaylight.

the class NetconfClientDispatcherImplTest method testNetconfClientDispatcherImpl.

@Test
public void testNetconfClientDispatcherImpl() throws Exception {
    EventLoopGroup bossGroup = Mockito.mock(EventLoopGroup.class);
    EventLoopGroup workerGroup = Mockito.mock(EventLoopGroup.class);
    Timer timer = new HashedWheelTimer();
    ChannelFuture chf = Mockito.mock(ChannelFuture.class);
    Channel ch = Mockito.mock(Channel.class);
    doReturn(ch).when(chf).channel();
    Throwable thr = Mockito.mock(Throwable.class);
    doReturn(chf).when(workerGroup).register(any(Channel.class));
    ChannelPromise promise = Mockito.mock(ChannelPromise.class);
    doReturn(promise).when(chf).addListener(any(GenericFutureListener.class));
    doReturn(thr).when(chf).cause();
    doReturn(true).when(chf).isDone();
    doReturn(false).when(chf).isSuccess();
    Long timeout = 200L;
    NetconfHelloMessageAdditionalHeader header = new NetconfHelloMessageAdditionalHeader("a", "host", "port", "trans", "id");
    NetconfClientSessionListener listener = new SimpleNetconfClientSessionListener();
    InetSocketAddress address = InetSocketAddress.createUnresolved("host", 830);
    ReconnectStrategyFactory reconnectStrategyFactory = Mockito.mock(ReconnectStrategyFactory.class);
    AuthenticationHandler handler = Mockito.mock(AuthenticationHandler.class);
    ReconnectStrategy reconnect = Mockito.mock(ReconnectStrategy.class);
    doReturn(5).when(reconnect).getConnectTimeout();
    doReturn("").when(reconnect).toString();
    doReturn("").when(handler).toString();
    doReturn("").when(reconnectStrategyFactory).toString();
    doReturn(reconnect).when(reconnectStrategyFactory).createReconnectStrategy();
    NetconfReconnectingClientConfiguration cfg = NetconfReconnectingClientConfigurationBuilder.create().withProtocol(NetconfClientConfiguration.NetconfClientProtocol.SSH).withAddress(address).withConnectionTimeoutMillis(timeout).withReconnectStrategy(reconnect).withAdditionalHeader(header).withSessionListener(listener).withConnectStrategyFactory(reconnectStrategyFactory).withAuthHandler(handler).build();
    NetconfReconnectingClientConfiguration cfg2 = NetconfReconnectingClientConfigurationBuilder.create().withProtocol(NetconfClientConfiguration.NetconfClientProtocol.TCP).withAddress(address).withConnectionTimeoutMillis(timeout).withReconnectStrategy(reconnect).withAdditionalHeader(header).withSessionListener(listener).withConnectStrategyFactory(reconnectStrategyFactory).withAuthHandler(handler).build();
    NetconfClientDispatcherImpl dispatcher = new NetconfClientDispatcherImpl(bossGroup, workerGroup, timer);
    Future<NetconfClientSession> sshSession = dispatcher.createClient(cfg);
    Future<NetconfClientSession> tcpSession = dispatcher.createClient(cfg2);
    ReconnectFuture sshReconn = dispatcher.createReconnectingClient(cfg);
    final ReconnectFuture tcpReconn = dispatcher.createReconnectingClient(cfg2);
    assertNotNull(sshSession);
    assertNotNull(tcpSession);
    assertNotNull(sshReconn);
    assertNotNull(tcpReconn);
    SslHandlerFactory sslHandlerFactory = Mockito.mock(SslHandlerFactory.class);
    NetconfReconnectingClientConfiguration cfg3 = NetconfReconnectingClientConfigurationBuilder.create().withProtocol(NetconfClientConfiguration.NetconfClientProtocol.TLS).withAddress(address).withConnectionTimeoutMillis(timeout).withReconnectStrategy(reconnect).withAdditionalHeader(header).withSessionListener(listener).withConnectStrategyFactory(reconnectStrategyFactory).withSslHandlerFactory(sslHandlerFactory).build();
    Future<NetconfClientSession> tlsSession = dispatcher.createClient(cfg3);
    ReconnectFuture tlsReconn = dispatcher.createReconnectingClient(cfg3);
    assertNotNull(tlsSession);
    assertNotNull(tlsReconn);
}
Also used : ChannelFuture(io.netty.channel.ChannelFuture) NetconfHelloMessageAdditionalHeader(org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader) ReconnectStrategy(org.opendaylight.netconf.nettyutil.ReconnectStrategy) InetSocketAddress(java.net.InetSocketAddress) Channel(io.netty.channel.Channel) HashedWheelTimer(io.netty.util.HashedWheelTimer) ChannelPromise(io.netty.channel.ChannelPromise) EventLoopGroup(io.netty.channel.EventLoopGroup) ReconnectStrategyFactory(org.opendaylight.netconf.nettyutil.ReconnectStrategyFactory) HashedWheelTimer(io.netty.util.HashedWheelTimer) Timer(io.netty.util.Timer) ReconnectFuture(org.opendaylight.netconf.nettyutil.ReconnectFuture) AuthenticationHandler(org.opendaylight.netconf.nettyutil.handler.ssh.authentication.AuthenticationHandler) GenericFutureListener(io.netty.util.concurrent.GenericFutureListener) NetconfReconnectingClientConfiguration(org.opendaylight.netconf.client.conf.NetconfReconnectingClientConfiguration) Test(org.junit.Test)

Example 5 with NetconfHelloMessageAdditionalHeader

use of org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader in project netconf by opendaylight.

the class NetconfReconnectingClientConfigurationTest method testNetconfReconnectingClientConfiguration.

@Test
public void testNetconfReconnectingClientConfiguration() throws Exception {
    Long timeout = 200L;
    NetconfHelloMessageAdditionalHeader header = new NetconfHelloMessageAdditionalHeader("a", "host", "port", "trans", "id");
    NetconfClientSessionListener listener = new SimpleNetconfClientSessionListener();
    InetSocketAddress address = InetSocketAddress.createUnresolved("host", 830);
    ReconnectStrategyFactory strategy = Mockito.mock(ReconnectStrategyFactory.class);
    AuthenticationHandler handler = Mockito.mock(AuthenticationHandler.class);
    ReconnectStrategy reconnect = Mockito.mock(ReconnectStrategy.class);
    NetconfReconnectingClientConfiguration cfg = NetconfReconnectingClientConfigurationBuilder.create().withProtocol(NetconfClientConfiguration.NetconfClientProtocol.SSH).withAddress(address).withConnectionTimeoutMillis(timeout).withReconnectStrategy(reconnect).withAdditionalHeader(header).withSessionListener(listener).withConnectStrategyFactory(strategy).withAuthHandler(handler).build();
    Assert.assertEquals(timeout, cfg.getConnectionTimeoutMillis());
    Assert.assertEquals(Optional.of(header), cfg.getAdditionalHeader());
    Assert.assertEquals(listener, cfg.getSessionListener());
    Assert.assertEquals(handler, cfg.getAuthHandler());
    Assert.assertEquals(strategy, cfg.getConnectStrategyFactory());
    Assert.assertEquals(NetconfClientConfiguration.NetconfClientProtocol.SSH, cfg.getProtocol());
    Assert.assertEquals(address, cfg.getAddress());
    Assert.assertEquals(reconnect, cfg.getReconnectStrategy());
    SslHandlerFactory sslHandlerFactory = Mockito.mock(SslHandlerFactory.class);
    NetconfReconnectingClientConfiguration cfg2 = NetconfReconnectingClientConfigurationBuilder.create().withProtocol(NetconfClientConfiguration.NetconfClientProtocol.TLS).withAddress(address).withConnectionTimeoutMillis(timeout).withReconnectStrategy(reconnect).withAdditionalHeader(header).withSessionListener(listener).withConnectStrategyFactory(strategy).withSslHandlerFactory(sslHandlerFactory).build();
    Assert.assertEquals(timeout, cfg2.getConnectionTimeoutMillis());
    Assert.assertEquals(Optional.of(header), cfg2.getAdditionalHeader());
    Assert.assertEquals(listener, cfg2.getSessionListener());
    Assert.assertEquals(sslHandlerFactory, cfg2.getSslHandlerFactory());
    Assert.assertEquals(strategy, cfg2.getConnectStrategyFactory());
    Assert.assertEquals(NetconfClientConfiguration.NetconfClientProtocol.TLS, cfg2.getProtocol());
    Assert.assertEquals(address, cfg2.getAddress());
    Assert.assertEquals(reconnect, cfg2.getReconnectStrategy());
}
Also used : NetconfHelloMessageAdditionalHeader(org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader) ReconnectStrategyFactory(org.opendaylight.netconf.nettyutil.ReconnectStrategyFactory) ReconnectStrategy(org.opendaylight.netconf.nettyutil.ReconnectStrategy) InetSocketAddress(java.net.InetSocketAddress) AuthenticationHandler(org.opendaylight.netconf.nettyutil.handler.ssh.authentication.AuthenticationHandler) NetconfReconnectingClientConfiguration(org.opendaylight.netconf.client.conf.NetconfReconnectingClientConfiguration) Test(org.junit.Test)

Aggregations

NetconfHelloMessageAdditionalHeader (org.opendaylight.netconf.api.messages.NetconfHelloMessageAdditionalHeader)13 Test (org.junit.Test)8 EmbeddedChannel (io.netty.channel.embedded.EmbeddedChannel)4 InetSocketAddress (java.net.InetSocketAddress)4 ReconnectStrategy (org.opendaylight.netconf.nettyutil.ReconnectStrategy)4 AuthenticationHandler (org.opendaylight.netconf.nettyutil.handler.ssh.authentication.AuthenticationHandler)4 NetconfClientConfiguration (org.opendaylight.netconf.client.conf.NetconfClientConfiguration)2 NetconfReconnectingClientConfiguration (org.opendaylight.netconf.client.conf.NetconfReconnectingClientConfiguration)2 ReconnectStrategyFactory (org.opendaylight.netconf.nettyutil.ReconnectStrategyFactory)2 Session (org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.netconf.monitoring.rev101004.netconf.state.sessions.Session)2 SuppressFBWarnings (edu.umd.cs.findbugs.annotations.SuppressFBWarnings)1 Bootstrap (io.netty.bootstrap.Bootstrap)1 Channel (io.netty.channel.Channel)1 ChannelFuture (io.netty.channel.ChannelFuture)1 ChannelPromise (io.netty.channel.ChannelPromise)1 EventLoopGroup (io.netty.channel.EventLoopGroup)1 LocalChannel (io.netty.channel.local.LocalChannel)1 HashedWheelTimer (io.netty.util.HashedWheelTimer)1 Timer (io.netty.util.Timer)1 GenericFutureListener (io.netty.util.concurrent.GenericFutureListener)1