discourse/spec/controllers/steps_controller_spec.rb
Sam 49ed382c2a FIX: return 429 when admin api key is limited on admin route
This also handles a general case where exceptions leak out prior to being handled by the application controller
2018-01-12 14:15:26 +11:00

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