Class: Pact::Consumer::MockService
- Inherits:
-
Object
- Object
- Pact::Consumer::MockService
- Defined in:
- lib/pact/consumer/mock_service/app.rb
Instance Method Summary collapse
- #call(env) ⇒ Object
- #configure_logger(options) ⇒ Object
-
#initialize(options = {}) ⇒ MockService
constructor
A new instance of MockService.
- #to_s ⇒ Object
Constructor Details
#initialize(options = {}) ⇒ MockService
Returns a new instance of MockService.
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
# File 'lib/pact/consumer/mock_service/app.rb', line 29 def initialize = {} log_description = configure_logger interaction_list = InteractionList.new @name = .fetch(:name, "MockService") interactions = [] @handlers = [ MissingInteractionsGet.new(@name, @logger, interaction_list), VerificationGet.new(@name, @logger, interaction_list, log_description), InteractionPost.new(@name, @logger, interaction_list), InteractionDelete.new(@name, @logger, interaction_list), LogGet.new(@name, @logger), PactPost.new(@name, @logger, interactions), InteractionReplay.new(@name, @logger, interaction_list, interactions) ] end |
Instance Method Details
#call(env) ⇒ Object
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/pact/consumer/mock_service/app.rb', line 63 def call env response = [] begin relevant_handler = @handlers.detect { |handler| handler.match? env } response = relevant_handler.respond env rescue StandardError => e @logger.error 'Error ocurred in mock service:' @logger.ap e, :error @logger.ap e.backtrace response = [500, {'Content-Type' => 'application/json'}, [{message: e., backtrace: e.backtrace}.to_json]] rescue Exception => e @logger.error 'Exception ocurred in mock service:' @logger.ap e, :error @logger.ap e.backtrace raise e end response end |
#configure_logger(options) ⇒ Object
46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/pact/consumer/mock_service/app.rb', line 46 def configure_logger = {log_file: $stdout}.merge log_stream = [:log_file] @logger = Logger.new log_stream @logger.level = Pact.configuration.logger.level if log_stream.is_a? File File.absolute_path(log_stream).gsub(Dir.pwd + "/", '') else "standard out/err" end end |
#to_s ⇒ Object
59 60 61 |
# File 'lib/pact/consumer/mock_service/app.rb', line 59 def to_s "#{@name} #{super.to_s}" end |