merge_request_spec.rb 2.15 KB
Newer Older
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
1 2 3 4
# == Schema Information
#
# Table name: merge_requests
#
5 6 7 8
#  id            :integer          not null, primary key
#  target_branch :string(255)      not null
#  source_branch :string(255)      not null
#  project_id    :integer          not null
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
9 10 11
#  author_id     :integer
#  assignee_id   :integer
#  title         :string(255)
12 13 14 15 16 17
#  closed        :boolean          default(FALSE), not null
#  created_at    :datetime         not null
#  updated_at    :datetime         not null
#  st_commits    :text(2147483647)
#  st_diffs      :text(2147483647)
#  merged        :boolean          default(FALSE), not null
Andrew8xx8's avatar
Andrew8xx8 committed
18
#  merge_status  :integer          default(1), not null
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
19
#  milestone_id  :integer
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
20 21
#

Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
22 23 24
require 'spec_helper'

describe MergeRequest do
25 26 27 28 29
  describe "Validation" do
    it { should validate_presence_of(:target_branch) }
    it { should validate_presence_of(:source_branch) }
  end

30 31 32 33 34
  describe "Mass assignment" do
    it { should_not allow_mass_assignment_of(:author_id) }
    it { should_not allow_mass_assignment_of(:project_id) }
  end

35 36 37 38 39 40
  describe "Respond to" do
    it { should respond_to(:unchecked?) }
    it { should respond_to(:can_be_merged?) }
    it { should respond_to(:cannot_be_merged?) }
  end
 
41
  describe 'modules' do
42
    it { should include_module(Issuable) }
43
  end
44

45 46 47 48
  describe "#mr_and_commit_notes" do

  end

49
  describe "#mr_and_commit_notes" do
50
    let!(:merge_request) { create(:merge_request) }
51 52

    before do
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
53
      merge_request.stub(:commits) { [merge_request.project.repository.commit] }
54
      create(:note, commit_id: merge_request.commits.first.id, noteable_type: 'Commit')
55
      create(:note, noteable: merge_request)
56 57 58 59 60 61 62
    end

    it "should include notes for commits" do
      merge_request.commits.should_not be_empty
      merge_request.mr_and_commit_notes.count.should == 2
    end
  end
63

64
  subject { create(:merge_request) }
65 66 67

  describe '#is_being_reassigned?' do
    it 'returns true if the merge_request assignee has changed' do
68
      subject.assignee = create(:user)
69 70 71 72 73 74
      subject.is_being_reassigned?.should be_true
    end
    it 'returns false if the merge request assignee has not changed' do
      subject.is_being_reassigned?.should be_false
    end
  end
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
75
end