Merge commit 'master' into discussions
Conflicts: app/assets/stylesheets/sections/notes.scss app/contexts/notes/load_context.rb app/models/project.rb app/observers/note_observer.rb app/roles/votes.rb app/views/commit/show.html.haml app/views/merge_requests/_show.html.haml app/views/merge_requests/diffs.js.haml app/views/merge_requests/show.js.haml app/views/notes/_note.html.haml features/steps/project/project_merge_requests.rb spec/models/note_spec.rb
This commit is contained in:
commit
3022786948
930 changed files with 80374 additions and 103682 deletions
|
@ -7,7 +7,8 @@ describe ExtractsPath do
|
|||
|
||||
before do
|
||||
@project = project
|
||||
project.stub(:ref_names).and_return(['master', 'foo/bar/baz', 'v1.0.0', 'v2.0.0'])
|
||||
project.stub(repository: stub(ref_names: ['master', 'foo/bar/baz', 'v1.0.0', 'v2.0.0']))
|
||||
project.stub(path_with_namespace: 'gitlab/gitlab-ci')
|
||||
end
|
||||
|
||||
describe '#extract_ref' do
|
||||
|
@ -53,5 +54,24 @@ describe ExtractsPath do
|
|||
extract_ref('stable/CHANGELOG').should == ['stable', 'CHANGELOG']
|
||||
end
|
||||
end
|
||||
|
||||
context "with a fullpath" do
|
||||
it "extracts a valid branch" do
|
||||
extract_ref('/gitlab/gitlab-ci/tree/foo/bar/baz/CHANGELOG').should == ['foo/bar/baz', 'CHANGELOG']
|
||||
end
|
||||
|
||||
it "extracts a valid tag" do
|
||||
extract_ref('/gitlab/gitlab-ci/tree/v2.0.0/CHANGELOG').should == ['v2.0.0', 'CHANGELOG']
|
||||
end
|
||||
|
||||
it "extracts a valid commit SHA" do
|
||||
extract_ref('/gitlab/gitlab-ci/tree/f4b14494ef6abf3d144c28e4af0c20143383e062/CHANGELOG').should ==
|
||||
['f4b14494ef6abf3d144c28e4af0c20143383e062', 'CHANGELOG']
|
||||
end
|
||||
|
||||
it "extracts a timestamp" do
|
||||
extract_ref('/gitlab/gitlab-ci/tree/v2.0.0/CHANGELOG?_=12354435').should == ['v2.0.0', 'CHANGELOG']
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -5,6 +5,7 @@ describe Gitlab::ProjectMover do
|
|||
|
||||
before do
|
||||
FileUtils.rm_rf base_path if File.exists? base_path
|
||||
FileUtils.mkdir_p base_path
|
||||
|
||||
Gitlab.config.gitolite.stub(repos_path: base_path)
|
||||
|
||||
|
|
138
spec/lib/votes_spec.rb
Normal file
138
spec/lib/votes_spec.rb
Normal file
|
@ -0,0 +1,138 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe Issue do
|
||||
it { should include_module(Votes) }
|
||||
end
|
||||
|
||||
describe MergeRequest do
|
||||
let(:merge_request) { FactoryGirl.create(:merge_request_with_diffs) }
|
||||
|
||||
it { should include_module(Votes) }
|
||||
|
||||
describe "#upvotes" do
|
||||
it "with no notes has a 0/0 score" do
|
||||
merge_request.upvotes.should == 0
|
||||
end
|
||||
|
||||
it "should recognize non-+1 notes" do
|
||||
merge_request.notes << create(:note, note: "No +1 here")
|
||||
merge_request.should have(1).note
|
||||
merge_request.notes.first.upvote?.should be_false
|
||||
merge_request.upvotes.should == 0
|
||||
end
|
||||
|
||||
it "should recognize a single +1 note" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.upvotes.should == 1
|
||||
end
|
||||
|
||||
it "should recognize multiple +1 notes" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.notes << create(:note, note: "+1 I want this")
|
||||
merge_request.upvotes.should == 2
|
||||
end
|
||||
end
|
||||
|
||||
describe "#downvotes" do
|
||||
it "with no notes has a 0/0 score" do
|
||||
merge_request.downvotes.should == 0
|
||||
end
|
||||
|
||||
it "should recognize non--1 notes" do
|
||||
merge_request.notes << create(:note, note: "Almost got a -1")
|
||||
merge_request.should have(1).note
|
||||
merge_request.notes.first.downvote?.should be_false
|
||||
merge_request.downvotes.should == 0
|
||||
end
|
||||
|
||||
it "should recognize a single -1 note" do
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.downvotes.should == 1
|
||||
end
|
||||
|
||||
it "should recognize multiple -1 notes" do
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.notes << create(:note, note: "-1 Away with this")
|
||||
merge_request.downvotes.should == 2
|
||||
end
|
||||
end
|
||||
|
||||
describe "#votes_count" do
|
||||
it "with no notes has a 0/0 score" do
|
||||
merge_request.votes_count.should == 0
|
||||
end
|
||||
|
||||
it "should recognize non notes" do
|
||||
merge_request.notes << create(:note, note: "No +1 here")
|
||||
merge_request.should have(1).note
|
||||
merge_request.votes_count.should == 0
|
||||
end
|
||||
|
||||
it "should recognize a single +1 note" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.votes_count.should == 1
|
||||
end
|
||||
|
||||
it "should recognize a single -1 note" do
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.votes_count.should == 1
|
||||
end
|
||||
|
||||
it "should recognize multiple notes" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.notes << create(:note, note: "+1 I want this")
|
||||
merge_request.votes_count.should == 3
|
||||
end
|
||||
end
|
||||
|
||||
describe "#upvotes_in_percent" do
|
||||
it "with no notes has a 0% score" do
|
||||
merge_request.upvotes_in_percent.should == 0
|
||||
end
|
||||
|
||||
it "should count a single 1 note as 100%" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.upvotes_in_percent.should == 100
|
||||
end
|
||||
|
||||
it "should count multiple +1 notes as 100%" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.notes << create(:note, note: "+1 I want this")
|
||||
merge_request.upvotes_in_percent.should == 100
|
||||
end
|
||||
|
||||
it "should count fractions for multiple +1 and -1 notes correctly" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.notes << create(:note, note: "+1 I want this")
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.notes << create(:note, note: "+1 me too")
|
||||
merge_request.upvotes_in_percent.should == 75
|
||||
end
|
||||
end
|
||||
|
||||
describe "#downvotes_in_percent" do
|
||||
it "with no notes has a 0% score" do
|
||||
merge_request.downvotes_in_percent.should == 0
|
||||
end
|
||||
|
||||
it "should count a single -1 note as 100%" do
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.downvotes_in_percent.should == 100
|
||||
end
|
||||
|
||||
it "should count multiple -1 notes as 100%" do
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.notes << create(:note, note: "-1 Away with this")
|
||||
merge_request.downvotes_in_percent.should == 100
|
||||
end
|
||||
|
||||
it "should count fractions for multiple +1 and -1 notes correctly" do
|
||||
merge_request.notes << create(:note, note: "+1 This is awesome")
|
||||
merge_request.notes << create(:note, note: "+1 I want this")
|
||||
merge_request.notes << create(:note, note: "-1 This is bad")
|
||||
merge_request.notes << create(:note, note: "+1 me too")
|
||||
merge_request.downvotes_in_percent.should == 25
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue