aboutsummaryrefslogtreecommitdiff
path: root/juick-xmpp-wip/src/test/java/com/juick/xmpp/XMPPTests.java
blob: a9c6904c56c1a0dad5e5a8c3924b529e4b05aa86 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
 * Copyright (C) 2008-2017, Juick
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

package com.juick.xmpp;

import com.juick.components.XMPPRouter;
import com.juick.components.configuration.BotAppConfiguration;
import com.juick.configuration.DataConfiguration;
import com.juick.service.ImagesService;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.mock.mockito.MockBean;
import org.springframework.test.context.junit4.SpringRunner;
import rocks.xmpp.addr.Jid;
import rocks.xmpp.core.XmppException;
import rocks.xmpp.core.session.ConnectionEvent;
import rocks.xmpp.core.session.Extension;
import rocks.xmpp.core.session.XmppSessionConfiguration;
import rocks.xmpp.core.session.debug.LogbackDebugger;
import rocks.xmpp.core.stanza.model.Message;
import rocks.xmpp.extensions.component.accept.ExternalComponent;

import javax.inject.Inject;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;

import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.equalTo;

@RunWith(SpringRunner.class)
@SpringBootTest(webEnvironment = SpringBootTest.WebEnvironment.DEFINED_PORT,
        classes = { BotAppConfiguration.class, DataConfiguration.class})
public class XMPPTests {
    @MockBean
    ImagesService imagesService;
    @Inject
    XMPPRouter router;
    @Inject
    ExecutorService executorService;
    @Test
    public void routerHandshake() throws InterruptedException {
        XmppSessionConfiguration configuration = XmppSessionConfiguration.builder()
                .extensions(Extension.of(com.juick.Message.class))
                .debugger(LogbackDebugger.class)
                .build();
        ExternalComponent routerClient = ExternalComponent.create("test.localhost",
                "secret", configuration, "localhost", 5347);
        CountDownLatch lock = new CountDownLatch(1);
        routerClient.addConnectionListener(connectionEvent -> {
            if (connectionEvent.equals(ConnectionEvent.Type.RECONNECTION_SUCCEEDED)) {
                lock.countDown();
            }
        });
        ExternalComponent routerClient2 = ExternalComponent.create("bot.localhost",
                "secret", configuration, "localhost", 5347);
        CountDownLatch lock2 = new CountDownLatch(1);
        routerClient2.addConnectionListener(connectionEvent -> {
            if (connectionEvent.equals(ConnectionEvent.Type.RECONNECTION_SUCCEEDED)) {
                lock2.countDown();
            }
        });
        executorService.submit(() -> {
            try {
                Thread.sleep(3000);
                routerClient.connect();
                routerClient2.connect();
            } catch (XmppException | InterruptedException e) {
                e.printStackTrace();
            }
            lock.countDown();
            lock2.countDown();
        });
        lock.await();
        CountDownLatch lock3 = new CountDownLatch(2);
        routerClient2.sendMessage(new Message(Jid.of("yoyo@test.localhost"), Message.Type.CHAT, "test" ));
        routerClient2.sendMessage(new Message(Jid.of("yoyo@test.localhost"), Message.Type.CHAT, "test" ));
        routerClient.addInboundMessageListener(messageEvent -> {
            assertThat(messageEvent.getMessage().getBody(), equalTo("test"));
            lock3.countDown();
        });
        lock3.await();
    }
}