2012-08-29 07:52:19 +02:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2012-09-08 02:30:47 +02:00
|
|
|
describe Issue do
|
2012-10-30 03:27:36 +01:00
|
|
|
it { should include_module(Votes) }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe MergeRequest do
|
|
|
|
let(:merge_request) { FactoryGirl.create(:merge_request_with_diffs) }
|
|
|
|
|
|
|
|
it { should include_module(Votes) }
|
2012-08-29 07:52:19 +02:00
|
|
|
|
2012-09-08 02:30:47 +02:00
|
|
|
describe "#upvotes" do
|
|
|
|
it "with no notes has a 0/0 score" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.upvotes.should == 0
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
2012-08-29 07:52:19 +02:00
|
|
|
|
2012-09-08 02:30:47 +02:00
|
|
|
it "should recognize non-+1 notes" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize a single +1 note" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "+1 This is awesome")
|
|
|
|
merge_request.upvotes.should == 1
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
2012-08-29 07:52:19 +02:00
|
|
|
|
2012-09-08 02:30:47 +02:00
|
|
|
it "should recognize multiple +1 notes" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
2012-08-29 07:52:19 +02:00
|
|
|
end
|
|
|
|
|
2012-09-08 02:30:47 +02:00
|
|
|
describe "#downvotes" do
|
|
|
|
it "with no notes has a 0/0 score" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.downvotes.should == 0
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize non--1 notes" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize a single -1 note" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "-1 This is bad")
|
|
|
|
merge_request.downvotes.should == 1
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize multiple -1 notes" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-08 02:30:47 +02:00
|
|
|
end
|
2012-08-29 07:52:19 +02:00
|
|
|
end
|
2012-09-08 02:37:29 +02:00
|
|
|
|
|
|
|
describe "#votes_count" do
|
|
|
|
it "with no notes has a 0/0 score" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.votes_count.should == 0
|
2012-09-08 02:37:29 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize non notes" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "No +1 here")
|
|
|
|
merge_request.should have(1).note
|
|
|
|
merge_request.votes_count.should == 0
|
2012-09-08 02:37:29 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize a single +1 note" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "+1 This is awesome")
|
|
|
|
merge_request.votes_count.should == 1
|
2012-09-08 02:37:29 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize a single -1 note" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "-1 This is bad")
|
|
|
|
merge_request.votes_count.should == 1
|
2012-09-08 02:37:29 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should recognize multiple notes" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-08 02:37:29 +02:00
|
|
|
end
|
|
|
|
end
|
2012-09-11 16:47:59 +02:00
|
|
|
|
|
|
|
describe "#upvotes_in_percent" do
|
|
|
|
it "with no notes has a 0% score" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.upvotes_in_percent.should == 0
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should count a single 1 note as 100%" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "+1 This is awesome")
|
|
|
|
merge_request.upvotes_in_percent.should == 100
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should count multiple +1 notes as 100%" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should count fractions for multiple +1 and -1 notes correctly" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#downvotes_in_percent" do
|
|
|
|
it "with no notes has a 0% score" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.downvotes_in_percent.should == 0
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should count a single -1 note as 100%" do
|
2012-10-30 03:27:36 +01:00
|
|
|
merge_request.notes << create(:note, note: "-1 This is bad")
|
|
|
|
merge_request.downvotes_in_percent.should == 100
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should count multiple -1 notes as 100%" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "should count fractions for multiple +1 and -1 notes correctly" do
|
2012-10-30 03:27:36 +01:00
|
|
|
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
|
2012-09-11 16:47:59 +02:00
|
|
|
end
|
|
|
|
end
|
2012-08-29 07:52:19 +02:00
|
|
|
end
|