discourse/spec/components/discourse_spec.rb

230 lines
6.7 KiB
Ruby
Raw Normal View History

require 'rails_helper'
2013-02-06 03:16:51 +08:00
require 'discourse'
describe Discourse do
before do
RailsMultisite::ConnectionManagement.stubs(:current_hostname).returns('foo.com')
end
context 'current_hostname' do
it 'returns the hostname from the current db connection' do
2015-01-10 00:34:37 +08:00
expect(Discourse.current_hostname).to eq('foo.com')
2013-02-06 03:16:51 +08:00
end
end
context 'running_in_rack' do
after do
ENV.delete("DISCOURSE_RUNNING_IN_RACK")
end
it 'should not be running in rack' do
expect(Discourse.running_in_rack?).to eq(false)
ENV["DISCOURSE_RUNNING_IN_RACK"] = "1"
expect(Discourse.running_in_rack?).to eq(true)
end
end
2013-02-06 03:16:51 +08:00
context 'base_url' do
context 'when https is off' do
2013-02-06 03:16:51 +08:00
before do
SiteSetting.force_https = false
2013-02-06 03:16:51 +08:00
end
it 'has a non https base url' do
2015-01-10 00:34:37 +08:00
expect(Discourse.base_url).to eq("http://foo.com")
2013-02-06 03:16:51 +08:00
end
end
context 'when https is on' do
2013-02-06 03:16:51 +08:00
before do
SiteSetting.force_https = true
2013-02-06 03:16:51 +08:00
end
it 'has a non-ssl base url' do
2015-01-10 00:34:37 +08:00
expect(Discourse.base_url).to eq("https://foo.com")
2013-02-06 03:16:51 +08:00
end
end
context 'with a non standard port specified' do
before do
SiteSetting.port = 3000
2013-02-06 03:16:51 +08:00
end
it "returns the non standart port in the base url" do
2015-01-10 00:34:37 +08:00
expect(Discourse.base_url).to eq("http://foo.com:3000")
2013-02-06 03:16:51 +08:00
end
end
end
context '#site_contact_user' do
let!(:admin) { Fabricate(:admin) }
let!(:another_admin) { Fabricate(:admin) }
it 'returns the user specified by the site setting site_contact_username' do
SiteSetting.site_contact_username = another_admin.username
2015-01-10 00:34:37 +08:00
expect(Discourse.site_contact_user).to eq(another_admin)
end
it 'returns the system user otherwise' do
SiteSetting.site_contact_username = nil
expect(Discourse.site_contact_user.username).to eq("system")
end
2013-02-26 00:42:20 +08:00
2013-02-06 03:16:51 +08:00
end
context "#store" do
it "returns LocalStore by default" do
2015-01-10 00:34:37 +08:00
expect(Discourse.store).to be_a(FileStore::LocalStore)
end
it "returns S3Store when S3 is enabled" do
SiteSetting.enable_s3_uploads = true
SiteSetting.s3_upload_bucket = "s3bucket"
SiteSetting.s3_access_key_id = "s3_access_key_id"
SiteSetting.s3_secret_access_key = "s3_secret_access_key"
2015-01-10 00:34:37 +08:00
expect(Discourse.store).to be_a(FileStore::S3Store)
end
end
context 'readonly mode' do
let(:readonly_mode_key) { Discourse::READONLY_MODE_KEY }
let(:readonly_mode_ttl) { Discourse::READONLY_MODE_KEY_TTL }
let(:user_readonly_mode_key) { Discourse::USER_READONLY_MODE_KEY }
2014-02-13 12:37:28 +08:00
after do
$redis.del(readonly_mode_key)
$redis.del(user_readonly_mode_key)
2014-02-13 12:37:28 +08:00
end
def assert_readonly_mode(message, key, ttl = -1)
expect(message.channel).to eq(Discourse.readonly_channel)
expect(message.data).to eq(true)
expect($redis.get(key)).to eq("1")
expect($redis.ttl(key)).to eq(ttl)
end
2014-02-13 12:37:28 +08:00
def assert_readonly_mode_disabled(message, key)
expect(message.channel).to eq(Discourse.readonly_channel)
expect(message.data).to eq(false)
expect($redis.get(key)).to eq(nil)
end
2014-02-13 12:37:28 +08:00
2017-07-27 01:21:33 +08:00
def get_readonly_message
messages = MessageBus.track_publish do
yield
end
2017-08-21 21:28:43 +08:00
messages.find { |m| m.channel == Discourse.readonly_channel }
2017-07-27 01:21:33 +08:00
end
describe ".enable_readonly_mode" do
it "adds a key in redis and publish a message through the message bus" do
expect($redis.get(readonly_mode_key)).to eq(nil)
2017-07-27 01:21:33 +08:00
message = get_readonly_message { Discourse.enable_readonly_mode }
assert_readonly_mode(message, readonly_mode_key, readonly_mode_ttl)
end
2014-02-13 12:37:28 +08:00
context 'user enabled readonly mode' do
it "adds a key in redis and publish a message through the message bus" do
expect($redis.get(user_readonly_mode_key)).to eq(nil)
2017-07-27 01:21:33 +08:00
message = get_readonly_message { Discourse.enable_readonly_mode(user_readonly_mode_key) }
assert_readonly_mode(message, user_readonly_mode_key)
end
end
2014-02-13 12:37:28 +08:00
end
describe ".disable_readonly_mode" do
it "removes a key from redis and publish a message through the message bus" do
Discourse.enable_readonly_mode
2017-07-27 01:21:33 +08:00
message = get_readonly_message do
Discourse.disable_readonly_mode
2017-07-27 01:21:33 +08:00
end
2014-02-13 12:37:28 +08:00
assert_readonly_mode_disabled(message, readonly_mode_key)
end
2014-02-13 12:37:28 +08:00
context 'user disabled readonly mode' do
it "removes readonly key in redis and publish a message through the message bus" do
Discourse.enable_readonly_mode(user_enabled: true)
2017-07-27 01:21:33 +08:00
message = get_readonly_message { Discourse.disable_readonly_mode(user_enabled: true) }
assert_readonly_mode_disabled(message, user_readonly_mode_key)
end
end
end
describe ".readonly_mode?" do
it "is false by default" do
expect(Discourse.readonly_mode?).to eq(false)
end
it "returns true when the key is present in redis" do
$redis.set(readonly_mode_key, 1)
expect(Discourse.readonly_mode?).to eq(true)
end
2014-02-13 12:37:28 +08:00
it "returns true when Discourse is recently read only" do
Discourse.received_readonly!
expect(Discourse.readonly_mode?).to eq(true)
end
it "returns true when user enabled readonly mode key is present in redis" do
Discourse.enable_readonly_mode(user_readonly_mode_key)
expect(Discourse.readonly_mode?).to eq(true)
expect(Discourse.readonly_mode?(readonly_mode_key)).to eq(false)
Discourse.disable_readonly_mode(user_readonly_mode_key)
expect(Discourse.readonly_mode?).to eq(false)
end
2014-02-13 12:37:28 +08:00
end
describe ".received_readonly!" do
it "sets the right time" do
time = Discourse.received_readonly!
expect(Discourse.last_read_only['default']).to eq(time)
end
end
end
context "#handle_exception" do
class TempSidekiqLogger < Sidekiq::ExceptionHandler::Logger
attr_accessor :exception, :context
def call(ex, ctx)
self.exception = ex
self.context = ctx
end
end
let!(:logger) { TempSidekiqLogger.new }
before do
Sidekiq.error_handlers.clear
Sidekiq.error_handlers << logger
end
it "should not fail when called" do
exception = StandardError.new
Discourse.handle_job_exception(exception, nil, nil)
2015-01-10 00:34:37 +08:00
expect(logger.exception).to eq(exception)
expect(logger.context.keys).to eq([:current_db, :current_hostname])
end
it "correctly passes extra context" do
exception = StandardError.new
2017-07-28 09:20:09 +08:00
Discourse.handle_job_exception(exception, { message: "Doing a test", post_id: 31 }, nil)
2015-01-10 00:34:37 +08:00
expect(logger.exception).to eq(exception)
expect(logger.context.keys.sort).to eq([:current_db, :current_hostname, :message, :post_id].sort)
end
end
2013-02-06 03:16:51 +08:00
end