Commit 220e0f01 authored by Alex Kalderimis's avatar Alex Kalderimis

Nil safety for Json.parse

Includes a more helpful error message if data is nil in the performance
bar.
parent 8ec7a386
...@@ -16,6 +16,9 @@ module Gitlab ...@@ -16,6 +16,9 @@ module Gitlab
# @return [Boolean, String, Array, Hash] # @return [Boolean, String, Array, Hash]
# @raise [JSON::ParserError] raised if parsing fails # @raise [JSON::ParserError] raised if parsing fails
def parse(string, opts = {}) def parse(string, opts = {})
# Parse nil as nil
return if string.nil?
# First we should ensure this really is a string, not some other # First we should ensure this really is a string, not some other
# type which purports to be a string. This handles some legacy # type which purports to be a string. This handles some legacy
# usage of the JSON class. # usage of the JSON class.
......
...@@ -25,8 +25,8 @@ module Gitlab ...@@ -25,8 +25,8 @@ module Gitlab
log_queries(id, data, 'active-record') log_queries(id, data, 'active-record')
log_queries(id, data, 'gitaly') log_queries(id, data, 'gitaly')
log_queries(id, data, 'redis') log_queries(id, data, 'redis')
rescue StandardError => err rescue StandardError => e
logger.error(message: "failed to process request id #{id}: #{err.message}") logger.error(message: "failed to process request id #{id}: #{e.message}")
end end
private private
...@@ -34,6 +34,8 @@ module Gitlab ...@@ -34,6 +34,8 @@ module Gitlab
def request(id) def request(id)
# Peek gem stores request data under peek:requests:request_id key # Peek gem stores request data under peek:requests:request_id key
json_data = @redis.get("peek:requests:#{id}") json_data = @redis.get("peek:requests:#{id}")
raise "No data for #{id}" if json_data.nil?
Gitlab::Json.parse(json_data) Gitlab::Json.parse(json_data)
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment