Convert `statuses_cleanup` controller specs to system specs (#33363)

pull/33365/head
Matt Jankowski 1 week ago committed by GitHub
parent d826919aeb
commit 03bf4cde55
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -1,43 +0,0 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe StatusesCleanupController do
render_views
let!(:user) { Fabricate(:user) }
before do
sign_in user, scope: :user
end
describe 'GET #show' do
before do
get :show
end
it 'returns http success' do
expect(response).to have_http_status(200)
end
it 'returns private cache control headers' do
expect(response.headers['Cache-Control']).to include('private, no-store')
end
end
describe 'PUT #update' do
before do
put :update, params: { account_statuses_cleanup_policy: { enabled: true, min_status_age: 2.weeks.seconds, keep_direct: false, keep_polls: true } }
end
it 'updates the account status cleanup policy' do
expect(user.account.statuses_cleanup_policy.enabled).to be true
expect(user.account.statuses_cleanup_policy.keep_direct).to be false
expect(user.account.statuses_cleanup_policy.keep_polls).to be true
end
it 'redirects' do
expect(response).to redirect_to(statuses_cleanup_path)
end
end
end

@ -0,0 +1,33 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe 'Automated post deletion settings' do
let(:user) { Fabricate :user }
let(:account) { user.account }
describe 'Updating settings' do
before { sign_in user }
it 'visits the page and updates the policy' do
visit statuses_cleanup_path
expect(page)
.to have_private_cache_control
check I18n.t('statuses_cleanup.enabled')
submit_form
expect(account.reload.statuses_cleanup_policy)
.to be_enabled
uncheck I18n.t('statuses_cleanup.keep_pinned')
expect { submit_form }
.to change { account.reload.statuses_cleanup_policy.keep_pinned? }.to(false)
expect(page)
.to have_content(I18n.t('settings.statuses_cleanup'))
end
def submit_form
click_on submit_button
end
end
end
Loading…
Cancel
Save