note_spec.rb
2.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
require 'spec_helper'
describe Note do
  describe "Associations" do
    it { should belong_to(:project) }
  end
  describe "Validation" do
    it { should validate_presence_of(:note) }
    it { should validate_presence_of(:project) }
  end
  it { Factory.create(:note,
                      :project => Factory.create(:project)).should be_valid }
  describe "Scopes" do
    it "should have a today named scope that returns ..." do
      Note.today.where_values.should == ["created_at >= '#{Date.today}'"]
    end
  end
  
  describe :authorization do
    before do
      @p1 = Factory :project
      @p2 = Factory :project, :code => "alien", :path => "legit_1"
      @u1 = Factory :user
      @u2 = Factory :user
      @u3 = Factory :user
      @abilities = Six.new
      @abilities << Ability
    end
    describe :read do
      before do
        @p1.users_projects.create(:user => @u1, :read => false)
        @p1.users_projects.create(:user => @u2, :read => true)
        @p2.users_projects.create(:user => @u3, :read => true)
      end
      it { @abilities.allowed?(@u1, :read_note, @p1).should be_false }
      it { @abilities.allowed?(@u2, :read_note, @p1).should be_true }
      it { @abilities.allowed?(@u3, :read_note, @p1).should be_false }
    end
    describe :write do
      before do
        @p1.users_projects.create(:user => @u1, :write => false)
        @p1.users_projects.create(:user => @u2, :write => true)
        @p2.users_projects.create(:user => @u3, :write => true)
      end
      it { @abilities.allowed?(@u1, :write_note, @p1).should be_false }
      it { @abilities.allowed?(@u2, :write_note, @p1).should be_true }
      it { @abilities.allowed?(@u3, :write_note, @p1).should be_false }
    end
    describe :admin do
      before do
        @p1.users_projects.create(:user => @u1, :admin => false)
        @p1.users_projects.create(:user => @u2, :admin => true)
        @p2.users_projects.create(:user => @u3, :admin => true)
      end
      it { @abilities.allowed?(@u1, :admin_note, @p1).should be_false }
      it { @abilities.allowed?(@u2, :admin_note, @p1).should be_true }
      it { @abilities.allowed?(@u3, :admin_note, @p1).should be_false }
    end
  end
end
# == Schema Information
#
# Table name: notes
#
#  id            :integer         not null, primary key
#  note          :text
#  noteable_id   :string(255)
#  noteable_type :string(255)
#  author_id     :integer
#  created_at    :datetime
#  updated_at    :datetime
#  project_id    :integer
#  attachment    :string(255)
#