aboutsummaryrefslogtreecommitdiff
path: root/t/release/02-multi-server.t
blob: 6a223d794439077c5fa2fc307e7443f78c2a06ea (plain)
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
use lib <lib t/release>;
use Test;
use Test::When <release>;
use Test::Notice;
use IRC::Client;
use Test::IRC::Server;

my $Wait = (%*ENV<IRC_CLIENT_TEST_WAIT>//1) * 5;

notice 'Testing connection to four servers and joining two channels in each';

diag 'Starting IRC Servers';
my $s1 = Test::IRC::Server.new: :port<5020>;
my $s2 = Test::IRC::Server.new: :port<5021>;
my $s3 = Test::IRC::Server.new: :port<5022>;
my $s4 = Test::IRC::Server.new: :port<5023>;
END { $s1.kill; $s2.kill; $s3.kill; $s4.kill; };

loop {
    last if $s1.out.elems & $s2.out.elems & $s3.out.elems & $s4.out.elems >= 2;
    sleep 0.5;
}

diag 'Starting IRC Client';
start {
    my $irc = IRC::Client.new(
        :debug(%*ENV<IRC_CLIENT_DEBUG>//0)
        :nick<IRCBot>
        :channels<#perl6 #perl7>
        :servers(
            s1 => { :port<5020>  },
            s2 => { :port<5021>, :nick<OtherBot>, :channels<#perl7 #perl9>  },
            s3 => { :port<5022>, :channels<#perl10 #perl11>  },
            s4 => { :port<5023>, :nick<YetAnotherBot>  },
        )
    ).run;
}

diag 'Waiting for things to happen...';
Promise.in($Wait).then: { $s1.kill; $s2.kill; $s3.kill; $s4.kill; }
await Promise.allof: ($s1, $s2, $s3, $s4).map: *.promise;

dd $s1.out;
diag '----';
dd $s2.out;
diag '----';
dd $s3.out;
diag '----';
dd $s4.out;
diag '----';

#
# my $out = [
#     {:args($[[Any],]), :event("ircd_registered")},
#     {:args($[[5000, 1, "0.0.0.0"],]), :event("ircd_listener_add")},
#     {
#         :args(
#             $[["IRCBot", 1, 'time', "+i", "~Perl6IRC",
#             "simple.poco.server.irc", "simple.poco.server.irc",
#             "Perl6 IRC Client"],]
#         ),
#         :event("ircd_daemon_nick")},
#     {
#         :args($[["IRCBot!~Perl6IRC\@simple.poco.server.irc", "#perl6"],]), :event("ircd_daemon_join")
#     }
# ];
#
# # Fix time signature;
# for $s.out {
#     next unless .<event> eq 'ircd_daemon_nick';
#     .<args>[0][2] = 'time';
# }
#
# is-deeply $s.out, $out, 'Server output looks right';

done-testing;