discourse/spec/models/site_setting_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

216 lines
6.2 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
RSpec.describe SiteSetting do
describe 'topic_title_length' do
it 'returns a range of min/max topic title length' do
2015-01-05 11:04:23 -05:00
expect(SiteSetting.topic_title_length).to eq(
(SiteSetting.defaults[:min_topic_title_length]..SiteSetting.defaults[:max_topic_title_length])
2015-01-05 11:04:23 -05:00
)
end
end
describe 'post_length' do
it 'returns a range of min/max post length' do
2015-01-05 11:04:23 -05:00
expect(SiteSetting.post_length).to eq(SiteSetting.defaults[:min_post_length]..SiteSetting.defaults[:max_post_length])
end
end
describe 'first_post_length' do
it 'returns a range of min/max first post length' do
expect(SiteSetting.first_post_length).to eq(SiteSetting.defaults[:min_first_post_length]..SiteSetting.defaults[:max_post_length])
end
end
describe 'private_message_title_length' do
it 'returns a range of min/max pm topic title length' do
expect(SiteSetting.private_message_title_length).to eq(SiteSetting.defaults[:min_personal_message_title_length]..SiteSetting.defaults[:max_topic_title_length])
end
end
describe 'in test we do some judo to ensure SiteSetting is always reset between tests' do
it 'is always the correct default' do
expect(SiteSetting.contact_email).to eq('')
end
it 'sets a setting' do
SiteSetting.contact_email = 'sam@sam.com'
end
it 'is always the correct default' do
expect(SiteSetting.contact_email).to eq('')
end
end
describe "anonymous_homepage" do
it "returns latest" do
expect(SiteSetting.anonymous_homepage).to eq('latest')
end
end
describe "top_menu" do
describe "validations" do
it "always demands latest" do
expect do
SiteSetting.top_menu = 'categories'
end.to raise_error(Discourse::InvalidParameters)
end
it "does not allow random text" do
expect do
SiteSetting.top_menu = 'latest|random'
end.to raise_error(Discourse::InvalidParameters)
end
end
describe "items" do
let(:items) { SiteSetting.top_menu_items }
it 'returns TopMenuItem objects' do
expect(items[0]).to be_kind_of(TopMenuItem)
end
end
describe "homepage" do
it "has homepage" do
SiteSetting.top_menu = "bookmarks|latest"
expect(SiteSetting.homepage).to eq('bookmarks')
end
end
end
describe "min_redirected_to_top_period" do
context "when has_enough_top_topics" do
before do
SiteSetting.topics_per_period_in_top_page = 2
SiteSetting.top_page_default_timeframe = 'daily'
2.times do
TopTopic.create!(daily_score: 2.5)
end
TopTopic.refresh!
end
it "should_return_a_time_period" do
expect(SiteSetting.min_redirected_to_top_period(1.days.ago)).to eq(:daily)
end
end
context "when does_not_have_enough_top_topics" do
before do
SiteSetting.topics_per_period_in_top_page = 20
SiteSetting.top_page_default_timeframe = 'daily'
TopTopic.refresh!
end
it "should_return_a_time_period" do
expect(SiteSetting.min_redirected_to_top_period(1.days.ago)).to eq(nil)
end
end
end
describe "scheme" do
before do
SiteSetting.force_https = true
end
it "returns http when ssl is disabled" do
SiteSetting.force_https = false
2015-01-05 11:04:23 -05:00
expect(SiteSetting.scheme).to eq("http")
end
it "returns https when using ssl" do
2015-01-05 11:04:23 -05:00
expect(SiteSetting.scheme).to eq("https")
end
end
describe ".shared_drafts_enabled?" do
it "returns false by default" do
expect(SiteSetting.shared_drafts_enabled?).to eq(false)
end
it "returns false when the category is uncategorized" do
SiteSetting.shared_drafts_category = SiteSetting.uncategorized_category_id
expect(SiteSetting.shared_drafts_enabled?).to eq(false)
end
it "returns true when the category is valid" do
SiteSetting.shared_drafts_category = Fabricate(:category).id
expect(SiteSetting.shared_drafts_enabled?).to eq(true)
end
end
describe 'deprecated site settings' do
2018-11-07 02:02:53 -05:00
before do
SiteSetting.force_https = true
@orig_logger = Rails.logger
Rails.logger = @fake_logger = FakeLogger.new
end
after do
Rails.logger = @orig_logger
2018-11-07 02:02:53 -05:00
end
2018-11-07 02:02:53 -05:00
it 'should act as a proxy to the new methods' do
begin
original_settings = SiteSettings::DeprecatedSettings::SETTINGS.dup
SiteSettings::DeprecatedSettings::SETTINGS.clear
2018-11-14 05:07:04 -05:00
SiteSettings::DeprecatedSettings::SETTINGS.push([
2018-11-14 05:07:04 -05:00
'use_https', 'force_https', true, '0.0.1'
])
2018-11-07 02:02:53 -05:00
SiteSetting.setup_deprecated_methods
2018-01-31 13:30:14 -05:00
expect do
expect(SiteSetting.use_https).to eq(true)
expect(SiteSetting.use_https?).to eq(true)
end.to change { @fake_logger.warnings.count }.by(2)
expect do
SiteSetting.use_https(warn: false)
end.to_not change { @fake_logger.warnings }
SiteSetting.use_https = false
expect(SiteSetting.force_https).to eq(false)
expect(SiteSetting.force_https?).to eq(false)
2018-11-07 02:02:53 -05:00
ensure
SiteSettings::DeprecatedSettings::SETTINGS.clear
2018-11-14 05:07:04 -05:00
SiteSettings::DeprecatedSettings::SETTINGS.concat(
2018-11-14 05:07:04 -05:00
original_settings
)
2018-01-31 13:30:14 -05:00
end
end
end
describe 'cached settings' do
it 'should recalculate cached setting when dependent settings are changed' do
SiteSetting.blocked_attachment_filenames = 'foo'
expect(SiteSetting.blocked_attachment_filenames_regex).to eq(/foo/)
SiteSetting.blocked_attachment_filenames = 'foo|bar'
expect(SiteSetting.blocked_attachment_filenames_regex).to eq(/foo|bar/)
end
end
it 'sanitizes the client settings when they are overridden' do
xss = "<b onmouseover=alert('Wufff!')>click me!</b><script>alert('TEST');</script>"
SiteSetting.global_notice = xss
expect(SiteSetting.global_notice).to eq("<b>click me!</b>alert('TEST');")
end
it "doesn't corrupt site settings with special characters" do
value = 'OX5y3Oljb+Qt9Bu809vsBQ==<>!%{}*&!@#$%..._-A'
settings = new_settings(SiteSettings::LocalProcessProvider.new)
settings.setting(:test_setting, '', client: true)
settings.test_setting = value
expect(settings.test_setting).to eq(value)
end
2013-02-05 14:16:51 -05:00
end