Class: PerfectRetry::Config

Inherits:
Struct
  • Object
show all
Defined in:
lib/perfect_retry/config.rb

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#dont_rescuesObject

Returns the value of attribute dont_rescues

Returns:

  • (Object)

    the current value of dont_rescues



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def dont_rescues
  @dont_rescues
end

#ensureObject

Returns the value of attribute ensure

Returns:

  • (Object)

    the current value of ensure



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def ensure
  @ensure
end

#limitObject

Returns the value of attribute limit

Returns:

  • (Object)

    the current value of limit



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def limit
  @limit
end

#log_levelObject

Returns the value of attribute log_level

Returns:

  • (Object)

    the current value of log_level



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def log_level
  @log_level
end

#loggerObject

Returns the value of attribute logger

Returns:

  • (Object)

    the current value of logger



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def logger
  @logger
end

#rescuesObject

Returns the value of attribute rescues

Returns:

  • (Object)

    the current value of rescues



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def rescues
  @rescues
end

#sleepObject

Returns the value of attribute sleep

Returns:

  • (Object)

    the current value of sleep



4
5
6
# File 'lib/perfect_retry/config.rb', line 4

def sleep
  @sleep
end

Class Method Details

.create_from_hash(hash) ⇒ Object



5
6
7
8
9
10
11
# File 'lib/perfect_retry/config.rb', line 5

def self.create_from_hash(hash)
  config = new
  hash.each do |k, v|
    config.send("#{k}=", v)
  end
  config
end

Instance Method Details

#set_log_levelObject



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/perfect_retry/config.rb', line 13

def set_log_level
  if log_level && !logger.respond_to?(:level=)
    logger.warn("Ignore log_level setting because your logger don't have `level=` method. Info: `config.log_level = nil` will not try to change log level.")
    return
  end

  case log_level
  when Fixnum
    logger.level = log_level
    return
  when String, Symbol
    if int = Logger::SEV_LABEL.index(log_level.to_s.upcase)
      logger.level = int
      return
    end
  when nil
    # Don't touch when nil
    return
  end

  raise "Unknown log level '#{log_level}'(#{log_level.class})"
end

#sleep_sec(count) ⇒ Object



36
37
38
39
40
41
42
# File 'lib/perfect_retry/config.rb', line 36

def sleep_sec(count)
  if sleep.is_a?(Proc)
    sleep.call(count)
  else
    sleep
  end
end