Commit 852b9c28dd80af4a49336b0ff921a1a863dbc929
1 parent
f13bccc1
Exists in
master
and in
4 other branches
Move observer specs out of spec/models into spec/observers
Showing
6 changed files
with
218 additions
and
218 deletions
Show diff stats
spec/models/activity_observer_spec.rb
| ... | ... | @@ -1,48 +0,0 @@ |
| 1 | -require 'spec_helper' | |
| 2 | - | |
| 3 | -describe ActivityObserver do | |
| 4 | - let(:project) { Factory :project } | |
| 5 | - | |
| 6 | - def self.it_should_be_valid_event | |
| 7 | - it { @event.should_not be_nil } | |
| 8 | - it { @event.project.should == project } | |
| 9 | - end | |
| 10 | - | |
| 11 | - describe "Merge Request created" do | |
| 12 | - before do | |
| 13 | - MergeRequest.observers.enable :activity_observer do | |
| 14 | - @merge_request = Factory :merge_request, project: project | |
| 15 | - @event = Event.last | |
| 16 | - end | |
| 17 | - end | |
| 18 | - | |
| 19 | - it_should_be_valid_event | |
| 20 | - it { @event.action.should == Event::Created } | |
| 21 | - it { @event.target.should == @merge_request } | |
| 22 | - end | |
| 23 | - | |
| 24 | - describe "Issue created" do | |
| 25 | - before do | |
| 26 | - Issue.observers.enable :activity_observer do | |
| 27 | - @issue = Factory :issue, project: project | |
| 28 | - @event = Event.last | |
| 29 | - end | |
| 30 | - end | |
| 31 | - | |
| 32 | - it_should_be_valid_event | |
| 33 | - it { @event.action.should == Event::Created } | |
| 34 | - it { @event.target.should == @issue } | |
| 35 | - end | |
| 36 | - | |
| 37 | - #describe "Issue commented" do | |
| 38 | - #before do | |
| 39 | - #@issue = Factory :issue, project: project | |
| 40 | - #@note = Factory :note, noteable: @issue, project: project | |
| 41 | - #@event = Event.last | |
| 42 | - #end | |
| 43 | - | |
| 44 | - #it_should_be_valid_event | |
| 45 | - #it { @event.action.should == Event::Commented } | |
| 46 | - #it { @event.target.should == @note } | |
| 47 | - #end | |
| 48 | -end |
spec/models/issue_observer_spec.rb
| ... | ... | @@ -1,144 +0,0 @@ |
| 1 | -require 'spec_helper' | |
| 2 | - | |
| 3 | -describe IssueObserver do | |
| 4 | - let(:some_user) { double(:user, id: 1) } | |
| 5 | - let(:assignee) { double(:user, id: 2) } | |
| 6 | - let(:issue) { double(:issue, id: 42, assignee: assignee) } | |
| 7 | - | |
| 8 | - before(:each) { subject.stub(:current_user).and_return(some_user) } | |
| 9 | - | |
| 10 | - subject { IssueObserver.instance } | |
| 11 | - | |
| 12 | - describe '#after_create' do | |
| 13 | - | |
| 14 | - it 'is called when an issue is created' do | |
| 15 | - subject.should_receive(:after_create) | |
| 16 | - | |
| 17 | - Issue.observers.enable :issue_observer do | |
| 18 | - Factory.create(:issue, project: Factory.create(:project)) | |
| 19 | - end | |
| 20 | - end | |
| 21 | - | |
| 22 | - it 'sends an email to the assignee' do | |
| 23 | - Notify.should_receive(:new_issue_email).with(issue.id). | |
| 24 | - and_return(double(deliver: true)) | |
| 25 | - | |
| 26 | - subject.after_create(issue) | |
| 27 | - end | |
| 28 | - | |
| 29 | - it 'does not send an email to the assignee if assignee created the issue' do | |
| 30 | - subject.stub(:current_user).and_return(assignee) | |
| 31 | - Notify.should_not_receive(:new_issue_email) | |
| 32 | - | |
| 33 | - subject.after_create(issue) | |
| 34 | - end | |
| 35 | - end | |
| 36 | - | |
| 37 | - context '#after_update' do | |
| 38 | - before(:each) do | |
| 39 | - issue.stub(:is_being_reassigned?).and_return(false) | |
| 40 | - issue.stub(:is_being_closed?).and_return(false) | |
| 41 | - issue.stub(:is_being_reopened?).and_return(false) | |
| 42 | - end | |
| 43 | - | |
| 44 | - it 'is called when an issue is changed' do | |
| 45 | - changed = Factory.create(:issue, project: Factory.create(:project)) | |
| 46 | - subject.should_receive(:after_update) | |
| 47 | - | |
| 48 | - Issue.observers.enable :issue_observer do | |
| 49 | - changed.description = 'I changed' | |
| 50 | - changed.save | |
| 51 | - end | |
| 52 | - end | |
| 53 | - | |
| 54 | - context 'a reassigned email' do | |
| 55 | - it 'is sent if the issue is being reassigned' do | |
| 56 | - issue.should_receive(:is_being_reassigned?).and_return(true) | |
| 57 | - subject.should_receive(:send_reassigned_email).with(issue) | |
| 58 | - | |
| 59 | - subject.after_update(issue) | |
| 60 | - end | |
| 61 | - | |
| 62 | - it 'is not sent if the issue is not being reassigned' do | |
| 63 | - issue.should_receive(:is_being_reassigned?).and_return(false) | |
| 64 | - subject.should_not_receive(:send_reassigned_email) | |
| 65 | - | |
| 66 | - subject.after_update(issue) | |
| 67 | - end | |
| 68 | - end | |
| 69 | - | |
| 70 | - context 'a status "closed" note' do | |
| 71 | - it 'is created if the issue is being closed' do | |
| 72 | - issue.should_receive(:is_being_closed?).and_return(true) | |
| 73 | - Note.should_receive(:create_status_change_note).with(issue, some_user, 'closed') | |
| 74 | - | |
| 75 | - subject.after_update(issue) | |
| 76 | - end | |
| 77 | - | |
| 78 | - it 'is not created if the issue is not being closed' do | |
| 79 | - issue.should_receive(:is_being_closed?).and_return(false) | |
| 80 | - Note.should_not_receive(:create_status_change_note).with(issue, some_user, 'closed') | |
| 81 | - | |
| 82 | - subject.after_update(issue) | |
| 83 | - end | |
| 84 | - end | |
| 85 | - | |
| 86 | - context 'a status "reopened" note' do | |
| 87 | - it 'is created if the issue is being reopened' do | |
| 88 | - issue.should_receive(:is_being_reopened?).and_return(true) | |
| 89 | - Note.should_receive(:create_status_change_note).with(issue, some_user, 'reopened') | |
| 90 | - | |
| 91 | - subject.after_update(issue) | |
| 92 | - end | |
| 93 | - | |
| 94 | - it 'is not created if the issue is not being reopened' do | |
| 95 | - issue.should_receive(:is_being_reopened?).and_return(false) | |
| 96 | - Note.should_not_receive(:create_status_change_note).with(issue, some_user, 'reopened') | |
| 97 | - | |
| 98 | - subject.after_update(issue) | |
| 99 | - end | |
| 100 | - end | |
| 101 | - end | |
| 102 | - | |
| 103 | - describe '#send_reassigned_email' do | |
| 104 | - let(:previous_assignee) { double(:user, id: 3) } | |
| 105 | - | |
| 106 | - before(:each) do | |
| 107 | - issue.stub(:assignee_id).and_return(assignee.id) | |
| 108 | - issue.stub(:assignee_id_was).and_return(previous_assignee.id) | |
| 109 | - end | |
| 110 | - | |
| 111 | - def it_sends_a_reassigned_email_to(recipient) | |
| 112 | - Notify.should_receive(:reassigned_issue_email).with(recipient, issue.id, previous_assignee.id). | |
| 113 | - and_return(double(deliver: true)) | |
| 114 | - end | |
| 115 | - | |
| 116 | - def it_does_not_send_a_reassigned_email_to(recipient) | |
| 117 | - Notify.should_not_receive(:reassigned_issue_email).with(recipient, issue.id, previous_assignee.id) | |
| 118 | - end | |
| 119 | - | |
| 120 | - it 'sends a reassigned email to the previous and current assignees' do | |
| 121 | - it_sends_a_reassigned_email_to assignee.id | |
| 122 | - it_sends_a_reassigned_email_to previous_assignee.id | |
| 123 | - | |
| 124 | - subject.send(:send_reassigned_email, issue) | |
| 125 | - end | |
| 126 | - | |
| 127 | - context 'does not send an email to the user who made the reassignment' do | |
| 128 | - it 'if the user is the assignee' do | |
| 129 | - subject.stub(:current_user).and_return(assignee) | |
| 130 | - it_sends_a_reassigned_email_to previous_assignee.id | |
| 131 | - it_does_not_send_a_reassigned_email_to assignee.id | |
| 132 | - | |
| 133 | - subject.send(:send_reassigned_email, issue) | |
| 134 | - end | |
| 135 | - it 'if the user is the previous assignee' do | |
| 136 | - subject.stub(:current_user).and_return(previous_assignee) | |
| 137 | - it_sends_a_reassigned_email_to assignee.id | |
| 138 | - it_does_not_send_a_reassigned_email_to previous_assignee.id | |
| 139 | - | |
| 140 | - subject.send(:send_reassigned_email, issue) | |
| 141 | - end | |
| 142 | - end | |
| 143 | - end | |
| 144 | -end |
spec/models/user_observer_spec.rb
| ... | ... | @@ -1,26 +0,0 @@ |
| 1 | -require 'spec_helper' | |
| 2 | - | |
| 3 | -describe UserObserver do | |
| 4 | - subject { UserObserver.instance } | |
| 5 | - | |
| 6 | - it 'calls #after_create when new users are created' do | |
| 7 | - new_user = Factory.new(:user) | |
| 8 | - subject.should_receive(:after_create).with(new_user) | |
| 9 | - | |
| 10 | - User.observers.enable :user_observer do | |
| 11 | - new_user.save | |
| 12 | - end | |
| 13 | - end | |
| 14 | - | |
| 15 | - context 'when a new user is created' do | |
| 16 | - let(:user) { double(:user, id: 42, password: 'P@ssword!') } | |
| 17 | - let(:notification) { double :notification } | |
| 18 | - | |
| 19 | - it 'sends an email' do | |
| 20 | - notification.should_receive(:deliver) | |
| 21 | - Notify.should_receive(:new_user_email).with(user.id, user.password).and_return(notification) | |
| 22 | - | |
| 23 | - subject.after_create(user) | |
| 24 | - end | |
| 25 | - end | |
| 26 | -end |
| ... | ... | @@ -0,0 +1,48 @@ |
| 1 | +require 'spec_helper' | |
| 2 | + | |
| 3 | +describe ActivityObserver do | |
| 4 | + let(:project) { Factory :project } | |
| 5 | + | |
| 6 | + def self.it_should_be_valid_event | |
| 7 | + it { @event.should_not be_nil } | |
| 8 | + it { @event.project.should == project } | |
| 9 | + end | |
| 10 | + | |
| 11 | + describe "Merge Request created" do | |
| 12 | + before do | |
| 13 | + MergeRequest.observers.enable :activity_observer do | |
| 14 | + @merge_request = Factory :merge_request, project: project | |
| 15 | + @event = Event.last | |
| 16 | + end | |
| 17 | + end | |
| 18 | + | |
| 19 | + it_should_be_valid_event | |
| 20 | + it { @event.action.should == Event::Created } | |
| 21 | + it { @event.target.should == @merge_request } | |
| 22 | + end | |
| 23 | + | |
| 24 | + describe "Issue created" do | |
| 25 | + before do | |
| 26 | + Issue.observers.enable :activity_observer do | |
| 27 | + @issue = Factory :issue, project: project | |
| 28 | + @event = Event.last | |
| 29 | + end | |
| 30 | + end | |
| 31 | + | |
| 32 | + it_should_be_valid_event | |
| 33 | + it { @event.action.should == Event::Created } | |
| 34 | + it { @event.target.should == @issue } | |
| 35 | + end | |
| 36 | + | |
| 37 | + #describe "Issue commented" do | |
| 38 | + #before do | |
| 39 | + #@issue = Factory :issue, project: project | |
| 40 | + #@note = Factory :note, noteable: @issue, project: project | |
| 41 | + #@event = Event.last | |
| 42 | + #end | |
| 43 | + | |
| 44 | + #it_should_be_valid_event | |
| 45 | + #it { @event.action.should == Event::Commented } | |
| 46 | + #it { @event.target.should == @note } | |
| 47 | + #end | |
| 48 | +end | ... | ... |
| ... | ... | @@ -0,0 +1,144 @@ |
| 1 | +require 'spec_helper' | |
| 2 | + | |
| 3 | +describe IssueObserver do | |
| 4 | + let(:some_user) { double(:user, id: 1) } | |
| 5 | + let(:assignee) { double(:user, id: 2) } | |
| 6 | + let(:issue) { double(:issue, id: 42, assignee: assignee) } | |
| 7 | + | |
| 8 | + before(:each) { subject.stub(:current_user).and_return(some_user) } | |
| 9 | + | |
| 10 | + subject { IssueObserver.instance } | |
| 11 | + | |
| 12 | + describe '#after_create' do | |
| 13 | + | |
| 14 | + it 'is called when an issue is created' do | |
| 15 | + subject.should_receive(:after_create) | |
| 16 | + | |
| 17 | + Issue.observers.enable :issue_observer do | |
| 18 | + Factory.create(:issue, project: Factory.create(:project)) | |
| 19 | + end | |
| 20 | + end | |
| 21 | + | |
| 22 | + it 'sends an email to the assignee' do | |
| 23 | + Notify.should_receive(:new_issue_email).with(issue.id). | |
| 24 | + and_return(double(deliver: true)) | |
| 25 | + | |
| 26 | + subject.after_create(issue) | |
| 27 | + end | |
| 28 | + | |
| 29 | + it 'does not send an email to the assignee if assignee created the issue' do | |
| 30 | + subject.stub(:current_user).and_return(assignee) | |
| 31 | + Notify.should_not_receive(:new_issue_email) | |
| 32 | + | |
| 33 | + subject.after_create(issue) | |
| 34 | + end | |
| 35 | + end | |
| 36 | + | |
| 37 | + context '#after_update' do | |
| 38 | + before(:each) do | |
| 39 | + issue.stub(:is_being_reassigned?).and_return(false) | |
| 40 | + issue.stub(:is_being_closed?).and_return(false) | |
| 41 | + issue.stub(:is_being_reopened?).and_return(false) | |
| 42 | + end | |
| 43 | + | |
| 44 | + it 'is called when an issue is changed' do | |
| 45 | + changed = Factory.create(:issue, project: Factory.create(:project)) | |
| 46 | + subject.should_receive(:after_update) | |
| 47 | + | |
| 48 | + Issue.observers.enable :issue_observer do | |
| 49 | + changed.description = 'I changed' | |
| 50 | + changed.save | |
| 51 | + end | |
| 52 | + end | |
| 53 | + | |
| 54 | + context 'a reassigned email' do | |
| 55 | + it 'is sent if the issue is being reassigned' do | |
| 56 | + issue.should_receive(:is_being_reassigned?).and_return(true) | |
| 57 | + subject.should_receive(:send_reassigned_email).with(issue) | |
| 58 | + | |
| 59 | + subject.after_update(issue) | |
| 60 | + end | |
| 61 | + | |
| 62 | + it 'is not sent if the issue is not being reassigned' do | |
| 63 | + issue.should_receive(:is_being_reassigned?).and_return(false) | |
| 64 | + subject.should_not_receive(:send_reassigned_email) | |
| 65 | + | |
| 66 | + subject.after_update(issue) | |
| 67 | + end | |
| 68 | + end | |
| 69 | + | |
| 70 | + context 'a status "closed" note' do | |
| 71 | + it 'is created if the issue is being closed' do | |
| 72 | + issue.should_receive(:is_being_closed?).and_return(true) | |
| 73 | + Note.should_receive(:create_status_change_note).with(issue, some_user, 'closed') | |
| 74 | + | |
| 75 | + subject.after_update(issue) | |
| 76 | + end | |
| 77 | + | |
| 78 | + it 'is not created if the issue is not being closed' do | |
| 79 | + issue.should_receive(:is_being_closed?).and_return(false) | |
| 80 | + Note.should_not_receive(:create_status_change_note).with(issue, some_user, 'closed') | |
| 81 | + | |
| 82 | + subject.after_update(issue) | |
| 83 | + end | |
| 84 | + end | |
| 85 | + | |
| 86 | + context 'a status "reopened" note' do | |
| 87 | + it 'is created if the issue is being reopened' do | |
| 88 | + issue.should_receive(:is_being_reopened?).and_return(true) | |
| 89 | + Note.should_receive(:create_status_change_note).with(issue, some_user, 'reopened') | |
| 90 | + | |
| 91 | + subject.after_update(issue) | |
| 92 | + end | |
| 93 | + | |
| 94 | + it 'is not created if the issue is not being reopened' do | |
| 95 | + issue.should_receive(:is_being_reopened?).and_return(false) | |
| 96 | + Note.should_not_receive(:create_status_change_note).with(issue, some_user, 'reopened') | |
| 97 | + | |
| 98 | + subject.after_update(issue) | |
| 99 | + end | |
| 100 | + end | |
| 101 | + end | |
| 102 | + | |
| 103 | + describe '#send_reassigned_email' do | |
| 104 | + let(:previous_assignee) { double(:user, id: 3) } | |
| 105 | + | |
| 106 | + before(:each) do | |
| 107 | + issue.stub(:assignee_id).and_return(assignee.id) | |
| 108 | + issue.stub(:assignee_id_was).and_return(previous_assignee.id) | |
| 109 | + end | |
| 110 | + | |
| 111 | + def it_sends_a_reassigned_email_to(recipient) | |
| 112 | + Notify.should_receive(:reassigned_issue_email).with(recipient, issue.id, previous_assignee.id). | |
| 113 | + and_return(double(deliver: true)) | |
| 114 | + end | |
| 115 | + | |
| 116 | + def it_does_not_send_a_reassigned_email_to(recipient) | |
| 117 | + Notify.should_not_receive(:reassigned_issue_email).with(recipient, issue.id, previous_assignee.id) | |
| 118 | + end | |
| 119 | + | |
| 120 | + it 'sends a reassigned email to the previous and current assignees' do | |
| 121 | + it_sends_a_reassigned_email_to assignee.id | |
| 122 | + it_sends_a_reassigned_email_to previous_assignee.id | |
| 123 | + | |
| 124 | + subject.send(:send_reassigned_email, issue) | |
| 125 | + end | |
| 126 | + | |
| 127 | + context 'does not send an email to the user who made the reassignment' do | |
| 128 | + it 'if the user is the assignee' do | |
| 129 | + subject.stub(:current_user).and_return(assignee) | |
| 130 | + it_sends_a_reassigned_email_to previous_assignee.id | |
| 131 | + it_does_not_send_a_reassigned_email_to assignee.id | |
| 132 | + | |
| 133 | + subject.send(:send_reassigned_email, issue) | |
| 134 | + end | |
| 135 | + it 'if the user is the previous assignee' do | |
| 136 | + subject.stub(:current_user).and_return(previous_assignee) | |
| 137 | + it_sends_a_reassigned_email_to assignee.id | |
| 138 | + it_does_not_send_a_reassigned_email_to previous_assignee.id | |
| 139 | + | |
| 140 | + subject.send(:send_reassigned_email, issue) | |
| 141 | + end | |
| 142 | + end | |
| 143 | + end | |
| 144 | +end | ... | ... |
| ... | ... | @@ -0,0 +1,26 @@ |
| 1 | +require 'spec_helper' | |
| 2 | + | |
| 3 | +describe UserObserver do | |
| 4 | + subject { UserObserver.instance } | |
| 5 | + | |
| 6 | + it 'calls #after_create when new users are created' do | |
| 7 | + new_user = Factory.new(:user) | |
| 8 | + subject.should_receive(:after_create).with(new_user) | |
| 9 | + | |
| 10 | + User.observers.enable :user_observer do | |
| 11 | + new_user.save | |
| 12 | + end | |
| 13 | + end | |
| 14 | + | |
| 15 | + context 'when a new user is created' do | |
| 16 | + let(:user) { double(:user, id: 42, password: 'P@ssword!') } | |
| 17 | + let(:notification) { double :notification } | |
| 18 | + | |
| 19 | + it 'sends an email' do | |
| 20 | + notification.should_receive(:deliver) | |
| 21 | + Notify.should_receive(:new_user_email).with(user.id, user.password).and_return(notification) | |
| 22 | + | |
| 23 | + subject.after_create(user) | |
| 24 | + end | |
| 25 | + end | |
| 26 | +end | ... | ... |