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 | ... | ... |