WebService-Antigate
view release on metacpan or search on metacpan
#!/usr/bin/env perl
BEGIN {
$ENV{http_proxy} = $ENV{HTTP_PROXY} =
$ENV{https_proxy} = $ENV{HTTPS_PROXY} =
$ENV{all_proxy} = $ENV{ALL_PROXY} = undef;
}
use strict;
use Test::More;
use WebService::Antigate;
use Net::HTTP;
use IO::Socket;
use constant API_KEY => 'd41d8cd98f00b204e9800998ecf8427e';
use constant CAPTCHA_ID => 15;
use constant CAPTCHA_TEXT => 'txet_ahctpac';
use constant BALANCE => 10;
if( $^O eq 'MSWin32' ) {
plan skip_all => 'Windows still does not support fork()';
}
if (%IO::Socket::IP:: && IO::Socket::IP->VERSION < 0.35) {
plan skip_all => 'Bugous IO::Socket::IP detected';
}
my ($pid, $host, $port) = make_api_server();
my $recognizer = WebService::Antigate->new(key => API_KEY, domain => "$host:$port", delay => 1);
is($recognizer->upload(file => 't/captcha.jpg'), CAPTCHA_ID, '->upload(captcha.jpg)');
is($recognizer->last_captcha_id, CAPTCHA_ID, '->last_captcha_id');
is($recognizer->recognize(CAPTCHA_ID), CAPTCHA_TEXT, '->recognize(CAPTCHA_ID)');
is($recognizer->recognize(CAPTCHA_ID+1), undef, '->recognize(CAPTCHA_ID+1)');
is($recognizer->upload(method => 'userrecaptcha'), CAPTCHA_ID, '->upload without content');
is($recognizer->abuse(CAPTCHA_ID), 1, '->abuse(CAPTCHA_ID)');
is($recognizer->abuse(CAPTCHA_ID+1), undef, '->abuse(CAPTCHA_ID+1)');
is($recognizer->balance, BALANCE, '->balance()');
$recognizer->key('b026324c6904b2a9cb4b88d6d61c81d1');
is($recognizer->balance, undef, '->balance() & bad key');
kill 15, $pid;
done_testing();
sub make_api_server {
my $serv = IO::Socket::INET->new(Listen => 3)
or die $@;
my $child = fork;
die 'fork: ', $! unless defined $child;
if ($child == 0) {
while (1) {
my $client = $serv->accept()
or next;
my $headers;
while (1) {
$client->sysread($headers, 1024, length $headers)
or last;
( run in 0.886 second using v1.01-cache-2.11-cpan-d7a12ab2c7f )