mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 05:12:46 +08:00
820ce8765e
split traffic report in 2, page view vs raw traffic hide raw traffic report by default improve flushing logic for application reqs
77 lines
1.7 KiB
Ruby
77 lines
1.7 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe ApplicationRequest do
|
|
|
|
before do
|
|
ApplicationRequest.clear_cache!
|
|
end
|
|
|
|
def inc(key,opts=nil)
|
|
ApplicationRequest.increment!(key,opts)
|
|
end
|
|
|
|
it 'logs nothing for an unflushed increment' do
|
|
ApplicationRequest.increment!(:anon)
|
|
ApplicationRequest.count.should == 0
|
|
end
|
|
|
|
it 'can automatically flush' do
|
|
t1 = Time.now.utc.at_midnight
|
|
freeze_time(t1)
|
|
inc(:http_total)
|
|
inc(:http_total)
|
|
inc(:http_total, autoflush: 3)
|
|
|
|
ApplicationRequest.http_total.first.count.should == 3
|
|
end
|
|
|
|
it 'can flush based on time' do
|
|
t1 = Time.now.utc.at_midnight
|
|
freeze_time(t1)
|
|
ApplicationRequest.write_cache!
|
|
inc(:http_total)
|
|
ApplicationRequest.count.should == 0
|
|
|
|
freeze_time(t1 + ApplicationRequest.autoflush_seconds + 1)
|
|
inc(:http_total)
|
|
|
|
ApplicationRequest.count.should == 1
|
|
end
|
|
|
|
it 'flushes yesterdays results' do
|
|
t1 = Time.now.utc.at_midnight
|
|
freeze_time(t1)
|
|
inc(:http_total)
|
|
freeze_time(t1.tomorrow)
|
|
inc(:http_total)
|
|
|
|
ApplicationRequest.write_cache!
|
|
ApplicationRequest.count.should == 2
|
|
end
|
|
|
|
it 'clears cache correctly' do
|
|
# otherwise we have test pollution
|
|
inc(:anon)
|
|
ApplicationRequest.clear_cache!
|
|
ApplicationRequest.write_cache!
|
|
|
|
ApplicationRequest.count.should == 0
|
|
end
|
|
|
|
it 'logs a few counts once flushed' do
|
|
time = Time.now.at_midnight
|
|
freeze_time(time)
|
|
|
|
3.times { inc(:http_total) }
|
|
2.times { inc(:http_2xx) }
|
|
4.times { inc(:http_3xx) }
|
|
|
|
ApplicationRequest.write_cache!
|
|
|
|
ApplicationRequest.http_total.first.count.should == 3
|
|
ApplicationRequest.http_2xx.first.count.should == 2
|
|
ApplicationRequest.http_3xx.first.count.should == 4
|
|
|
|
end
|
|
end
|