2013-03-19 23:18:00 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe AdminDashboardData do
|
|
|
|
|
|
|
|
describe "rails_env_check" do
|
|
|
|
subject { AdminDashboardData.new.rails_env_check }
|
|
|
|
|
|
|
|
it 'returns nil when running in production mode' do
|
|
|
|
Rails.stubs(:env).returns('production')
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when running in development mode' do
|
|
|
|
Rails.stubs(:env).returns('development')
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when running in test mode' do
|
|
|
|
Rails.stubs(:env).returns('test')
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-20 15:38:28 -04:00
|
|
|
describe 'host_names_check' do
|
|
|
|
subject { AdminDashboardData.new.host_names_check }
|
|
|
|
|
|
|
|
it 'returns nil when host_names is set' do
|
|
|
|
Discourse.stubs(:current_hostname).returns('something.com')
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when host_name is localhost' do
|
|
|
|
Discourse.stubs(:current_hostname).returns('localhost')
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when host_name is production.localhost' do
|
|
|
|
Discourse.stubs(:current_hostname).returns('production.localhost')
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-20 16:16:23 -04:00
|
|
|
describe 'gc_checks' do
|
|
|
|
subject { AdminDashboardData.new.gc_checks }
|
|
|
|
|
|
|
|
it 'returns nil when gc params are set' do
|
|
|
|
ENV.stubs(:[]).with('RUBY_GC_MALLOC_LIMIT').returns(90000000)
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when gc params are not set' do
|
|
|
|
ENV.stubs(:[]).with('RUBY_GC_MALLOC_LIMIT').returns(nil)
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-21 16:51:19 -04:00
|
|
|
describe 'clockwork_check' do
|
|
|
|
subject { AdminDashboardData.new.clockwork_check }
|
|
|
|
|
|
|
|
it 'returns nil when clockwork is running' do
|
|
|
|
Jobs::ClockworkHeartbeat.stubs(:is_clockwork_running?).returns(true)
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when clockwork is not running' do
|
|
|
|
Jobs::ClockworkHeartbeat.stubs(:is_clockwork_running?).returns(false)
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-22 11:35:32 -04:00
|
|
|
describe 'sidekiq_check' do
|
|
|
|
subject { AdminDashboardData.new.sidekiq_check }
|
|
|
|
|
|
|
|
it 'returns nil when sidekiq processed a job recently' do
|
|
|
|
Jobs.stubs(:last_job_performed_at).returns(1.minute.ago)
|
|
|
|
Jobs.stubs(:queued).returns(0)
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns nil when last job processed was a long time ago, but no jobs are queued' do
|
|
|
|
Jobs.stubs(:last_job_performed_at).returns(7.days.ago)
|
|
|
|
Jobs.stubs(:queued).returns(0)
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns nil when no jobs have ever been processed, but no jobs are queued' do
|
|
|
|
Jobs.stubs(:last_job_performed_at).returns(nil)
|
|
|
|
Jobs.stubs(:queued).returns(0)
|
|
|
|
subject.should be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when no jobs were processed recently and some jobs are queued' do
|
|
|
|
Jobs.stubs(:last_job_performed_at).returns(20.minutes.ago)
|
|
|
|
Jobs.stubs(:queued).returns(1)
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a string when no jobs have ever been processed, and some jobs are queued' do
|
|
|
|
Jobs.stubs(:last_job_performed_at).returns(nil)
|
|
|
|
Jobs.stubs(:queued).returns(1)
|
|
|
|
subject.should_not be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-19 23:18:00 -04:00
|
|
|
end
|