summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSean McGivern <sean@mcgivern.me.uk>2017-11-14 12:25:14 +0000
committerSean McGivern <sean@mcgivern.me.uk>2017-11-14 12:25:14 +0000
commitfb7abd87daa8930682b05870361fe9dd112f050f (patch)
tree3b7e73b8985666bef1d1ae5af69cea2453cbab2f
parentacc60818caf34db81f276fa94daea7b6c3a37be4 (diff)
parentaefefbf11701042ae59a60818e3f957b30831dfd (diff)
downloadgitlab-ce-fb7abd87daa8930682b05870361fe9dd112f050f.tar.gz
Merge branch 'issue_40058' into 'master'
Prevent position update for image diff notes Closes #40058 See merge request gitlab-org/gitlab-ce!15357
-rw-r--r--app/models/diff_note.rb3
-rw-r--r--changelogs/unreleased/issue_40058.yml5
-rw-r--r--spec/models/diff_note_spec.rb6
3 files changed, 13 insertions, 1 deletions
diff --git a/app/models/diff_note.rb b/app/models/diff_note.rb
index d88a92dc027..ae5f138a920 100644
--- a/app/models/diff_note.rb
+++ b/app/models/diff_note.rb
@@ -18,7 +18,8 @@ class DiffNote < Note
validate :positions_complete
validate :verify_supported
- before_validation :set_original_position, :update_position, on: :create
+ before_validation :set_original_position, on: :create
+ before_validation :update_position, on: :create, if: :on_text?
before_validation :set_line_code
after_save :keep_around_commits
diff --git a/changelogs/unreleased/issue_40058.yml b/changelogs/unreleased/issue_40058.yml
new file mode 100644
index 00000000000..46e83d947ba
--- /dev/null
+++ b/changelogs/unreleased/issue_40058.yml
@@ -0,0 +1,5 @@
+---
+title: Prevents position update for image diff notes
+merge_request:
+author:
+type: fixed
diff --git a/spec/models/diff_note_spec.rb b/spec/models/diff_note_spec.rb
index da972d2d86a..8389d5c5430 100644
--- a/spec/models/diff_note_spec.rb
+++ b/spec/models/diff_note_spec.rb
@@ -283,6 +283,12 @@ describe DiffNote do
expect(diff_line).to be nil
expect(subject).to be_valid
end
+
+ it "does not update the position" do
+ expect(subject).not_to receive(:update_position)
+
+ subject.save
+ end
end
it "returns true for on_image?" do