mirror of
https://github.com/discourse/discourse.git
synced 2025-06-01 09:08:10 +08:00
FIX: do not include contact url & email in client site settings payload (#13004)
This commit is contained in:
48
spec/serializers/about_serializer_spec.rb
Normal file
48
spec/serializers/about_serializer_spec.rb
Normal file
@ -0,0 +1,48 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
describe AboutSerializer do
|
||||
|
||||
fab!(:user) { Fabricate(:user) }
|
||||
|
||||
context "login_required is enabled" do
|
||||
before do
|
||||
SiteSetting.login_required = true
|
||||
SiteSetting.contact_url = "https://example.com/contact"
|
||||
SiteSetting.contact_email = "example@foobar.com"
|
||||
end
|
||||
|
||||
it "contact details are hidden from anonymous users" do
|
||||
json = AboutSerializer.new(About.new(nil), scope: Guardian.new(nil), root: nil).as_json
|
||||
expect(json[:contact_url]).to eq(nil)
|
||||
expect(json[:contact_email]).to eq(nil)
|
||||
end
|
||||
|
||||
it "contact details are visible to regular users" do
|
||||
json = AboutSerializer.new(About.new(user), scope: Guardian.new(user), root: nil).as_json
|
||||
expect(json[:contact_url]).to eq(SiteSetting.contact_url)
|
||||
expect(json[:contact_email]).to eq(SiteSetting.contact_email)
|
||||
end
|
||||
end
|
||||
|
||||
context "login_required is disabled" do
|
||||
before do
|
||||
SiteSetting.login_required = false
|
||||
SiteSetting.contact_url = "https://example.com/contact"
|
||||
SiteSetting.contact_email = "example@foobar.com"
|
||||
end
|
||||
|
||||
it "contact details are visible to anonymous users" do
|
||||
json = AboutSerializer.new(About.new(nil), scope: Guardian.new(nil), root: nil).as_json
|
||||
expect(json[:contact_url]).to eq(SiteSetting.contact_url)
|
||||
expect(json[:contact_email]).to eq(SiteSetting.contact_email)
|
||||
end
|
||||
|
||||
it "contact details are visible to regular users" do
|
||||
json = AboutSerializer.new(About.new(user), scope: Guardian.new(user), root: nil).as_json
|
||||
expect(json[:contact_url]).to eq(SiteSetting.contact_url)
|
||||
expect(json[:contact_email]).to eq(SiteSetting.contact_email)
|
||||
end
|
||||
end
|
||||
end
|
Reference in New Issue
Block a user