Commit b1461de993daf6d43c8a54482eecacc6bb58df4d
1 parent
db3d90cb
Exists in
master
and in
4 other branches
Make Note methods saner
Showing
7 changed files
with
39 additions
and
18 deletions
Show diff stats
app/helpers/notes_helper.rb
@@ -13,9 +13,7 @@ module NotesHelper | @@ -13,9 +13,7 @@ module NotesHelper | ||
13 | end | 13 | end |
14 | 14 | ||
15 | def link_to_commit_diff_line_note(note) | 15 | def link_to_commit_diff_line_note(note) |
16 | - return unless note.line_note? | ||
17 | - | ||
18 | - commit = note.target | 16 | + commit = note.noteable |
19 | diff_index, diff_old_line, diff_new_line = note.line_code.split('_') | 17 | diff_index, diff_old_line, diff_new_line = note.line_code.split('_') |
20 | 18 | ||
21 | link_file = commit.diffs[diff_index.to_i].new_path | 19 | link_file = commit.diffs[diff_index.to_i].new_path |
app/mailers/notify.rb
@@ -29,7 +29,7 @@ class Notify < ActionMailer::Base | @@ -29,7 +29,7 @@ class Notify < ActionMailer::Base | ||
29 | 29 | ||
30 | def note_commit_email(recipient_id, note_id) | 30 | def note_commit_email(recipient_id, note_id) |
31 | @note = Note.find(note_id) | 31 | @note = Note.find(note_id) |
32 | - @commit = @note.target | 32 | + @commit = @note.noteable |
33 | @commit = CommitDecorator.decorate(@commit) | 33 | @commit = CommitDecorator.decorate(@commit) |
34 | @project = @note.project | 34 | @project = @note.project |
35 | mail(to: recipient(recipient_id), subject: subject("note for commit #{@commit.short_id}", @commit.title)) | 35 | mail(to: recipient(recipient_id), subject: subject("note for commit #{@commit.short_id}", @commit.title)) |
app/models/note.rb
@@ -48,11 +48,12 @@ class Note < ActiveRecord::Base | @@ -48,11 +48,12 @@ class Note < ActiveRecord::Base | ||
48 | @notify_author ||= false | 48 | @notify_author ||= false |
49 | end | 49 | end |
50 | 50 | ||
51 | - def target | ||
52 | - if commit? | 51 | + # override to return commits, which are not active record |
52 | + def noteable | ||
53 | + if for_commit? | ||
53 | project.commit(noteable_id) | 54 | project.commit(noteable_id) |
54 | else | 55 | else |
55 | - noteable | 56 | + super |
56 | end | 57 | end |
57 | # Temp fix to prevent app crash | 58 | # Temp fix to prevent app crash |
58 | # if note commit id doesnt exist | 59 | # if note commit id doesnt exist |
@@ -74,22 +75,22 @@ class Note < ActiveRecord::Base | @@ -74,22 +75,22 @@ class Note < ActiveRecord::Base | ||
74 | # Boolean | 75 | # Boolean |
75 | # | 76 | # |
76 | def notify_only_author?(user) | 77 | def notify_only_author?(user) |
77 | - commit? && commit_author && | 78 | + for_commit? && commit_author && |
78 | commit_author.email != user.email | 79 | commit_author.email != user.email |
79 | end | 80 | end |
80 | 81 | ||
81 | - def commit? | 82 | + def for_commit? |
82 | noteable_type == "Commit" | 83 | noteable_type == "Commit" |
83 | end | 84 | end |
84 | 85 | ||
85 | - def line_note? | 86 | + def for_diff_line? |
86 | line_code.present? | 87 | line_code.present? |
87 | end | 88 | end |
88 | 89 | ||
89 | def commit_author | 90 | def commit_author |
90 | @commit_author ||= | 91 | @commit_author ||= |
91 | - project.users.find_by_email(target.author_email) || | ||
92 | - project.users.find_by_name(target.author_name) | 92 | + project.users.find_by_email(noteable.author_email) || |
93 | + project.users.find_by_name(noteable.author_name) | ||
93 | rescue | 94 | rescue |
94 | nil | 95 | nil |
95 | end | 96 | end |
app/roles/static_model.rb
app/views/notes/_note.html.haml
@@ -8,10 +8,10 @@ | @@ -8,10 +8,10 @@ | ||
8 | ago | 8 | ago |
9 | 9 | ||
10 | - unless note_for_main_target?(note) | 10 | - unless note_for_main_target?(note) |
11 | - - if note.commit? | 11 | + - if note.for_commit? |
12 | %span.cgray | 12 | %span.cgray |
13 | - on #{link_to note.target.short_id, project_commit_path(@project, note.target)} | ||
14 | - = link_to_commit_diff_line_note(note) if note.line_note? | 13 | + on #{link_to note.noteable.short_id, project_commit_path(@project, note.noteable)} |
14 | + = link_to_commit_diff_line_note(note) if note.for_diff_line? | ||
15 | 15 | ||
16 | -# only show vote if it's a note for the main target | 16 | -# only show vote if it's a note for the main target |
17 | - if note_for_main_target?(note) | 17 | - if note_for_main_target?(note) |
spec/mailers/notify_spec.rb
@@ -235,7 +235,7 @@ describe Notify do | @@ -235,7 +235,7 @@ describe Notify do | ||
235 | commit.stub(:safe_message).and_return('some message') | 235 | commit.stub(:safe_message).and_return('some message') |
236 | end | 236 | end |
237 | end | 237 | end |
238 | - before(:each) { note.stub(:target).and_return(commit) } | 238 | + before(:each) { note.stub(:noteable).and_return(commit) } |
239 | 239 | ||
240 | subject { Notify.note_commit_email(recipient.id, note.id) } | 240 | subject { Notify.note_commit_email(recipient.id, note.id) } |
241 | 241 |
spec/models/note_spec.rb
@@ -85,9 +85,19 @@ describe Note do | @@ -85,9 +85,19 @@ describe Note do | ||
85 | noteable_type: "Commit" | 85 | noteable_type: "Commit" |
86 | end | 86 | end |
87 | 87 | ||
88 | + it "should be accessible through #noteable" do | ||
89 | + @note.noteable_id.should == commit.id | ||
90 | + @note.noteable.should be_a(Commit) | ||
91 | + @note.noteable.should == commit | ||
92 | + end | ||
93 | + | ||
88 | it "should save a valid note" do | 94 | it "should save a valid note" do |
89 | @note.noteable_id.should == commit.id | 95 | @note.noteable_id.should == commit.id |
90 | - @note.target.id.should == commit.id | 96 | + @note.noteable == commit |
97 | + end | ||
98 | + | ||
99 | + it "should be recognized by #for_commit?" do | ||
100 | + @note.should be_for_commit | ||
91 | end | 101 | end |
92 | end | 102 | end |
93 | 103 | ||
@@ -101,7 +111,11 @@ describe Note do | @@ -101,7 +111,11 @@ describe Note do | ||
101 | 111 | ||
102 | it "should save a valid note" do | 112 | it "should save a valid note" do |
103 | @note.noteable_id.should == commit.id | 113 | @note.noteable_id.should == commit.id |
104 | - @note.target.id.should == commit.id | 114 | + @note.noteable.id.should == commit.id |
115 | + end | ||
116 | + | ||
117 | + it "should be recognized by #for_diff_line?" do | ||
118 | + @note.should be_for_diff_line | ||
105 | end | 119 | end |
106 | end | 120 | end |
107 | 121 |