summaryrefslogtreecommitdiffstats
path: root/t/02-read-write.t
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2010-06-15 21:20:26 -0500
committerJesse Luehrs <doy@tozt.net>2010-06-15 21:21:56 -0500
commit508218365c734253b7a0855084031be28446de66 (patch)
tree80cf3464c6c425e3cf017f56ee5c0e66861b82a4 /t/02-read-write.t
parent43477c66218bbf97a1ad83d6df70e38c19926240 (diff)
downloadapp-termcast-508218365c734253b7a0855084031be28446de66.tar.gz
app-termcast-508218365c734253b7a0855084031be28446de66.zip
dzil stuff0.07
Diffstat (limited to 't/02-read-write.t')
-rw-r--r--t/02-read-write.t55
1 files changed, 55 insertions, 0 deletions
diff --git a/t/02-read-write.t b/t/02-read-write.t
new file mode 100644
index 0000000..a03effb
--- /dev/null
+++ b/t/02-read-write.t
@@ -0,0 +1,55 @@
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+use App::Termcast;
+use IO::Pty::Easy;
+BEGIN {
+ eval "use Test::TCP;";
+ plan skip_all => "Test::TCP is required for this test" if $@;
+ plan tests => 5;
+}
+
+test_tcp(
+ client => sub {
+ my $port = shift;
+ my $client_script = <<EOF;
+ use App::Termcast;
+ my \$tc = App::Termcast->new(
+ host => '127.0.0.1', port => $port,
+ user => 'test', password => 'tset');
+ \$tc->run('$^X', "-e", "while (<>) { last if /\\\\./; print }");
+EOF
+ my $pty = IO::Pty::Easy->new;
+ $pty->spawn("$^X", "-e", $client_script);
+ $pty->write("foo\n");
+ sleep 1; # give the subprocess time to generate its output
+ is($pty->read, "foo\r\nfoo\r\n", 'got the right thing on stdout');
+ $pty->write("bar\n");
+ sleep 1; # give the subprocess time to generate its output
+ is($pty->read, "bar\r\nbar\r\n", 'got the right thing on stdout');
+ $pty->write(".\n");
+ is($pty->read, ".\r\n", "didn't get too much data");
+ sleep 1; # because the server gets killed when the client exits
+ },
+ server => sub {
+ my $port = shift;
+ my $sock = IO::Socket::INET->new(LocalAddr => '127.0.0.1',
+ LocalPort => $port,
+ Listen => 1);
+ $sock->accept; # signal to the client that the port is available
+ my $client = $sock->accept;
+ my $login;
+ $client->recv($login, 4096);
+ is($login, "hello test tset\n", 'got the correct login info');
+ my $output;
+ my $total_out = '';
+ while (1) {
+ $client->recv($output, 4096);
+ last unless defined($output) && length($output);
+ $total_out .= $output;
+ }
+ is($total_out, "foo\r\nfoo\r\nbar\r\nbar\r\n.\r\n",
+ 'sent the right data to the server');
+ },
+);