litmus_paper 0.8.2 → 0.8.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,9 +5,10 @@ module LitmusPaper
5
5
  get "/" do
6
6
  output = "Litmus Paper #{LitmusPaper::VERSION}\n\n"
7
7
  output += "Services monitored:\n"
8
+ output += " Service ( Health / Measured Health )\n"
8
9
  LitmusPaper.services.each do |service_name, service|
9
10
  health = service.current_health
10
- output += "* #{service_name} (#{health.value})"
11
+ output += "* #{service_name} ( #{health.value} / #{health.measured_health} )"
11
12
  if health.forced?
12
13
  output += " - forced: #{service.current_health.summary}"
13
14
  end
@@ -48,6 +49,9 @@ module LitmusPaper
48
49
 
49
50
  headers = {"X-Health" => health.value.to_s}
50
51
  body = "Health: #{health.value}\n"
52
+ if health.forced?
53
+ body << "Measured Health: #{health.measured_health}\n"
54
+ end
51
55
  body << health.summary
52
56
 
53
57
  if health.forced?
@@ -3,10 +3,11 @@ module LitmusPaper
3
3
 
4
4
  attr_reader :summary
5
5
 
6
- def initialize
6
+ def initialize(forced = :none, summary = "")
7
7
  @value = 0
8
8
  @dependencies_available = true
9
- @summary = ""
9
+ @summary = summary
10
+ @forced = forced
10
11
  end
11
12
 
12
13
  def ok?
@@ -14,10 +15,18 @@ module LitmusPaper
14
15
  end
15
16
 
16
17
  def forced?
17
- false
18
+ @forced != :none
18
19
  end
19
20
 
20
21
  def value
22
+ if forced?
23
+ return @forced == :up ? 100 : 0
24
+ end
25
+
26
+ measured_health
27
+ end
28
+
29
+ def measured_health
21
30
  return 0 unless @dependencies_available
22
31
  @value
23
32
  end
@@ -8,9 +8,8 @@ module LitmusPaper
8
8
 
9
9
  def current_health
10
10
  forced_health = _determine_forced_health
11
- return forced_health unless forced_health.nil?
12
11
 
13
- health = LitmusPaper::Health.new
12
+ health = forced_health ? forced_health : LitmusPaper::Health.new
14
13
  @dependencies.each do |dependency|
15
14
  health.ensure(dependency)
16
15
  end
@@ -35,7 +34,7 @@ module LitmusPaper
35
34
 
36
35
  def _determine_forced_health
37
36
  _health_files.map do |status_file|
38
- ForcedHealth.new(status_file.health, status_file.content) if status_file.exists?
37
+ LitmusPaper::Health.new(status_file.forced, status_file.content) if status_file.exists?
39
38
  end.compact.first
40
39
  end
41
40
  end
@@ -1,21 +1,21 @@
1
1
  module LitmusPaper
2
2
  class StatusFile
3
- attr_reader :health
3
+ attr_reader :forced
4
4
 
5
5
  def self.global_down_file
6
- new("global_down", 0)
6
+ new("global_down", :down)
7
7
  end
8
8
 
9
9
  def self.global_up_file
10
- new("global_up", 100)
10
+ new("global_up", :up)
11
11
  end
12
12
 
13
13
  def self.service_down_file(service_name)
14
- new("#{service_name}_down", 0)
14
+ new("#{service_name}_down", :down)
15
15
  end
16
16
 
17
17
  def self.service_up_file(service_name)
18
- new("#{service_name}_up", 100)
18
+ new("#{service_name}_up", :up)
19
19
  end
20
20
 
21
21
  def self.priority_check_order_for_service(service_name)
@@ -27,13 +27,13 @@ module LitmusPaper
27
27
  ]
28
28
  end
29
29
 
30
- def initialize(filename, health)
30
+ def initialize(filename, forced)
31
31
  @path = File.join(LitmusPaper.data_directory, filename)
32
- @health = health
32
+ @forced = forced
33
33
  end
34
34
 
35
35
  def content
36
- File.read(@path).chomp
36
+ File.read(@path).chomp + "\n"
37
37
  end
38
38
 
39
39
  def create(reason)
@@ -1,3 +1,3 @@
1
1
  module LitmusPaper
2
- VERSION = "0.8.2"
2
+ VERSION = "0.8.3"
3
3
  end
data/lib/litmus_paper.rb CHANGED
@@ -31,7 +31,6 @@ require 'litmus_paper/dependency/http'
31
31
  require 'litmus_paper/dependency/script'
32
32
  require 'litmus_paper/dependency/tcp'
33
33
  require 'litmus_paper/health'
34
- require 'litmus_paper/forced_health'
35
34
  require 'litmus_paper/logger'
36
35
  require 'litmus_paper/metric/available_memory'
37
36
  require 'litmus_paper/metric/big_brother_service'
@@ -35,7 +35,7 @@ describe LitmusPaper::App do
35
35
  get "/"
36
36
 
37
37
  last_response.status.should == 200
38
- last_response.body.should include("* test (0)\n")
38
+ last_response.body.should include("* test ( 0 / 0 )\n")
39
39
  end
40
40
 
41
41
  it "includes the status if forced" do
@@ -48,8 +48,8 @@ describe LitmusPaper::App do
48
48
  get "/"
49
49
 
50
50
  last_response.status.should == 200
51
- last_response.body.should include("* another (0) - forced: Down for testing\n")
52
- last_response.body.should include("* test (100) - forced: Up for testing\n")
51
+ last_response.body.should include("* another ( 0 / 0 ) - forced: Down for testing\n")
52
+ last_response.body.should include("* test ( 100 / 0 ) - forced: Up for testing\n")
53
53
  end
54
54
  end
55
55
 
@@ -212,8 +212,23 @@ describe LitmusPaper::App do
212
212
  last_response.body.should match(/Down for testing/)
213
213
  end
214
214
 
215
- it "is 'service available' when an up file exists" do
216
- test_service = LitmusPaper::Service.new('test', [NeverAvailableDependency.new], [LitmusPaper::Metric::ConstantMetric.new(100)])
215
+ it "still reports the health, dependencies, and metrics when forced down" do
216
+ test_service = LitmusPaper::Service.new('test', [AlwaysAvailableDependency.new], [LitmusPaper::Metric::ConstantMetric.new(100)])
217
+ LitmusPaper.services['test'] = test_service
218
+
219
+ LitmusPaper::StatusFile.service_down_file("test").create("Down for testing")
220
+
221
+ get "/test/status"
222
+
223
+ last_response.status.should == 503
224
+ last_response.headers["X-Health-Forced"].should == "down"
225
+ last_response.body.should match(/Measured Health: 100\n/)
226
+ last_response.body.should match(/AlwaysAvailableDependency: OK\n/)
227
+ last_response.body.should match(/Metric::ConstantMetric\(100\): 100\n/)
228
+ end
229
+
230
+ it "still reports the health, dependencies, and metrics when forced up" do
231
+ test_service = LitmusPaper::Service.new('test', [AlwaysAvailableDependency.new], [LitmusPaper::Metric::ConstantMetric.new(100)])
217
232
  LitmusPaper.services['test'] = test_service
218
233
 
219
234
  LitmusPaper::StatusFile.service_up_file("test").create("Up for testing")
@@ -222,7 +237,9 @@ describe LitmusPaper::App do
222
237
 
223
238
  last_response.status.should == 200
224
239
  last_response.headers["X-Health-Forced"].should == "up"
225
- last_response.body.should match(/Up for testing/)
240
+ last_response.body.should match(/Measured Health: 100\n/)
241
+ last_response.body.should match(/AlwaysAvailableDependency: OK\n/)
242
+ last_response.body.should match(/Metric::ConstantMetric\(100\): 100\n/)
226
243
  end
227
244
 
228
245
  it "is 'service available' when an up file exists" do
@@ -26,7 +26,7 @@ describe LitmusPaper::Service do
26
26
  LitmusPaper::StatusFile.service_down_file("test").create("Down for testing")
27
27
 
28
28
  service.current_health.value.should == 0
29
- service.current_health.summary.should == "Down for testing"
29
+ service.current_health.summary.should match(/Down for testing/)
30
30
  end
31
31
 
32
32
  it "is 0 when a global down file exists" do
@@ -37,7 +37,7 @@ describe LitmusPaper::Service do
37
37
  LitmusPaper::StatusFile.global_down_file.create("Down for testing")
38
38
 
39
39
  service.current_health.value.should == 0
40
- service.current_health.summary.should == "Down for testing"
40
+ service.current_health.summary.should match(/Down for testing/)
41
41
  end
42
42
 
43
43
  it "is 100 when an up file exists" do
@@ -48,7 +48,7 @@ describe LitmusPaper::Service do
48
48
  LitmusPaper::StatusFile.service_up_file("test").create("Up for testing")
49
49
 
50
50
  service.current_health.value.should == 100
51
- service.current_health.summary.should == "Up for testing"
51
+ service.current_health.summary.should match(/Up for testing/)
52
52
  end
53
53
 
54
54
  it "is 100 when a global up file exists" do
@@ -59,7 +59,7 @@ describe LitmusPaper::Service do
59
59
  LitmusPaper::StatusFile.global_up_file.create("Up for testing")
60
60
 
61
61
  service.current_health.value.should == 100
62
- service.current_health.summary.should == "Up for testing"
62
+ service.current_health.summary.should match(/Up for testing/)
63
63
  end
64
64
  end
65
65
  end
@@ -3,23 +3,23 @@ require 'spec_helper'
3
3
  describe LitmusPaper::StatusFile do
4
4
  describe "create" do
5
5
  it "creates a file" do
6
- status_file = LitmusPaper::StatusFile.new("foo", 100)
6
+ status_file = LitmusPaper::StatusFile.new("foo", :up)
7
7
  status_file.create("for testing")
8
8
 
9
9
  status_file.exists?.should == true
10
10
  end
11
11
 
12
12
  it "writes the content" do
13
- status_file = LitmusPaper::StatusFile.new("foo", 100)
13
+ status_file = LitmusPaper::StatusFile.new("foo", :up)
14
14
  status_file.create("for testing")
15
15
 
16
- status_file.content.should == "for testing"
16
+ status_file.content.should match(/for testing/)
17
17
  end
18
18
  end
19
19
 
20
20
  describe "delete" do
21
21
  it "removes the file" do
22
- status_file = LitmusPaper::StatusFile.new("foo", 100)
22
+ status_file = LitmusPaper::StatusFile.new("foo", :up)
23
23
  status_file.create("for testing")
24
24
 
25
25
  status_file.exists?.should be_true
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: litmus_paper
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.8.2
4
+ version: 0.8.3
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2014-03-12 00:00:00.000000000 Z
12
+ date: 2014-05-05 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: sinatra
@@ -191,7 +191,6 @@ files:
191
191
  - lib/litmus_paper/dependency/http.rb
192
192
  - lib/litmus_paper/dependency/script.rb
193
193
  - lib/litmus_paper/dependency/tcp.rb
194
- - lib/litmus_paper/forced_health.rb
195
194
  - lib/litmus_paper/health.rb
196
195
  - lib/litmus_paper/logger.rb
197
196
  - lib/litmus_paper/metric/available_memory.rb
@@ -1,22 +0,0 @@
1
- module LitmusPaper
2
- class ForcedHealth
3
- attr_reader :summary
4
-
5
- def initialize(health, summary)
6
- @health = health
7
- @summary = summary
8
- end
9
-
10
- def value
11
- @health
12
- end
13
-
14
- def ok?
15
- @health > 0
16
- end
17
-
18
- def forced?
19
- true
20
- end
21
- end
22
- end