diff options
| author | Steve Kemp <steve@steve.org.uk> | 2012-11-22 15:59:45 +0000 | 
|---|---|---|
| committer | Steve Kemp <steve@steve.org.uk> | 2012-11-22 15:59:45 +0000 | 
| commit | 1277b6ba2356205b5809bfee44a25fa49077db32 (patch) | |
| tree | 12fe4b96ab823a315f418735785e728b480060ec /lib | |
| parent | cf588bcbe2fe066a3df1cc10ab5606dbf4205513 (diff) | |
  Updated to use the new string-body from jobs, and the new factory to generate tests.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/custodian/worker.rb | 94 | 
1 files changed, 25 insertions, 69 deletions
| diff --git a/lib/custodian/worker.rb b/lib/custodian/worker.rb index 73cc97c..49a298d 100644 --- a/lib/custodian/worker.rb +++ b/lib/custodian/worker.rb @@ -12,18 +12,18 @@ require 'logger'  #  # Implementation of our protocol tests.  # -require 'custodian/alerter.rb' -require 'custodian/protocol-tests/dns.rb' -require 'custodian/protocol-tests/ftp.rb' -require 'custodian/protocol-tests/http.rb' -require 'custodian/protocol-tests/jabber.rb' -require 'custodian/protocol-tests/ldap.rb' -require 'custodian/protocol-tests/ping.rb' -require 'custodian/protocol-tests/rsync.rb' -require 'custodian/protocol-tests/smtp.rb' -require 'custodian/protocol-tests/ssh.rb' -require 'custodian/protocol-tests/tcp.rb' - +#require 'custodian/alerter.rb' +require 'custodian/protocoltest/tcp.rb' +require 'custodian/protocoltest/dns.rb' +require 'custodian/protocoltest/ftp.rb' +require 'custodian/protocoltest/http.rb' +require 'custodian/protocoltest/jabber.rb' +require 'custodian/protocoltest/ldap.rb' +require 'custodian/protocoltest/ping.rb' +require 'custodian/protocoltest/rsync.rb' +require 'custodian/protocoltest/ssh.rb' +require 'custodian/protocoltest/smtp.rb' +require 'custodian/testfactory' @@ -114,39 +114,17 @@ module Custodian          log_message( "Job aquired - Job ID : #{job.id}" ) -          #          #  Get the job body          # -        json = job.body -        raise ArgumentError, "Body doesn't look like JSON" unless( json =~ /[{}]/ ) - - -        # -        # Decode the JSON body - it should return a non-empty hash. -        # -        hash = JSON.parse( json ) +        body = job.body +        raise ArgumentError, "Job was empty" if (body.nil?) +        raise ArgumentError, "Job was not a string" unless body.kind_of?(String)          # -        # Ensure we got a non-empty hash. -        # -        raise ArgumentError, "JSON didn't decode to a hash" unless hash.kind_of?(Hash) -        raise ArgumentError, "JSON hash is empty" if (hash.empty?) - +        #  Output the job.          # -        # Are we being verbose? -        # -        hash['verbose'] = 1 if ( ENV['VERBOSE'] ) - - -        # -        #  Output the details. -        # -        log_message( "Job body contains the following keys & values:") -        hash.keys.each do |key| -          log_message( "   #{key} => #{hash[key]}" ) -        end - +        log_message( "Job: #{body}" )          # @@ -156,41 +134,19 @@ module Custodian          success = false          count   = 0 -        # -        # As a result of this test we'll either raise/clear with mauve. -        # -        # This helper will do that job. -        # -        alert = Alerter.new( hash ) -          # -        # Convert the test-type to a class name, to do the protocol test. +        # Create the test-object.          # -        # Given a test-type "foo" we'll attempt to instantiate a class called FOOTest. -        # -        test  = hash['test_type'] -        test  = "http" if ( test == "https" ) -        clazz = test.upcase -        clazz = "#{clazz}Test" +        test = Custodian::TestFactory.create( body )          # -        # Create the test object. -        # -        obj = eval(clazz).new( hash ) - - +        # As a result of this test we'll either raise/clear with mauve.          # -        # Ensure that the object we load implements the two methods -        # we expect. +        # This helper will do that job.          # -        if ( ( ! obj.respond_to?( "error") ) || -             ( ! obj.respond_to?( "run_test" ) ) ) -          puts "Class #{clazz} doesn't implement the full protocol-test API" -        end - - +        alert = Alerter.new( test )          #          #  We'll run no more than MAX times. @@ -201,7 +157,7 @@ module Custodian            log_message( "Running test - [#{count}/#{@retry_count}]" ) -          if ( obj.run_test() ) +          if ( test.run_test )              log_message( "Test succeeed - clearing alert" )              success = true              alert.clear() @@ -218,8 +174,8 @@ module Custodian            #            # Raise the alert, passing the error message.            # -          log_message( "Test failed - alerting with #{obj.error()}" ) -          alert.raise( obj.error() ) +          log_message( "Test failed - alerting with #{test.error()}" ) +          alert.raise( test.error() )          end        rescue => ex | 
