# # 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 # # Convert this class to JSON such that it may be serialized. # def to_json hash = { :test_type => 'jabber', :test_target => @host, :test_port => @port, } hash.to_json 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, "