Sha256: 7722912196cb266fd03969c02da436f236a85c768a42ed5aac971721313183df

Contents?: true

Size: 1.37 KB

Versions: 2

Compression:

Stored size: 1.37 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
          WLogger.info(log_message)        
          WLogger.error("#{e.message}. try no #{trial+1}")     
          if trial < MAX_TRIAL
            trial += 1            
            sleep(2)          
            retry
          end
          WLogger.info(log_message)  
          WLogger.error(e) 
          WLogger.error(e.backtrace.join("\n"))
        end
      end      
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
webroar-0.7.0 src/ruby_lib/analyzer/with_exception_handling.rb
webroar-0.6.1 src/ruby_lib/analyzer/with_exception_handling.rb