Commit 7856fba3621c0c3437f3bd208de0fdab43f0ab9d

Authored by Izaak Alpert
1 parent 4d373005

Updated format_patch to use '..' rather than '...'

Was incorrectly including commits reachable from rev2.

Change-Id: I3560e5d5ce474ba3d374f29ae16190b1f74989be
lib/gitlab/satellite/merge_action.rb
... ... @@ -89,13 +89,15 @@ module Gitlab
89 89 prepare_satellite!(merge_repo)
90 90 update_satellite_source_and_target!(merge_repo)
91 91 if (merge_request.for_fork?)
92   - patch = merge_repo.git.format_patch(default_options({stdout: true}), "origin/#{merge_request.target_branch}...source/#{merge_request.source_branch}")
  92 + patch = merge_repo.git.format_patch(default_options({stdout: true}), "origin/#{merge_request.target_branch}..source/#{merge_request.source_branch}")
93 93 else
94   - patch = merge_repo.git.format_patch(default_options({stdout: true}), "#{merge_request.target_branch}...#{merge_request.source_branch}")
  94 + patch = merge_repo.git.format_patch(default_options({stdout: true}), "#{merge_request.target_branch}..#{merge_request.source_branch}")
95 95 end
96 96 return patch
97 97 end
98 98 rescue Grit::Git::CommandFailed => ex
  99 + puts ex
  100 + ex.backtrace.each {|l|puts l}
99 101 handle_exception(ex)
100 102 end
101 103  
... ...
spec/lib/gitlab/satellite/merge_action_spec.rb
... ... @@ -51,23 +51,36 @@ describe 'Gitlab::Satellite::MergeAction' do
51 51 end
52 52  
53 53 describe '#format_patch' do
  54 + let(:target_commit) {['artiom-config-examples','9edbac5ac88ffa1ec9dad0097226b51e29ebc9ac']}
  55 + let(:source_commit) {['metior', '313d96e42b313a0af5ab50fa233bf43e27118b3f']}
  56 +
  57 + def verify_content(patch)
  58 + (patch.include? source_commit[1]).should be_true
  59 + (patch.include? '635d3e09b72232b6e92a38de6cc184147e5bcb41').should be_true
  60 + (patch.include? '2bb2dee057327c81978ed0aa99904bd7ff5e6105').should be_true
  61 + (patch.include? '2e83de1924ad3429b812d17498b009a8b924795d').should be_true
  62 + (patch.include? 'ee45a49c57a362305431cbf004e4590b713c910e').should be_true
  63 + (patch.include? 'a6870dd08f8f274d9a6b899f638c0c26fefaa690').should be_true
  64 +
  65 + (patch.include? 'e74fae147abc7d2ffbf93d363dbbe45b87751f6f').should be_false
  66 + (patch.include? '86f76b11c670425bbab465087f25172378d76147').should be_false
  67 + end
  68 +
54 69 context 'on fork' do
55 70 it 'should build a format patch' do
56   - merge_request_fork.target_branch = @close_commit1[0]
57   - merge_request_fork.source_branch = @close_commit2[0]
  71 + merge_request_fork.target_branch = target_commit[0]
  72 + merge_request_fork.source_branch = source_commit[0]
58 73 patch = Gitlab::Satellite::MergeAction.new(merge_request_fork.author, merge_request_fork).format_patch
59   - (patch.include? "From #{@close_commit2[1]}").should be_true
60   - (patch.include? "From #{@close_commit1[1]}").should be_true
  74 + verify_content(patch)
61 75 end
62 76 end
63 77  
64 78 context 'between branches' do
65 79 it 'should build a format patch' do
66   - merge_request.target_branch = @close_commit1[0]
67   - merge_request.source_branch = @close_commit2[0]
68   - patch = Gitlab::Satellite::MergeAction.new(merge_request.author, merge_request).format_patch
69   - (patch.include? "From #{@close_commit2[1]}").should be_true
70   - (patch.include? "From #{@close_commit1[1]}").should be_true
  80 + merge_request.target_branch = target_commit[0]
  81 + merge_request.source_branch = source_commit[0]
  82 + patch = Gitlab::Satellite::MergeAction.new(merge_request_fork.author, merge_request).format_patch
  83 + verify_content(patch)
71 84 end
72 85 end
73 86 end
... ...