Add coverage for "live TOS" and "no TOS" paths in tos/drafts spec (#35902)

This commit is contained in:
Matt Jankowski 2025-08-26 04:43:43 -04:00 committed by GitHub
parent 460043a969
commit a8166d28ed
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -8,6 +8,7 @@ RSpec.describe 'Admin TermsOfService Drafts' do
before { sign_in(admin_user) } before { sign_in(admin_user) }
describe 'Managing TOS drafts' do describe 'Managing TOS drafts' do
context 'when a draft TOS record exists' do
let!(:terms) { Fabricate :terms_of_service, published_at: nil } let!(:terms) { Fabricate :terms_of_service, published_at: nil }
it 'saves and publishes TOS drafts' do it 'saves and publishes TOS drafts' do
@ -38,4 +39,44 @@ RSpec.describe 'Admin TermsOfService Drafts' do
.to have_title(I18n.t('admin.terms_of_service.title')) .to have_title(I18n.t('admin.terms_of_service.title'))
end end
end end
context 'when a live TOS record exists' do
before do
travel_to 5.days.ago do
Fabricate :terms_of_service, published_at: 2.days.ago, effective_date: 1.day.from_now
end
end
it 'populates an unsaved record with prior text' do
visit admin_terms_of_service_draft_path
expect(page)
.to have_title(I18n.t('admin.terms_of_service.title'))
# Valid submission with draft button
expect { click_on I18n.t('admin.terms_of_service.save_draft') }
.to change(TermsOfService, :count).by(1)
.and not_change(Admin::ActionLog, :count)
expect(TermsOfService.current.text)
.to eq(TermsOfService.draft.last.text)
expect(page)
.to have_title(I18n.t('admin.terms_of_service.title'))
end
end
context 'when there are no TOS records' do
it 'builds an unsaved record for editing' do
visit admin_terms_of_service_draft_path
expect(page)
.to have_title(I18n.t('admin.terms_of_service.title'))
# Valid submission with draft button
fill_in 'terms_of_service_text', with: 'new'
expect { click_on I18n.t('admin.terms_of_service.save_draft') }
.to change(TermsOfService, :count).by(1)
.and not_change(Admin::ActionLog, :count)
expect(page)
.to have_title(I18n.t('admin.terms_of_service.title'))
end
end
end
end end