diff options
-rwxr-xr-x | bin/custodian-parse-execute | 1 | ||||
-rw-r--r-- | lib/custodian/protocoltest/jabber.rb | 89 |
2 files changed, 90 insertions, 0 deletions
diff --git a/bin/custodian-parse-execute b/bin/custodian-parse-execute index 19dd0bc..5ef48a7 100755 --- a/bin/custodian-parse-execute +++ b/bin/custodian-parse-execute @@ -11,6 +11,7 @@ require 'custodian/protocoltest.rb' require 'custodian/protocoltest/tcp.rb' require 'custodian/protocoltest/ftp.rb' +require 'custodian/protocoltest/jabber.rb' require 'custodian/protocoltest/rsync.rb' require 'custodian/protocoltest/ssh.rb' require 'custodian/protocoltest/smtp.rb' diff --git a/lib/custodian/protocoltest/jabber.rb b/lib/custodian/protocoltest/jabber.rb new file mode 100644 index 0000000..a9920f0 --- /dev/null +++ b/lib/custodian/protocoltest/jabber.rb @@ -0,0 +1,89 @@ +# +# The Jabber-protocol test. +# +# This object is instantiated if the parser sees a line such as: +# +### +### foo.vm.bytemark.co.uk must run jabber otherwise 'chat failure'. +### +# +# The specification of the port is optional. +# +class JABBERTest < TCPTest + + + # + # The host to test against. + # + attr_reader :host + + + # + # The port to connect to. + # + attr_reader :port + + + + # + # Constructor + # + def initialize( line ) + # + # Save the host + # + @host = line.split( /\s+/)[0] + + # + # Save the port + # + if ( line =~ /on\s+([0-9]+)/ ) + @port = $1.dup + else + @port = 5222 + end + end + + + + + # + # Helper for development. + # + def to_s + "jabber-test of #{@host}:#{@port}." + end + + + + + # + # Run the TCP-protocol test. + # + def run_test + + # reset the error, in case we were previously executed. + @error = nil + + run_test_internal( @host, @port, "<stream:stream" ) + end + + + + + # + # If the test fails then report the error. + # + def error + @error + end + + + + + register_test_type "jabber" + + + + +end |