99 lines
3.2 KiB
Ruby
99 lines
3.2 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe User, type: :model do
|
|
describe 'database columns' do
|
|
it { is_expected.to have_db_column(:email) }
|
|
it { is_expected.to have_db_column(:encrypted_password) }
|
|
it { is_expected.to have_db_column(:reset_password_token) }
|
|
it { is_expected.to have_db_column(:reset_password_sent_at) }
|
|
it { is_expected.to have_db_column(:remember_created_at) }
|
|
it { is_expected.to have_db_column(:sign_in_count) }
|
|
it { is_expected.to have_db_column(:current_sign_in_at) }
|
|
it { is_expected.to have_db_column(:last_sign_in_at) }
|
|
it { is_expected.to have_db_column(:current_sign_in_ip) }
|
|
it { is_expected.to have_db_column(:last_sign_in_ip) }
|
|
it { is_expected.to have_db_column(:created_at) }
|
|
it { is_expected.to have_db_column(:updated_at) }
|
|
it { is_expected.to have_db_column(:siret) }
|
|
it { is_expected.to have_db_column(:loged_in_with_france_connect) }
|
|
|
|
end
|
|
describe 'associations' do
|
|
it { is_expected.to have_many(:dossiers) }
|
|
it { is_expected.to have_many(:invites) }
|
|
it { is_expected.to have_many(:piece_justificative) }
|
|
it { is_expected.to have_many(:cerfa) }
|
|
end
|
|
describe '#find_for_france_connect' do
|
|
let(:siret) { '00000000000000' }
|
|
context 'when user exist' do
|
|
let!(:user) { create(:user) }
|
|
subject { described_class.find_for_france_connect(user.email, siret) }
|
|
it 'retrieves user' do
|
|
expect(subject).to eq(user)
|
|
end
|
|
it 'saves siret in user' do
|
|
expect(subject.siret).to eq(siret)
|
|
end
|
|
it 'does not create new user' do
|
|
expect { subject }.not_to change(User, :count)
|
|
end
|
|
end
|
|
context 'when user does not exist' do
|
|
let(:email) { 'super-m@n.com' }
|
|
subject { described_class.find_for_france_connect(email, siret) }
|
|
it 'returns user' do
|
|
expect(subject).to be_an_instance_of(User)
|
|
end
|
|
it 'creates new user' do
|
|
expect { subject }.to change(User, :count).by(1)
|
|
end
|
|
it 'saves siret' do
|
|
expect(subject.siret).to eq(siret)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#invite?' do
|
|
let(:dossier) { create :dossier }
|
|
let(:user) { dossier.user }
|
|
|
|
subject { user.invite? dossier.id }
|
|
|
|
context 'when user is invite at the dossier' do
|
|
before do
|
|
create :invite, dossier_id: dossier.id, user: user
|
|
end
|
|
|
|
it { is_expected.to be_truthy }
|
|
end
|
|
|
|
context 'when user is not invite at the dossier' do
|
|
it { is_expected.to be_falsey }
|
|
end
|
|
end
|
|
|
|
context 'unified login' do
|
|
it 'syncs credentials to associated gestionnaire' do
|
|
user = create(:user)
|
|
gestionnaire = create(:gestionnaire, email: user.email)
|
|
|
|
user.update_attributes(email: 'whoami@plop.com', password: 'super secret')
|
|
|
|
gestionnaire.reload
|
|
expect(gestionnaire.email).to eq('whoami@plop.com')
|
|
expect(gestionnaire.valid_password?('super secret')).to be(true)
|
|
end
|
|
|
|
it 'syncs credentials to associated administrateur' do
|
|
user = create(:user)
|
|
admin = create(:administrateur, email: user.email)
|
|
|
|
user.update_attributes(email: 'whoami@plop.com', password: 'super secret')
|
|
|
|
admin.reload
|
|
expect(admin.email).to eq('whoami@plop.com')
|
|
expect(admin.valid_password?('super secret')).to be(true)
|
|
end
|
|
end
|
|
end
|