79 lines
2.8 KiB
Ruby
79 lines
2.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'Unsubscribe links', :sidekiq_might_not_need_inline do
|
|
include Warden::Test::Helpers
|
|
|
|
let(:recipient) { create(:user) }
|
|
let(:author) { create(:user) }
|
|
let(:project) { create(:project, :public) }
|
|
let(:params) { { title: 'A bug!', description: 'Fix it!', assignees: [recipient] } }
|
|
let(:issue) { Issues::CreateService.new(project: project, current_user: author, params: params, spam_params: nil).execute }
|
|
|
|
let(:mail) { ActionMailer::Base.deliveries.last }
|
|
let(:body) { Capybara::Node::Simple.new(mail.default_part_body.to_s) }
|
|
let(:header_link) { mail.header['List-Unsubscribe'].to_s[1..-2] } # Strip angle brackets
|
|
let(:body_link) { body.find_link('Unsubscribe')['href'] }
|
|
|
|
before do
|
|
perform_enqueued_jobs { issue }
|
|
end
|
|
|
|
context 'when logged out' do
|
|
context 'when visiting the link from the body' do
|
|
it 'shows the unsubscribe confirmation page and redirects to root path when confirming' do
|
|
visit body_link
|
|
|
|
expect(page).to have_current_path unsubscribe_sent_notification_path(SentNotification.last), ignore_query: true
|
|
expect(page).to have_text(%(Unsubscribe from issue))
|
|
expect(page).to have_text(%(Are you sure you want to unsubscribe from the issue: #{issue.title} (#{issue.to_reference})?))
|
|
expect(issue.subscribed?(recipient, project)).to be_truthy
|
|
|
|
click_link 'Unsubscribe'
|
|
|
|
expect(issue.subscribed?(recipient, project)).to be_falsey
|
|
expect(page).to have_current_path new_user_session_path, ignore_query: true
|
|
end
|
|
|
|
it 'shows the unsubscribe confirmation page and redirects to root path when canceling' do
|
|
visit body_link
|
|
|
|
expect(page).to have_current_path unsubscribe_sent_notification_path(SentNotification.last), ignore_query: true
|
|
expect(issue.subscribed?(recipient, project)).to be_truthy
|
|
|
|
click_link 'Cancel'
|
|
|
|
expect(issue.subscribed?(recipient, project)).to be_truthy
|
|
expect(page).to have_current_path new_user_session_path, ignore_query: true
|
|
end
|
|
end
|
|
|
|
it 'unsubscribes from the issue when visiting the link from the header' do
|
|
visit header_link
|
|
|
|
expect(page).to have_text('unsubscribed')
|
|
expect(issue.subscribed?(recipient, project)).to be_falsey
|
|
end
|
|
end
|
|
|
|
context 'when logged in' do
|
|
before do
|
|
sign_in(recipient)
|
|
end
|
|
|
|
it 'unsubscribes from the issue when visiting the link from the email body' do
|
|
visit body_link
|
|
|
|
expect(page).to have_text('unsubscribed')
|
|
expect(issue.subscribed?(recipient, project)).to be_falsey
|
|
end
|
|
|
|
it 'unsubscribes from the issue when visiting the link from the header' do
|
|
visit header_link
|
|
|
|
expect(page).to have_text('unsubscribed')
|
|
expect(issue.subscribed?(recipient, project)).to be_falsey
|
|
end
|
|
end
|
|
end
|