From e4d382dcd7c36f6b153b29254ebdc5e33f1f8274 Mon Sep 17 00:00:00 2001 From: Steve Kemp Date: Fri, 22 Nov 2013 13:14:31 +0000 Subject: Added trivial TCP-connect test for postgresql --- lib/custodian/protocoltest/postgresql.rb | 100 +++++++++++++++++++++++++++++++ lib/custodian/protocoltests.rb | 1 + 2 files changed, 101 insertions(+) create mode 100644 lib/custodian/protocoltest/postgresql.rb (limited to 'lib/custodian') 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' -- cgit v1.2.1