Convert settings/preferences/notifications controller spec to system (#33322)

This commit is contained in:
Matt Jankowski 2024-12-16 11:24:05 -05:00 committed by GitHub
parent bfef66276a
commit 9067a7f696
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 27 additions and 43 deletions

View file

@ -1,43 +0,0 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe Settings::Preferences::NotificationsController 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 with private cache control headers', :aggregate_failures do
expect(response).to have_http_status(200)
expect(response.headers['Cache-Control']).to include('private, no-store')
end
end
describe 'PUT #update' do
it 'updates notifications settings' do
user.settings.update('notification_emails.follow': false)
user.save
put :update, params: {
user: {
settings_attributes: {
'notification_emails.follow': '1',
},
},
}
expect(response).to redirect_to(settings_preferences_notifications_path)
user.reload
expect(user.settings['notification_emails.follow']).to be true
end
end
end

View file

@ -0,0 +1,27 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe 'Settings preferences notifications page' do
let(:user) { Fabricate :user }
before { sign_in user }
it 'Views and updates user prefs' do
visit settings_preferences_notifications_path
expect(page)
.to have_private_cache_control
uncheck notifications_follow_field
expect { click_on submit_button }
.to change { user.reload.settings['notification_emails.follow'] }.to(false)
expect(page)
.to have_title(I18n.t('settings.notifications'))
end
def notifications_follow_field
I18n.t('simple_form.labels.notification_emails.follow')
end
end