debian-mirror-gitlab/spec/mailers/emails/profile_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

540 lines
18 KiB
Ruby
Raw Normal View History

2019-12-26 22:10:19 +05:30
# frozen_string_literal: true
2016-04-02 18:10:28 +05:30
require 'spec_helper'
require 'email_spec'
2020-07-28 23:09:34 +05:30
RSpec.describe Emails::Profile do
2016-04-02 18:10:28 +05:30
include EmailSpec::Matchers
include_context 'gitlab email notification'
2017-08-17 22:00:37 +05:30
shared_examples 'a new user email' do
it 'is sent to the new user with the correct subject and body' do
aggregate_failures do
is_expected.to deliver_to new_user_address
is_expected.to have_subject(/^Account was created for you$/i)
is_expected.to have_body_text(new_user_address)
end
end
end
2016-06-02 11:05:42 +05:30
2017-08-17 22:00:37 +05:30
describe 'for new users, the email' do
let(:example_site_path) { root_path }
let(:new_user) { create(:user, email: new_user_address, created_by_id: 1) }
let(:token) { 'kETLwRaayvigPq_x3SNM' }
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
subject { Notify.new_user_email(new_user.id, token) }
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'a new user email'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it 'contains the password text' do
is_expected.to have_body_text /Click here to set your password/
end
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it 'includes a link for user to set password' do
params = "reset_password_token=#{token}"
is_expected.to have_body_text(
%r{http://#{Gitlab.config.gitlab.host}(:\d+)?/users/password/edit\?#{params}}
)
2016-04-02 18:10:28 +05:30
end
2017-08-17 22:00:37 +05:30
it 'explains the reset link expiration' do
is_expected.to have_body_text(/This link is valid for \d+ (hours?|days?)/)
is_expected.to have_body_text(new_user_password_url)
is_expected.to have_body_text(/\?user_email=.*%40.*/)
end
end
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
describe 'for users that signed up, the email' do
let(:example_site_path) { root_path }
2022-08-27 11:52:29 +05:30
let(:new_user) { create(:user, email: new_user_address) }
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
subject { Notify.new_user_email(new_user.id) }
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'a new user email'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'does not contain the new user\'s password' do
2022-08-27 11:52:29 +05:30
is_expected.not_to have_body_text(new_user.password)
2017-08-17 22:00:37 +05:30
is_expected.not_to have_body_text /password/
2016-04-02 18:10:28 +05:30
end
2017-08-17 22:00:37 +05:30
end
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
describe 'user added ssh key' do
let(:key) { create(:personal_key) }
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
subject { Notify.new_ssh_key_email(key.id) }
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it 'is sent to the new user' do
is_expected.to deliver_to key.user.email
end
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it 'has the correct subject' do
is_expected.to have_subject /^SSH key was added to your account$/i
end
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it 'contains the new ssh key title' do
is_expected.to have_body_text /#{key.title}/
end
2016-04-02 18:10:28 +05:30
2017-08-17 22:00:37 +05:30
it 'includes a link to ssh keys page' do
is_expected.to have_body_text /#{profile_keys_path}/
end
2016-06-02 11:05:42 +05:30
2017-08-17 22:00:37 +05:30
context 'with SSH key that does not exist' do
it { expect { Notify.new_ssh_key_email('foo') }.not_to raise_error }
2016-04-02 18:10:28 +05:30
end
2017-08-17 22:00:37 +05:30
end
2016-04-02 18:10:28 +05:30
2017-09-10 17:25:29 +05:30
describe 'user added gpg key' do
let(:gpg_key) { create(:gpg_key) }
subject { Notify.new_gpg_key_email(gpg_key.id) }
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the new user' do
is_expected.to deliver_to gpg_key.user.email
end
it 'has the correct subject' do
is_expected.to have_subject /^GPG key was added to your account$/i
end
it 'contains the new gpg key title' do
is_expected.to have_body_text /#{gpg_key.fingerprint}/
end
it 'includes a link to gpg keys page' do
is_expected.to have_body_text /#{profile_gpg_keys_path}/
end
context 'with GPG key that does not exist' do
it { expect { Notify.new_gpg_key_email('foo') }.not_to raise_error }
end
end
2020-01-01 13:55:28 +05:30
2022-05-07 20:08:51 +05:30
describe 'user personal access token has been created' do
let_it_be(:user) { create(:user) }
let_it_be(:token) { create(:personal_access_token, user: user) }
context 'when valid' do
subject { Notify.access_token_created_email(user, token.name) }
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
is_expected.to have_subject /^A new personal access token has been created$/i
end
it 'provides the names of the token' do
is_expected.to have_body_text /#{token.name}/
end
it 'includes a link to personal access tokens page' do
is_expected.to have_body_text /#{profile_personal_access_tokens_path}/
end
it 'includes the email reason' do
2023-03-04 22:38:38 +05:30
is_expected.to have_body_text %r{You're receiving this email because of your account on <a .*>localhost</a>}
2022-05-07 20:08:51 +05:30
end
end
end
2020-01-01 13:55:28 +05:30
describe 'user personal access token is about to expire' do
let_it_be(:user) { create(:user) }
2021-04-17 20:07:23 +05:30
let_it_be(:expiring_token) { create(:personal_access_token, user: user, expires_at: 5.days.from_now) }
2020-01-01 13:55:28 +05:30
2021-04-17 20:07:23 +05:30
subject { Notify.access_token_about_to_expire_email(user, [expiring_token.name]) }
2020-01-01 13:55:28 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
2021-04-17 20:07:23 +05:30
is_expected.to have_subject /^Your personal access tokens will expire in 7 days or less$/i
2020-01-01 13:55:28 +05:30
end
it 'mentions the access tokens will expire' do
is_expected.to have_body_text /One or more of your personal access tokens will expire in 7 days or less/
end
2021-04-17 20:07:23 +05:30
it 'provides the names of expiring tokens' do
is_expected.to have_body_text /#{expiring_token.name}/
end
2020-01-01 13:55:28 +05:30
it 'includes a link to personal access tokens page' do
is_expected.to have_body_text /#{profile_personal_access_tokens_path}/
end
it 'includes the email reason' do
2023-03-04 22:38:38 +05:30
is_expected.to have_body_text %r{You're receiving this email because of your account on <a .*>localhost</a>}
2020-01-01 13:55:28 +05:30
end
context 'with User does not exist' do
it { expect { Notify.access_token_about_to_expire_email('foo') }.not_to raise_error }
end
end
2020-05-24 23:13:21 +05:30
2020-10-24 23:57:45 +05:30
describe 'user personal access token has expired' do
let_it_be(:user) { create(:user) }
2023-03-17 16:20:25 +05:30
let_it_be(:pat) { create(:personal_access_token, user: user) }
2020-10-24 23:57:45 +05:30
context 'when valid' do
2023-03-17 16:20:25 +05:30
subject { Notify.access_token_expired_email(user, [pat.name]) }
2020-10-24 23:57:45 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
2023-03-17 16:20:25 +05:30
is_expected.to have_subject /Your personal access tokens have expired/
2020-10-24 23:57:45 +05:30
end
it 'mentions the access token has expired' do
2023-03-17 16:20:25 +05:30
is_expected.to have_body_text /The following personal access tokens have expired:/
is_expected.to have_body_text /#{pat.name}/
2020-10-24 23:57:45 +05:30
end
it 'includes a link to personal access tokens page' do
is_expected.to have_body_text /#{profile_personal_access_tokens_path}/
end
it 'includes the email reason' do
2023-03-04 22:38:38 +05:30
is_expected.to have_body_text %r{You're receiving this email because of your account on <a .*>localhost</a>}
2020-10-24 23:57:45 +05:30
end
end
context 'when invalid' do
context 'when user does not exist' do
it do
expect { Notify.access_token_expired_email(nil) }.not_to change { ActionMailer::Base.deliveries.count }
end
end
context 'when user is not active' do
before do
user.block!
end
it do
expect { Notify.access_token_expired_email(user) }.not_to change { ActionMailer::Base.deliveries.count }
end
end
end
end
2022-11-25 23:54:43 +05:30
describe 'user personal access token has been revoked' do
let_it_be(:user) { create(:user) }
let_it_be(:token) { create(:personal_access_token, user: user) }
context 'when valid' do
subject { Notify.access_token_revoked_email(user, token.name) }
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
is_expected.to have_subject /^A personal access token has been revoked$/i
end
it 'provides the names of the token' do
is_expected.to have_body_text /#{token.name}/
end
2023-03-04 22:38:38 +05:30
it 'wont include the revocation reason' do
is_expected.not_to have_body_text %r{We found your token in a public project and have automatically revoked it to protect your account.$}
end
it 'includes the email reason' do
is_expected.to have_body_text %r{You're receiving this email because of your account on <a .*>localhost</a>}
end
end
context 'when source is provided' do
2023-03-17 16:20:25 +05:30
subject { Notify.access_token_revoked_email(user, token.name, :secret_detection) }
2023-03-04 22:38:38 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
is_expected.to have_subject /^A personal access token has been revoked$/i
end
it 'provides the names of the token' do
is_expected.to have_body_text /#{token.name}/
end
it 'includes the revocation reason' do
is_expected.to have_body_text %r{We found your token in a public project and have automatically revoked it to protect your account.$}
end
2022-11-25 23:54:43 +05:30
it 'includes the email reason' do
2023-03-04 22:38:38 +05:30
is_expected.to have_body_text %r{You're receiving this email because of your account on <a .*>localhost</a>}
2022-11-25 23:54:43 +05:30
end
end
end
2021-04-29 21:17:54 +05:30
describe 'SSH key notification' do
let_it_be_with_reload(:user) { create(:user) }
let_it_be(:fingerprints) { ["aa:bb:cc:dd:ee:zz"] }
shared_examples 'is sent to the user' do
it { is_expected.to deliver_to user.email }
end
shared_examples 'has the correct subject' do |subject_text|
it { is_expected.to have_subject subject_text }
end
shared_examples 'has the correct body text' do |body_text|
it { is_expected.to have_body_text body_text }
end
shared_examples 'includes a link to ssh key page' do
it { is_expected.to have_body_text /#{profile_keys_url}/ }
end
shared_examples 'includes the email reason' do
2023-03-04 22:38:38 +05:30
it { is_expected.to have_body_text %r{You're receiving this email because of your account on <a .*>localhost</a>} }
2021-04-29 21:17:54 +05:30
end
shared_examples 'valid use case' do
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it_behaves_like 'is sent to the user'
it_behaves_like 'includes a link to ssh key page'
it_behaves_like 'includes the email reason'
end
shared_examples 'does not send email' do
it do
expect { subject }.not_to change { ActionMailer::Base.deliveries.count }
end
end
shared_context 'block user' do
before do
user.block!
end
end
context 'notification email for expired ssh key' do
context 'when valid' do
subject { Notify.ssh_key_expired_email(user, fingerprints) }
include_examples 'valid use case'
it_behaves_like 'has the correct subject', /Your SSH key has expired/
2021-09-04 01:27:46 +05:30
it_behaves_like 'has the correct body text', /SSH keys with the following fingerprints have expired/
2021-04-29 21:17:54 +05:30
end
context 'when invalid' do
context 'when user does not exist' do
subject { Notify.ssh_key_expired_email(nil, fingerprints) }
it_behaves_like 'does not send email'
end
context 'when user is not active' do
subject { Notify.ssh_key_expired_email(user, fingerprints) }
include_context 'block user'
it_behaves_like 'does not send email'
end
end
end
context 'notification email for expiring ssh key' do
context 'when valid' do
subject { Notify.ssh_key_expiring_soon_email(user, fingerprints) }
include_examples 'valid use case'
it_behaves_like 'has the correct subject', /Your SSH key is expiring soon/
2021-09-04 01:27:46 +05:30
it_behaves_like 'has the correct body text', /SSH keys with the following fingerprints are scheduled to expire soon/
2021-04-29 21:17:54 +05:30
end
context 'when invalid' do
context 'when user does not exist' do
subject { Notify.ssh_key_expiring_soon_email(nil, fingerprints) }
it_behaves_like 'does not send email'
end
context 'when user is not active' do
subject { Notify.ssh_key_expiring_soon_email(user, fingerprints) }
include_context 'block user'
it_behaves_like 'does not send email'
end
end
end
end
2020-05-24 23:13:21 +05:30
describe 'user unknown sign in email' do
let_it_be(:user) { create(:user) }
let_it_be(:ip) { '169.0.0.1' }
2020-06-23 00:09:42 +05:30
let_it_be(:current_time) { Time.current }
let_it_be(:email) { Notify.unknown_sign_in_email(user, ip, current_time) }
2020-05-24 23:13:21 +05:30
2020-06-23 00:09:42 +05:30
subject { email }
2020-05-24 23:13:21 +05:30
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
2020-06-23 00:09:42 +05:30
is_expected.to deliver_to user.email
2020-05-24 23:13:21 +05:30
end
it 'has the correct subject' do
2020-06-23 00:09:42 +05:30
is_expected.to have_subject "#{Gitlab.config.gitlab.host} sign-in from new location"
end
it 'mentions the new sign-in IP' do
is_expected.to have_body_text ip
2020-05-24 23:13:21 +05:30
end
2020-06-23 00:09:42 +05:30
it 'mentioned the time' do
2021-09-04 01:27:46 +05:30
is_expected.to have_body_text current_time.strftime('%Y-%m-%d %H:%M:%S %Z')
2020-05-24 23:13:21 +05:30
end
2020-06-23 00:09:42 +05:30
it 'includes a link to the change password documentation' do
2022-11-25 23:54:43 +05:30
is_expected.to have_body_text 'https://docs.gitlab.com/ee/user/profile/user_passwords.html#change-your-password'
2020-05-24 23:13:21 +05:30
end
it 'mentions two factor authentication when two factor is not enabled' do
2020-06-23 00:09:42 +05:30
is_expected.to have_body_text 'two-factor authentication'
end
it 'includes a link to two-factor authentication documentation' do
is_expected.to have_body_text 'https://docs.gitlab.com/ee/user/profile/account/two_factor_authentication.html'
2020-05-24 23:13:21 +05:30
end
context 'when two factor authentication is enabled' do
2020-06-23 00:09:42 +05:30
let(:user) { create(:user, :two_factor) }
2020-05-24 23:13:21 +05:30
2020-06-23 00:09:42 +05:30
it 'does not mention two factor authentication' do
expect( Notify.unknown_sign_in_email(user, ip, current_time) )
2020-05-24 23:13:21 +05:30
.not_to have_body_text /two-factor authentication/
end
end
end
2020-11-24 15:15:51 +05:30
2022-11-25 23:54:43 +05:30
describe 'user attempted sign in with wrong 2FA OTP email' do
let_it_be(:user) { create(:user) }
let_it_be(:ip) { '169.0.0.1' }
let_it_be(:current_time) { Time.current }
let_it_be(:email) { Notify.two_factor_otp_attempt_failed_email(user, ip, current_time) }
subject { email }
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
is_expected.to have_subject "Attempted sign in to #{Gitlab.config.gitlab.host} using a wrong two-factor authentication code"
end
it 'mentions the IP address' do
is_expected.to have_body_text ip
end
it 'mentioned the time' do
is_expected.to have_body_text current_time.strftime('%Y-%m-%d %H:%M:%S %Z')
end
it 'includes a link to the change password documentation' do
is_expected.to have_body_text 'https://docs.gitlab.com/ee/user/profile/user_passwords.html#change-your-password'
end
end
2020-11-24 15:15:51 +05:30
describe 'disabled two-factor authentication email' do
let_it_be(:user) { create(:user) }
subject { Notify.disabled_two_factor_email(user) }
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
is_expected.to have_subject /^Two-factor authentication disabled$/i
end
it 'includes a link to two-factor authentication settings page' do
is_expected.to have_body_text /#{profile_two_factor_auth_path}/
end
end
2022-06-21 17:19:12 +05:30
describe 'added a new email address' do
let_it_be(:user) { create(:user) }
let_it_be(:email) { create(:email, user: user) }
subject { Notify.new_email_address_added_email(user, email) }
it_behaves_like 'an email sent from GitLab'
it_behaves_like 'it should not have Gmail Actions links'
it_behaves_like 'a user cannot unsubscribe through footer link'
it 'is sent to the user' do
is_expected.to deliver_to user.email
end
it 'has the correct subject' do
is_expected.to have_subject /^New email address added$/i
end
it 'includes a link to the email address page' do
is_expected.to have_body_text /#{profile_emails_path}/
end
end
2016-04-02 18:10:28 +05:30
end