2012-06-20 12:29:10 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe UserObserver do
|
|
|
|
subject { UserObserver.instance }
|
|
|
|
|
|
|
|
it 'calls #after_create when new users are created' do
|
2012-11-06 14:31:55 +11:00
|
|
|
new_user = build(:user)
|
2012-06-20 12:29:10 -04:00
|
|
|
subject.should_receive(:after_create).with(new_user)
|
|
|
|
|
|
|
|
User.observers.enable :user_observer do
|
|
|
|
new_user.save
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a new user is created' do
|
2012-11-23 22:25:28 +02:00
|
|
|
let(:user) { double(:user, id: 42,
|
|
|
|
password: 'P@ssword!',
|
|
|
|
name: 'John',
|
|
|
|
email: 'u@mail.local',
|
|
|
|
username: 'root',
|
|
|
|
create_namespace: true) }
|
2012-06-20 12:29:10 -04:00
|
|
|
let(:notification) { double :notification }
|
|
|
|
|
|
|
|
it 'sends an email' do
|
|
|
|
notification.should_receive(:deliver)
|
|
|
|
Notify.should_receive(:new_user_email).with(user.id, user.password).and_return(notification)
|
|
|
|
|
|
|
|
subject.after_create(user)
|
|
|
|
end
|
2012-09-12 09:05:12 +03:00
|
|
|
|
|
|
|
it 'trigger logger' do
|
|
|
|
Gitlab::AppLogger.should_receive(:info)
|
|
|
|
subject.after_create(user)
|
|
|
|
end
|
2012-06-20 12:29:10 -04:00
|
|
|
end
|
|
|
|
end
|