diff options
| author | Steve Kemp <steve@steve.org.uk> | 2013-11-22 13:14:31 +0000 | 
|---|---|---|
| committer | Steve Kemp <steve@steve.org.uk> | 2013-11-22 13:14:31 +0000 | 
| commit | e4d382dcd7c36f6b153b29254ebdc5e33f1f8274 (patch) | |
| tree | 84f54e57a51559220a5a6d860f14d1508748ec6a | |
| parent | 1b01ec3b7d59ee1316bea78ea17b8bf0002dda87 (diff) | |
  Added trivial TCP-connect test for postgresql
| -rw-r--r-- | lib/custodian/protocoltest/postgresql.rb | 100 | ||||
| -rw-r--r-- | lib/custodian/protocoltests.rb | 1 | 
2 files changed, 101 insertions, 0 deletions
| diff --git a/lib/custodian/protocoltest/postgresql.rb b/lib/custodian/protocoltest/postgresql.rb new file mode 100644 index 0000000..294ca52 --- /dev/null +++ b/lib/custodian/protocoltest/postgresql.rb @@ -0,0 +1,100 @@ +require 'custodian/protocoltest/tcp' + +# +#  The PostgreSQL-protocol test. +# +#  This object is instantiated if the parser sees a line such as: +# +### +### foo.vm.bytemark.co.uk must run postgresql otherwise 'database fail'. +### +# +#  The specification of the port is optional, and defaults to 5432 +# +module Custodian + +  module ProtocolTest + +    class PostgreSQLTest < TCPTest + +      # +      # Constructor +      # +      # Ensure we received a port to run the test against. +      # +      def initialize( line ) + +        # +        # Save the line +        # +        @line = line + +        # +        # Save the host +        # +        @host  = line.split( /\s+/)[0] + + +        # +        # Is this test inverted? +        # +        if ( line =~ /must\s+not\s+run\s+/ ) +          @inverted = true +        else +          @inverted = false +        end + + +        # +        # Save the port +        # +        if ( line =~ /on\s+([0-9]+)/ ) +          @port = $1.dup +        else +          @port = 5432 +        end +      end + + + + +      # +      # Allow this test to be serialized. +      # +      def to_s +        return( @line ) +      end + + + + +      # +      # Run the test. +      # +      def run_test + +        # reset the error, in case we were previously executed. +        @error = nil + +        run_test_internal( @host, @port ) +      end + + + + +      # +      # If the test fails then report the error. +      # +      def error +        @error +      end + + + + +      register_test_type "postgresql" + + +    end +  end +end diff --git a/lib/custodian/protocoltests.rb b/lib/custodian/protocoltests.rb index 3a18754..a1b6f3b 100644 --- a/lib/custodian/protocoltests.rb +++ b/lib/custodian/protocoltests.rb @@ -21,6 +21,7 @@ require 'custodian/protocoltest/ldap'  require 'custodian/protocoltest/mysql'  require 'custodian/protocoltest/ping'  require 'custodian/protocoltest/pop3' +require 'custodian/protocoltest/postgresql'  require 'custodian/protocoltest/redis'  require 'custodian/protocoltest/rsync'  require 'custodian/protocoltest/openproxy' | 
