From 6c11958ab96a8a0f0b75bfd5fee21dbb3fdf2eec Mon Sep 17 00:00:00 2001 From: Steve Kemp Date: Wed, 21 Nov 2012 23:52:09 +0000 Subject: LDAP-protocol is now testable. --- lib/custodian/protocoltest/ldap.rb | 113 +++++++++++++++++++++++++++++++++++++ 1 file changed, 113 insertions(+) create mode 100644 lib/custodian/protocoltest/ldap.rb (limited to 'lib/custodian/protocoltest/ldap.rb') diff --git a/lib/custodian/protocoltest/ldap.rb b/lib/custodian/protocoltest/ldap.rb new file mode 100644 index 0000000..6b55687 --- /dev/null +++ b/lib/custodian/protocoltest/ldap.rb @@ -0,0 +1,113 @@ +# +# The LDAP-protocol test. +# +# This object is instantiated if the parser sees a line such as: +# +### +### foo.vm.bytemark.co.uk must run ldap otherwise 'auth-server fail'. +### +# +# The specification of the port is optional and defaults to 389. +# +class LDAPTest < TCPTest + + + # + # The line from which we were constructed. + # + attr_reader :line + + + # + # The host to test against. + # + attr_reader :host + + + # + # The port to connect to. + # + attr_reader :port + + + + + # + # Constructor + # + def initialize( line ) + + # + # Save the line. + # + @line = line + + # + # Save the host + # + @host = line.split( /\s+/)[0] + + # + # Save the port + # + if ( line =~ /on\s+([0-9]+)/ ) + @port = $1.dup + else + @port = 389 + end + end + + + + + # + # Helper for development. + # + def to_s + "ldap-test of #{@host}:#{@port}." + end + + + + + # + # Convert this class to JSON such that it may be serialized. + # + def to_json + hash = { :line => @line } + 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, nil, false ) + end + + + + + # + # If the test fails then report the error. + # + def error + @error + end + + + + + register_test_type "ldap" + + + + +end -- cgit v1.2.1