mirror of
https://github.com/discourse/discourse.git
synced 2024-11-24 11:12:23 +08:00
49ed382c2a
This also handles a general case where exceptions leak out prior to being handled by the application controller
58 lines
1.4 KiB
Ruby
58 lines
1.4 KiB
Ruby
require 'rails_helper'
|
|
|
|
describe StepsController do
|
|
|
|
before do
|
|
SiteSetting.wizard_enabled = true
|
|
end
|
|
|
|
it 'needs you to be logged in' do
|
|
put :update, params: {
|
|
id: 'made-up-id', fields: { forum_title: "updated title" }
|
|
}, format: :json
|
|
expect(response.status).to eq(403)
|
|
end
|
|
|
|
it "raises an error if you aren't an admin" do
|
|
log_in(:moderator)
|
|
|
|
put :update, params: {
|
|
id: 'made-up-id', fields: { forum_title: "updated title" }
|
|
}, format: :json
|
|
|
|
expect(response).to be_forbidden
|
|
end
|
|
|
|
context "as an admin" do
|
|
before do
|
|
log_in(:admin)
|
|
end
|
|
|
|
it "raises an error if the wizard is disabled" do
|
|
SiteSetting.wizard_enabled = false
|
|
put :update, params: {
|
|
id: 'contact', fields: { contact_email: "eviltrout@example.com" }
|
|
}, format: :json
|
|
expect(response).to be_forbidden
|
|
end
|
|
|
|
it "updates properly if you are staff" do
|
|
put :update, params: {
|
|
id: 'contact', fields: { contact_email: "eviltrout@example.com" }
|
|
}, format: :json
|
|
|
|
expect(response).to be_success
|
|
expect(SiteSetting.contact_email).to eq("eviltrout@example.com")
|
|
end
|
|
|
|
it "returns errors if the field has them" do
|
|
put :update, params: {
|
|
id: 'contact', fields: { contact_email: "not-an-email" }
|
|
}, format: :json
|
|
|
|
expect(response).to_not be_success
|
|
end
|
|
end
|
|
|
|
end
|