discourse/spec/controllers/wizard_controller_spec.rb
Sam f2e7b74d88 FIX: don't return 200s when login is required to paths
When running `ensure_login_required` it should always happen prior to
`check_xhr` cause check xhr will trigger a 200 response
2018-02-01 12:26:45 +11:00

52 lines
1.2 KiB
Ruby

require 'rails_helper'
describe WizardController do
context 'wizard enabled' do
render_views
before do
SiteSetting.wizard_enabled = true
end
it 'needs you to be logged in' do
get :index, format: :json
expect(response.status).to eq(403)
end
it 'needs you to be logged in' do
get :index
# for whatever reason, no access is 404
# we may want to revisit this at some point and make it 403
expect(response.status).to eq(404)
end
it "raises an error if you aren't an admin" do
log_in(:moderator)
get :index, format: :json
expect(response).to be_forbidden
end
it "raises an error if the wizard is disabled" do
SiteSetting.wizard_enabled = false
log_in(:admin)
get :index, format: :json
expect(response).to be_forbidden
end
it "renders the wizard if you are an admin" do
log_in(:admin)
get :index, format: :json
expect(response).to be_success
end
it "returns JSON when the mime type is appropriate" do
log_in(:admin)
get :index, format: 'json'
expect(response).to be_success
expect(::JSON.parse(response.body).has_key?('wizard')).to eq(true)
end
end
end