Class: Soaspec::SpecLogger
- Inherits:
-
Object
- Object
- Soaspec::SpecLogger
- Defined in:
- lib/soaspec/spec_logger.rb
Overview
Handles logs of API requests and responses
Class Attribute Summary collapse
-
.output_to_file ⇒ Object
Readers for log parameters.
-
.output_to_terminal ⇒ Object
Readers for log parameters.
-
.time_test_run ⇒ Object
readonly
Readers for log parameters.
-
.traffic_folder ⇒ Object
Folder to put API traffic logs.
Class Method Summary collapse
-
.create ⇒ Logger
Create new log file if necessary and setup logging level.
-
.info(message) ⇒ Object
Log a message using Soaspec logger.
-
.log_api_traffic=(set) ⇒ Object
Whether to log all API traffic.
-
.log_api_traffic? ⇒ Boolean
Whether to log all API traffic.
-
.traffic_file ⇒ String
Traffic file to create logs at.
Class Attribute Details
.output_to_file ⇒ Object
Readers for log parameters
21 22 23 |
# File 'lib/soaspec/spec_logger.rb', line 21 def output_to_file @output_to_file end |
.output_to_terminal ⇒ Object
Readers for log parameters
21 22 23 |
# File 'lib/soaspec/spec_logger.rb', line 21 def output_to_terminal @output_to_terminal end |
.time_test_run ⇒ Object (readonly)
Readers for log parameters
21 22 23 |
# File 'lib/soaspec/spec_logger.rb', line 21 def time_test_run @time_test_run end |
.traffic_folder ⇒ Object
Folder to put API traffic logs
19 20 21 |
# File 'lib/soaspec/spec_logger.rb', line 19 def traffic_folder @traffic_folder end |
Class Method Details
.create ⇒ Logger
Create new log file if necessary and setup logging level
54 55 56 57 58 59 60 61 62 63 |
# File 'lib/soaspec/spec_logger.rb', line 54 def create create_log_file @logger = Logger.new(traffic_file) # Where request and responses of APIs are stored @logger.formatter = proc do |severity, datetime, _progname, msg| = "SpecLog, [#{datetime.strftime('%Y-%m-%d_%H:%M:%S')}] #{severity} -- : #{msg}\n" print .colorize(:light_blue) if @output_to_terminal end @logger end |
.info(message) ⇒ Object
Log a message using Soaspec logger
67 68 69 70 71 72 73 74 75 76 77 |
# File 'lib/soaspec/spec_logger.rb', line 67 def info() return unless log_api_traffic? if .respond_to? :each .each do || @logger.info() end else @logger.info() end end |
.log_api_traffic=(set) ⇒ Object
Whether to log all API traffic
24 25 26 27 |
# File 'lib/soaspec/spec_logger.rb', line 24 def log_api_traffic=(set) @log_api_traffic = set RestClient.log = nil unless set end |
.log_api_traffic? ⇒ Boolean
30 31 32 |
# File 'lib/soaspec/spec_logger.rb', line 30 def log_api_traffic? @log_api_traffic.nil? ? true : @log_api_traffic end |
.traffic_file ⇒ String
47 48 49 50 |
# File 'lib/soaspec/spec_logger.rb', line 47 def traffic_file filename = "traffic_#{time_test_run}.log" File.join(traffic_folder, filename) end |