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-09-12 09:05:12 +03:00
|
|
|
let(:user) { double(:user, id: 42, password: 'P@ssword!', name: 'John', email: 'u@mail.local') }
|
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
|