You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
docuseal/spec/services/external_auth_service_spec.rb

140 lines
4.6 KiB

# frozen_string_literal: true
require 'rails_helper'
RSpec.describe ExternalAuthService do
describe '#authenticate_user' do
let(:user_params) do
{
external_id: 123,
email: 'test@example.com',
first_name: 'John',
last_name: 'Doe'
}
end
context 'with account params' do
let(:params) do
{
account: {
external_id: '456', name: 'Test Account', locale: 'en-US', timezone: 'UTC', entity_type: 'Account'
},
user: user_params
}
end
it 'returns access token for new account and user' do
token = described_class.new(params).authenticate_user
expect(token).to be_present
expect(Account.last.external_account_id).to eq(456)
expect(User.last.external_user_id).to eq(123)
end
it 'returns access token for existing user' do
account = create(:account, external_account_id: 456)
user = create(:user, account: account, external_user_id: 123)
token = described_class.new(params).authenticate_user
expect(token).to eq(user.access_token.token)
end
it 'finds correct user when same external_user_id exists in different accounts' do
# Create two accounts with users having the same external_user_id
account1 = create(:account, external_account_id: 456)
user1 = create(:user, account: account1, external_user_id: 123, email: 'user1@example.com')
account2 = create(:account, external_account_id: 789)
create(:user, account: account2, external_user_id: 123, email: 'user2@example.com')
# Authenticate for account1 - should find user1, not user2
token = described_class.new(params).authenticate_user
expect(token).to eq(user1.access_token.token)
expect(User.count).to eq(2) # Should not create a new user
end
end
context 'with partnership params' do
let(:params) do
{
partnership: {
external_id: '789', name: 'Test Group', locale: 'en-US', timezone: 'UTC', entity_type: 'Partnership'
},
user: user_params
}
end
it 'returns access token for new partnership and user' do
token = described_class.new(params).authenticate_user
expect(token).to be_present
expect(Partnership.last.external_partnership_id).to eq(789)
expect(User.last.external_user_id).to eq(123)
end
it 'returns access token for existing partnership and user' do
user = create(:user, account: nil, external_user_id: 123)
token = described_class.new(params).authenticate_user
expect(token).to eq(user.access_token.token)
end
end
context 'with partnership and account params' do
let(:params) do
{
partnership: {
external_id: '789', name: 'Test Group', locale: 'en-US', timezone: 'UTC', entity_type: 'Partnership'
},
external_account_id: '456',
user: user_params
}
end
it 'creates partnership user with account context' do
account = create(:account, external_account_id: 456)
token = described_class.new(params).authenticate_user
expect(token).to be_present
expect(Partnership.last.external_partnership_id).to eq(789)
expect(User.last.external_user_id).to eq(123)
expect(User.last.account_id).to eq(account.id)
end
it 'creates new user when partnership user exists but account context differs' do
account = create(:account, external_account_id: 456)
partnership_user = create(:user, account: nil, external_user_id: 123)
token = described_class.new(params).authenticate_user
# Should create a new user for the account context (account scoping)
expect(token).not_to eq(partnership_user.access_token.token)
expect(User.count).to eq(2)
expect(User.last.account_id).to eq(account.id)
expect(User.last.external_user_id).to eq(123)
end
it 'handles external_account_id for account-level operations' do
account = create(:account, external_account_id: 456)
token = described_class.new(params).authenticate_user
expect(token).to be_present
expect(User.last.account_id).to eq(account.id)
end
end
context 'with invalid params' do
it 'raises error when neither account nor partnership provided' do
params = { user: user_params }
expect { described_class.new(params).authenticate_user }
.to raise_error(ArgumentError, 'Either account or partnership params must be provided')
end
end
end
end