File: z_06_iq_ping_timeout.t

package info (click to toggle)
libanyevent-xmpp-perl 0.55-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 784 kB
  • ctags: 553
  • sloc: perl: 8,004; makefile: 13
file content (49 lines) | stat: -rw-r--r-- 1,235 bytes parent folder | download | duplicates (6)
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
#!perl

use strict;
no warnings;
use Test::More;
use AnyEvent::XMPP;
use AnyEvent::XMPP::Namespaces qw/xmpp_ns/;
use AnyEvent::XMPP::TestClient;
use AnyEvent::XMPP::IM::Message;
use AnyEvent::XMPP::Util qw/bare_jid/;

my $cl =
   AnyEvent::XMPP::TestClient->new_or_exit (tests => 1, finish_count => 1);
my $C = $cl->client;
my $disco = $cl->instance_ext ('AnyEvent::XMPP::Ext::Disco');
my $ping  = $cl->instance_ext ('AnyEvent::XMPP::Ext::Ping');

$disco->enable_feature ($ping->disco_feature);

my $disconnect_reason = '';
my @ignore_ids;

$C->reg_cb (
   session_ready => sub {
      my ($C, $acc) = @_;
      my $con = $acc->connection;
      push @ignore_ids, $con->next_iq_id;
      $ping->enable_timeout ($con, 1);
   },
   disconnect => sub {
      my ($C, $acc, $h, $p, $reason) = @_;
      $disconnect_reason = $reason;
      $cl->finish;
   },
   before_recv_stanza_xml => sub {
      my ($C, $acc, $node, $rstop) = @_;

      if ($node->eq (client => 'iq')
          && ($node->attr ('type') eq 'result' || $node->attr ('type') eq 'error')
          && grep { $_ eq $node->attr ('id') } @ignore_ids)
      {
         $$rstop = 1;
      }
   }
);

$cl->wait;

ok ($disconnect_reason =~ /timeout/, "disconnected by timeout");