Skip to content

Commit

Permalink
performance_notifier: drop support for :{start,end}_time params
Browse files Browse the repository at this point in the history
Fixes #601
  • Loading branch information
kyrylo committed Aug 12, 2020
1 parent 71242c1 commit 2bf5c90
Show file tree
Hide file tree
Showing 13 changed files with 12 additions and 142 deletions.
8 changes: 3 additions & 5 deletions benchmarks/performance.rb
Original file line number Diff line number Diff line change
Expand Up @@ -15,24 +15,22 @@
func: 'foo',
file: 'foo.rb',
line: 123,
start_time: Time.new - 200,
end_time: Time.new,
timing: 200,
}

request = {
method: 'GET',
route: '/things/1',
status_code: 200,
start_time: Time.new - 200,
end_time: Time.new,
timing: 200,
}

breakdown = {
method: 'GET',
route: '/things/1',
response_type: 'json',
groups: { db: 24.0, view: 0.4 },
start_time: Time.new,
timing: 200,
}

Benchmark.ips do |ips|
Expand Down
7 changes: 1 addition & 6 deletions lib/airbrake-ruby/performance_breakdown.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,13 @@ class PerformanceBreakdown
include Stashable
include Mergeable

attr_accessor :method, :route, :response_type, :groups, :start_time,
:end_time, :timing, :time
attr_accessor :method, :route, :response_type, :groups, :timing, :time

def initialize(
method:,
route:,
response_type:,
groups:,
start_time: Time.now,
end_time: start_time + 1,
timing: nil,
time: Time.now
)
Expand All @@ -30,8 +27,6 @@ def initialize(
@route = route
@response_type = response_type
@groups = groups
@start_time = start_time
@end_time = end_time
@timing = timing
@time = time
end
Expand Down
15 changes: 1 addition & 14 deletions lib/airbrake-ruby/performance_notifier.rb
Original file line number Diff line number Diff line change
Expand Up @@ -104,27 +104,14 @@ def update_payload(resource)
@payload[resource] = { total: Airbrake::Stat.new }
end

update_total(resource, @payload[resource][:total])
@payload[resource][:total].increment_ms(resource.timing)

resource.groups.each do |name, ms|
@payload[resource][name] ||= Airbrake::Stat.new
@payload[resource][name].increment_ms(ms)
end
end

def update_total(resource, total)
if resource.timing
total.increment_ms(resource.timing)
else
loc = caller_locations(6..6).first
Kernel.warn(
"#{loc.path}:#{loc.lineno}: warning: :start_time and :end_time are " \
"deprecated. Use :timing & :time instead",
)
total.increment(resource.start_time, resource.end_time)
end
end

def check_configuration(resource)
promise = @config.check_configuration
return promise if promise.rejected?
Expand Down
7 changes: 1 addition & 6 deletions lib/airbrake-ruby/query.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,7 @@ class Query
include Mergeable
include Grouppable

attr_accessor :method, :route, :query, :func, :file, :line, :start_time,
:end_time, :timing, :time
attr_accessor :method, :route, :query, :func, :file, :line, :timing, :time

def initialize(
method:,
Expand All @@ -22,8 +21,6 @@ def initialize(
func: nil,
file: nil,
line: nil,
start_time: Time.now,
end_time: start_time + 1,
timing: nil,
time: Time.now
)
Expand All @@ -34,8 +31,6 @@ def initialize(
@func = func
@file = file
@line = line
@start_time = start_time
@end_time = end_time
@timing = timing
@time = time
end
Expand Down
9 changes: 1 addition & 8 deletions lib/airbrake-ruby/queue.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,30 +4,24 @@ module Airbrake
# @see Airbrake.notify_queue
# @api public
# @since v4.9.0
# rubocop:disable Metrics/ParameterLists
class Queue
include HashKeyable
include Ignorable
include Stashable

attr_accessor :queue, :error_count, :groups, :start_time, :end_time,
:timing, :time
attr_accessor :queue, :error_count, :groups, :timing, :time

def initialize(
queue:,
error_count:,
groups: {},
start_time: Time.now,
end_time: start_time + 1,
timing: nil,
time: Time.now
)
@time_utc = TimeTruncate.utc_truncate_minutes(time)
@queue = queue
@error_count = error_count
@groups = groups
@start_time = start_time
@end_time = end_time
@timing = timing
@time = time
end
Expand Down Expand Up @@ -68,5 +62,4 @@ def route
''
end
end
# rubocop:enable Metrics/ParameterLists
end
9 changes: 1 addition & 8 deletions lib/airbrake-ruby/request.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,32 +4,26 @@ module Airbrake
# @see Airbrake.notify_request
# @api public
# @since v3.2.0
# rubocop:disable Metrics/ParameterLists
class Request
include HashKeyable
include Ignorable
include Stashable
include Mergeable
include Grouppable

attr_accessor :method, :route, :status_code, :start_time, :end_time,
:timing, :time
attr_accessor :method, :route, :status_code, :timing, :time

def initialize(
method:,
route:,
status_code:,
start_time: Time.now,
end_time: start_time + 1,
timing: nil,
time: Time.now
)
@time_utc = TimeTruncate.utc_truncate_minutes(time)
@method = method
@route = route
@status_code = status_code
@start_time = start_time
@end_time = end_time
@timing = timing
@time = time
end
Expand All @@ -51,5 +45,4 @@ def to_h
}.delete_if { |_key, val| val.nil? }
end
end
# rubocop:enable Metrics/ParameterLists
end
13 changes: 1 addition & 12 deletions lib/airbrake-ruby/stat.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ module Airbrake
#
# @example
# stat = Airbrake::Stat.new
# stat.increment(Time.now - 200)
# stat.increment_ms(2000)
# stat.to_h # Pack and serialize data so it can be transmitted.
#
# @since v3.2.0
Expand Down Expand Up @@ -41,17 +41,6 @@ def to_h
end
end

# Increments tdigest timings and updates tdigest with the difference between
# +end_time+ and +start_time+.
#
# @param [Date] start_time
# @param [Date] end_time
# @return [void]
def increment(start_time, end_time = nil)
end_time ||= Time.new
increment_ms((end_time - start_time) * 1000)
end

# Increments tdigest timings and updates tdigest with given +ms+ value.
#
# @param [Float] ms
Expand Down
12 changes: 0 additions & 12 deletions spec/performance_breakdown_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,21 +3,9 @@
subject do
described_class.new(
method: 'GET', route: '/', response_type: '', groups: {},
start_time: Time.now
)
end

it { is_expected.to respond_to(:stash) }
end

describe "#end_time" do
it "is always equal to start_time + 1 second by default" do
time = Time.now
performance_breakdown = described_class.new(
method: 'GET', route: '/', response_type: '', groups: {},
start_time: time
)
expect(performance_breakdown.end_time).to eq(time + 1)
end
end
end
25 changes: 0 additions & 25 deletions spec/performance_notifier_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -541,31 +541,6 @@
end
end

context "when :start_time is specified (deprecated)" do
before do
allow(Kernel).to receive(:warn)
end

it "uses the value of :start_time to update stat" do
subject.notify(
Airbrake::Query.new(
method: 'POST',
route: '/foo',
query: 'SELECT * FROM things',
start_time: Time.new(2018, 1, 1, 0, 49, 0, 0),
end_time: Time.new(2018, 1, 1, 0, 50, 0, 0),
),
)
subject.close

expect(
a_request(:put, queries).with(
body: /"count":1,"sum":60000.0,"sumsq":3600000000.0/,
),
).to have_been_made
end
end

context "when provided :timing is zero" do
it "doesn't notify" do
queue = Airbrake::Queue.new(queue: 'bananas', error_count: 0, timing: 0)
Expand Down
12 changes: 1 addition & 11 deletions spec/query_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,10 @@
describe "#stash" do
subject do
described_class.new(
method: 'GET', route: '/', query: '', start_time: Time.now,
method: 'GET', route: '/', query: '',
)
end

it { is_expected.to respond_to(:stash) }
end

describe "#end_time" do
it "is always equal to start_time + 1 second by default" do
time = Time.now
query = described_class.new(
method: 'GET', route: '/', query: '', start_time: time,
)
expect(query.end_time).to eq(time + 1)
end
end
end
14 changes: 1 addition & 13 deletions spec/queue_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -9,21 +9,9 @@
it { is_expected.to respond_to(:stash) }
end

describe "#end_time" do
it "is always equal to start_time + 1 second by default" do
time = Time.now
queue = described_class.new(
queue: 'bananas', error_count: 0, start_time: time,
)
expect(queue.end_time).to eq(time + 1)
end
end

describe "#route" do
it "always returns an empty route" do
queue = described_class.new(
queue: 'a', error_count: 0, start_time: Time.now,
)
queue = described_class.new(queue: 'a', error_count: 0)
expect(queue.route).to be_empty
end
end
Expand Down
14 changes: 1 addition & 13 deletions spec/request_spec.rb
Original file line number Diff line number Diff line change
@@ -1,21 +1,9 @@
RSpec.describe Airbrake::Request do
describe "#stash" do
subject do
described_class.new(
method: 'GET', route: '/', status_code: 200, start_time: Time.now,
)
described_class.new(method: 'GET', route: '/', status_code: 200)
end

it { is_expected.to respond_to(:stash) }
end

describe "#end_time" do
it "is always equal to start_time + 1 second by default" do
time = Time.now
request = described_class.new(
method: 'GET', route: '/', status_code: 200, start_time: time,
)
expect(request.end_time).to eq(time + 1)
end
end
end
9 changes: 0 additions & 9 deletions spec/stat_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -10,15 +10,6 @@
end
end

describe "#increment" do
let(:start_time) { Time.new(2018, 1, 1, 0, 0, 20, 0) }
let(:end_time) { Time.new(2018, 1, 1, 0, 0, 22, 0) }

before { subject.increment(start_time, end_time) }

its(:sum) { is_expected.to eq(2000) }
end

describe "#increment_ms" do
before { subject.increment_ms(1000) }

Expand Down

0 comments on commit 2bf5c90

Please sign in to comment.