Sha256: b623fa1f7715fa768302831ea240487f14de1a07c5b94c8386a93dbbcfc62483

Contents?: true

Size: 1.75 KB

Versions: 4

Compression:

Stored size: 1.75 KB

Contents

# WebROaR - Ruby Application Server - http://webroar.in/
# Copyright (C) 2009  Goonj LLC
#
# This file is part of WebROaR.
#
# WebROaR is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# WebROaR is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with WebROaR.  If not, see <http://www.gnu.org/licenses/>.

module Webroar
  module Analyzer
    module WithExceptionHandling
      MAX_TRIAL = 3
      def with_exception_handling(log_message, &block)
        trial = 0
        begin
          block.call
        rescue ActiveRecord::StatementInvalid, Exception => e
          log_message_with_check(:info, log_message)        
          log_message_with_check(:error, "#{e.message}. try no #{trial+1}")     
          if trial < MAX_TRIAL
            trial += 1            
            sleep(2)          
            retry
          end
          log_message_with_check(:info, log_message)  
          log_message_with_check(:error, e) 
          log_message_with_check(:error, e.backtrace.join("\n"))
        end
      end
      
      def log_message_with_check(level, message)
        if defined? Webroar::Analyzer::Logger
          case level
            when :info
              Webroar::Analyzer::Logger.info(message)
            when :error
              Webroar::Analyzer::Logger.error(message)
          end  
        end
      end
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
webroar-0.5.0 src/ruby_lib/analyzer/with_exception_handling.rb
webroar-0.4.0 src/ruby_lib/analyzer/with_exception_handling.rb
webroar-0.3.1 src/ruby_lib/analyzer/with_exception_handling.rb
webroar-0.3.0 src/ruby_lib/analyzer/with_exception_handling.rb