summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2014-09-14 17:54:10 +0300
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2014-09-14 17:54:10 +0300
commit757426dbb18b5c62670b6090d6fed25fc71528a1 (patch)
treea89f77d43d529e387ea39643c066364eb62ce234
parent3503b504eabf95487fc3fb49df953a7d694da4fe (diff)
downloadgitlab-ce-757426dbb18b5c62670b6090d6fed25fc71528a1.tar.gz
Add Member AR model
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
-rw-r--r--app/models/member.rb18
-rw-r--r--spec/models/members_spec.rb15
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