Class: Maze::MazeOutput
- Inherits:
-
Object
- Object
- Maze::MazeOutput
- Defined in:
- lib/maze/maze_output.rb
Overview
Responsible for writing files to the maze_output directory
Instance Method Summary collapse
-
#initialize(scenario) ⇒ MazeOutput
constructor
A new instance of MazeOutput.
-
#write_device_logs(logs) ⇒ Object
Pulls the logs from the device if the scenario fails.
-
#write_requests ⇒ Object
Writes each list of requests to a separate file under, e.g: maze_output/failed/scenario_name/errors.log.
Constructor Details
#initialize(scenario) ⇒ MazeOutput
Returns a new instance of MazeOutput.
6 7 8 |
# File 'lib/maze/maze_output.rb', line 6 def initialize(scenario) @scenario = scenario end |
Instance Method Details
#write_device_logs(logs) ⇒ Object
Pulls the logs from the device if the scenario fails
66 67 68 69 70 71 72 73 74 75 |
# File 'lib/maze/maze_output.rb', line 66 def write_device_logs(logs) dir = output_folder FileUtils.makedirs(dir) filepath = File.join(dir, 'device.log') File.open(filepath, 'w+') do |file| logs.each { |line| file.puts line } end end |
#write_requests ⇒ Object
Writes each list of requests to a separate file under, e.g: maze_output/failed/scenario_name/errors.log
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
# File 'lib/maze/maze_output.rb', line 12 def write_requests path = output_folder FileUtils.makedirs(path) request_types = %w[errors sessions builds uploads logs sourcemaps traces invalid] request_types.each do |request_type| list = Maze::Server.list_for(request_type).all next if list.empty? filename = "#{request_type}.log" filepath = File.join(path, filename) counter = 1 File.open(filepath, 'w+') do |file| list.each do |request| file.puts "=== Request #{counter} of #{list.size} ===" if request[:invalid] invalid_request = true uri = request[:request][:request_uri] headers = request[:request][:header] body = request[:request][:body] else invalid_request = false uri = request[:request].request_uri headers = request[:request].header body = request[:body] end file.puts "URI: #{uri}" file.puts "HEADERS:" headers.each do |key, values| file.puts " #{key}: #{values.map {|v| "'#{v}'"}.join(' ')}" end file.puts file.puts "BODY:" if !invalid_request && headers["content-type"].first == 'application/json' file.puts JSON.pretty_generate(body) else file.puts body end file.puts if request.include?(:reason) file.puts "REASON:" file.puts request[:reason] file.puts end counter += 1 end end end end |