Class: Kapnismology::SmokeTest

Inherits:
Object
  • Object
show all
Defined in:
lib/kapnismology/smoke_test.rb

Overview

This is the base class for all the smoke tests. Inherit from this class and implement the result and self.name method

Defined Under Namespace

Classes: NullResult, Result, SmokeTestFailed, Success

Constant Summary collapse

DEPLOYMENT_TAG =
'deployment'.freeze
RUNTIME_TAG =
'runtime'.freeze
DEFAULT_TAGS =
[DEPLOYMENT_TAG, RUNTIME_TAG].freeze

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.inherited(klass) ⇒ Object



40
41
42
# File 'lib/kapnismology/smoke_test.rb', line 40

def inherited(klass)
  SmokeTestCollection.add_smoke_test(klass)
end

.tagsObject



44
45
46
# File 'lib/kapnismology/smoke_test.rb', line 44

def tags
  DEFAULT_TAGS
end

.timeoutObject



48
49
50
# File 'lib/kapnismology/smoke_test.rb', line 48

def timeout
  10
end

Instance Method Details

#__result__Object

Internally Kapnismology is calling this method. We are handling exceptions under the hood here



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# File 'lib/kapnismology/smoke_test.rb', line 19

def __result__
  execution = Timeout::timeout(self.class.timeout) { result }
  result_object = execution || Result.new(false, {}, 'This test has not returned any result')
  unless result_object.class.ancestors.include?(BaseResult)
    message = "Smoke test #{self.class}, returned #{result_object.class} instead of a Result"
    result_object = Result.new(false, { returned_class: result_object.class }, message)
  end
rescue Kapnismology::SmokeTestFailed => e
  result_object = e.result
rescue Timeout::Error => e
  message = "#{self.class} took more than #{self.class.timeout} seconds to finish and timed-out"
  result_object = Result.new(false, { exception: e.class, message: e.message }, message)
rescue Exception => e # Socket, IO errors inherit from Exception, not StandardError
  message = "Unrescued error happened in #{self.class}"
  result_object = Result.new(false, { exception: e.class, message: e.message }, message)
ensure
  @all_result_messages ||= []
  return result_object.add_debug_messages(@all_result_messages)
end

#resultObject



15
16
# File 'lib/kapnismology/smoke_test.rb', line 15

def result
end