File: z_06_iq_ping.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 (51 lines) | stat: -rw-r--r-- 1,309 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
50
51
#!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 => 3, two_accounts => 1, finish_count => 2);
my $C = $cl->client;
my $disco = $cl->instance_ext ('AnyEvent::XMPP::Ext::Disco');
my $ping  = $cl->instance_ext ('AnyEvent::XMPP::Ext::Ping');
$ping->auto_timeout (1);

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

my $ping_error = '';
my $response_time;
my $feature = 0;

$C->reg_cb (
   two_accounts_ready => sub {
      my ($C) = @_;
      my $con = $cl->{acc}->connection;

      $disco->request_info ($con, $cl->{jid2}, undef, sub {
         my ($disco, $info, $error) = @_;
         $feature = ! ! ($info->features->{xmpp_ns ('ping')});
         $cl->finish;
      });

      $ping->ping ($con, $cl->{jid2}, sub {
         my ($time, $error) = @_;
         if ($error) {
            $ping_error = $error->string;
         }
         $response_time = $time;
         $cl->finish;
      });
   }
);

$cl->wait;

is ($ping_error,         '', 'no ping error');
ok ($feature               , 'ping feature advertised');
ok ($response_time > 0.0001, 'got a reasonable response time');