summaryrefslogtreecommitdiff
path: root/app/models/members
diff options
context:
space:
mode:
authorLong Nguyen <long.polyglot@gmail.com>2016-05-21 00:37:48 +0700
committerLong Nguyen <long.polyglot@gmail.com>2016-05-21 00:37:48 +0700
commitad17741008b5ec874f92016ed48c2c1e6638dab5 (patch)
tree0bc4256bcb79945ea573aebf6a5ca99e6acc6faf /app/models/members
parented9b6497865e28c60e96dbc30567987165b0b221 (diff)
downloadgitlab-ce-ad17741008b5ec874f92016ed48c2c1e6638dab5.tar.gz
Remove todos when destroy project member and specs
Diffstat (limited to 'app/models/members')
-rw-r--r--app/models/members/project_member.rb4
1 files changed, 3 insertions, 1 deletions
diff --git a/app/models/members/project_member.rb b/app/models/members/project_member.rb
index 8dae3bb2ef2..0ced9c31581 100644
--- a/app/models/members/project_member.rb
+++ b/app/models/members/project_member.rb
@@ -3,9 +3,9 @@ class ProjectMember < Member
include Gitlab::ShellAdapter
+ has_many :todos, through: :user
belongs_to :project, class_name: 'Project', foreign_key: 'source_id'
-
# Make sure project member points only to project as it source
default_value_for :source_type, SOURCE_TYPE
validates_format_of :source_type, with: /\AProject\z/
@@ -15,6 +15,8 @@ class ProjectMember < Member
scope :in_projects, ->(projects) { where(source_id: projects.pluck(:id)) }
scope :with_user, ->(user) { where(user_id: user.id) }
+ before_destroy { todos.each(&:destroy) }
+
class << self
# Add users to project teams with passed access option