Class: IsItWorking::Status

Inherits:
Object
  • Object
show all
Defined in:
lib/is_it_working/status.rb

Overview

This class is used to pass the status of a monitoring check. Each status can have multiple messages added to it by calling the ok or fail methods. The status check will only be considered a success if all messages are ok.

Defined Under Namespace

Classes: Message

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name) ⇒ Status

Returns a new instance of Status.



38
39
40
41
# File 'lib/is_it_working/status.rb', line 38

def initialize(name)
  @name = name
  @messages = []
end

Instance Attribute Details

#messagesObject (readonly)

The messages set on the status check.



33
34
35
# File 'lib/is_it_working/status.rb', line 33

def messages
  @messages
end

#nameObject (readonly)

The name of the status check for display purposes.



30
31
32
# File 'lib/is_it_working/status.rb', line 30

def name
  @name
end

#timeObject

The amount of time it takes to complete the status check.



36
37
38
# File 'lib/is_it_working/status.rb', line 36

def time
  @time
end

Instance Method Details

#fail(message) ⇒ Object

Add a message indicating that the check failed.



53
54
55
# File 'lib/is_it_working/status.rb', line 53

def fail(message)
  @messages << Message.new(message, :fail)
end

#info(message) ⇒ Object



48
49
50
# File 'lib/is_it_working/status.rb', line 48

def info(message)
  @messages << Message.new(message, :info)
end

#ok(message) ⇒ Object

Add a message indicating that the check passed.



44
45
46
# File 'lib/is_it_working/status.rb', line 44

def ok(message)
  @messages << Message.new(message, :ok)
end

#success?Boolean

Returns true only if all checks were OK.

Returns:

  • (Boolean)


58
59
60
# File 'lib/is_it_working/status.rb', line 58

def success?
  @messages.all?{|m| m.ok?}
end