Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 8 additions & 8 deletions lib/raven/context.rb
Original file line number Diff line number Diff line change
Expand Up @@ -13,28 +13,28 @@ def self.clear!
attr_accessor :extra, :server_os, :rack_env, :runtime, :tags, :user

def initialize
self.extra = {}
self.server_os = self.class.os_context
self.rack_env = nil
self.runtime = self.class.runtime_context
self.extra = { :server => { :os => server_os, :runtime => runtime } }
self.rack_env = nil
self.tags = {}
self.user = {}
end

class << self
def os_context
@os_context ||= {
"name" => Raven.sys_command("uname -s") || RbConfig::CONFIG["host_os"],
"version" => Raven.sys_command("uname -v"),
"build" => Raven.sys_command("uname -r"),
"kernel_version" => Raven.sys_command("uname -a") || Raven.sys_command("ver") # windows
:name => Raven.sys_command("uname -s") || RbConfig::CONFIG["host_os"],
:version => Raven.sys_command("uname -v"),
:build => Raven.sys_command("uname -r"),
:kernel_version => Raven.sys_command("uname -a") || Raven.sys_command("ver") # windows
}
end

def runtime_context
@runtime_context ||= {
"name" => RbConfig::CONFIG["ruby_install_name"],
"version" => Raven.sys_command("ruby -v")
:name => RbConfig::CONFIG["ruby_install_name"],
:version => Raven.sys_command("ruby -v")
}
end
end
Expand Down
8 changes: 1 addition & 7 deletions lib/raven/event.rb
Original file line number Diff line number Diff line change
Expand Up @@ -68,8 +68,6 @@ def initialize(init = {})
@user = @context.user.merge(@user) # TODO: contexts
@extra = @context.extra.merge(@extra) # TODO: contexts
@tags = @configuration.tags.merge(@context.tags).merge(@tags) # TODO: contexts
@server_os = @context.server_os # TODO: contexts
@runtime = @context.runtime # TODO: contexts

# Some type coercion
@timestamp = @timestamp.strftime('%Y-%m-%dT%H:%M:%S') if @timestamp.is_a?(Time)
Expand Down Expand Up @@ -248,11 +246,7 @@ def to_hash
:time_spent => @time_spent,
:level => @level,
:platform => PLATFORM,
:sdk => SDK,
:contexts => {
:server_os => @server_os,
:runtime => @runtime
}
:sdk => SDK
}

data[:logger] = @logger if @logger
Expand Down
22 changes: 11 additions & 11 deletions spec/raven/event_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@
end

it 'has extra data' do
expect(hash[:extra]).to eq('my_custom_variable' => 'value')
expect(hash[:extra]["my_custom_variable"]).to eq('value')
end

it 'has platform' do
Expand All @@ -63,11 +63,11 @@
end

it 'has server os' do
expect(hash[:contexts][:server_os].keys).to eq(%w(name version build kernel_version))
expect(hash[:extra][:server][:os].keys).to eq([:name, :version, :build, :kernel_version])
end

it 'has runtime' do
expect(hash[:contexts][:runtime]["version"]).to match(/ruby/)
expect(hash[:extra][:server][:runtime][:version]).to match(/ruby/)
end
end

Expand Down Expand Up @@ -128,8 +128,8 @@
end

it "merges extra data" do
expect(hash[:extra]).to eq('key' => 'value',
'my_custom_variable' => 'value')
expect(hash[:extra]['key']).to eq('value')
expect(hash[:extra]['my_custom_variable']).to eq('value')
end
end

Expand Down Expand Up @@ -309,9 +309,9 @@
end

it 'prioritizes event context over request context' do
expect(hash[:extra]).to eq('context_event_key' => 'event_value',
'context_key' => 'context_value',
'event_key' => 'event_value')
expect(hash[:extra]['context_event_key']).to eq('event_value')
expect(hash[:extra]['context_key']).to eq('context_value')
expect(hash[:extra]['event_key']).to eq('event_value')
end
end

Expand All @@ -333,9 +333,9 @@ def raven_context
end

it 'prioritizes event context over request context' do
expect(hash[:extra]).to eq('context_event_key' => 'event_value',
'context_key' => 'context_value',
'event_key' => 'event_value')
expect(hash[:extra]['context_event_key']).to eq('event_value')
expect(hash[:extra]['context_key']).to eq('context_value')
expect(hash[:extra]['event_key']).to eq('event_value')
end
end

Expand Down