diff options
| author | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-09-14 17:54:10 +0300 |
|---|---|---|
| committer | Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com> | 2014-09-14 17:54:10 +0300 |
| commit | 757426dbb18b5c62670b6090d6fed25fc71528a1 (patch) | |
| tree | a89f77d43d529e387ea39643c066364eb62ce234 | |
| parent | 3503b504eabf95487fc3fb49df953a7d694da4fe (diff) | |
| download | gitlab-ce-757426dbb18b5c62670b6090d6fed25fc71528a1.tar.gz | |
Add Member AR model
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
| -rw-r--r-- | app/models/member.rb | 18 | ||||
| -rw-r--r-- | spec/models/members_spec.rb | 15 |
2 files changed, 33 insertions, 0 deletions
diff --git a/app/models/member.rb b/app/models/member.rb new file mode 100644 index 00000000000..13827db175b --- /dev/null +++ b/app/models/member.rb @@ -0,0 +1,18 @@ +class Member < ActiveRecord::Base + include Notifiable + include Gitlab::Access + + belongs_to :user + belongs_to :source, polymorphic: true + + validates :user, presence: true + validates :source, presence: true + validates :user_id, uniqueness: { scope: [:source_type, :source_id], message: "already exists in source" } + validates :access_level, inclusion: { in: Gitlab::Access.values }, presence: true + + scope :guests, -> { where(group_access: GUEST) } + scope :reporters, -> { where(group_access: REPORTER) } + scope :developers, -> { where(group_access: DEVELOPER) } + scope :masters, -> { where(group_access: MASTER) } + scope :owners, -> { where(group_access: OWNER) } +end diff --git a/spec/models/members_spec.rb b/spec/models/members_spec.rb new file mode 100644 index 00000000000..33e97686654 --- /dev/null +++ b/spec/models/members_spec.rb @@ -0,0 +1,15 @@ +require 'spec_helper' + +describe Member do + describe "Associations" do + it { should belong_to(:user) } + end + + describe "Validation" do + subject { Member.new(access_level: Member::GUEST) } + + it { should validate_presence_of(:user) } + it { should validate_presence_of(:source) } + it { should ensure_inclusion_of(:access_level).in_array(Gitlab::Access.values) } + end +end |
