Allows multiple roles on the same project (#706). Prerequisite for user groups feature.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2726 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
814e138c2a
commit
7dccf9fda6
|
@ -38,10 +38,6 @@ class ApplicationController < ActionController::Base
|
||||||
require_dependency "repository/#{scm.underscore}"
|
require_dependency "repository/#{scm.underscore}"
|
||||||
end
|
end
|
||||||
|
|
||||||
def current_role
|
|
||||||
@current_role ||= User.current.role_for_project(@project)
|
|
||||||
end
|
|
||||||
|
|
||||||
def user_setup
|
def user_setup
|
||||||
# Check the settings cache for each request
|
# Check the settings cache for each request
|
||||||
Setting.check_cache
|
Setting.check_cache
|
||||||
|
|
|
@ -146,7 +146,7 @@ class IssuesController < ApplicationController
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@issue.status = default_status
|
@issue.status = default_status
|
||||||
@allowed_statuses = ([default_status] + default_status.find_new_statuses_allowed_to(User.current.role_for_project(@project), @issue.tracker)).uniq
|
@allowed_statuses = ([default_status] + default_status.find_new_statuses_allowed_to(User.current.roles_for_project(@project), @issue.tracker)).uniq
|
||||||
|
|
||||||
if request.get? || request.xhr?
|
if request.get? || request.xhr?
|
||||||
@issue.start_date ||= Date.today
|
@issue.start_date ||= Date.today
|
||||||
|
|
|
@ -48,7 +48,12 @@ class MembersController < ApplicationController
|
||||||
if request.post? and @member.update_attributes(params[:member])
|
if request.post? and @member.update_attributes(params[:member])
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project }
|
format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project }
|
||||||
format.js { render(:update) {|page| page.replace_html "tab-content-members", :partial => 'projects/settings/members'} }
|
format.js {
|
||||||
|
render(:update) {|page|
|
||||||
|
page.replace_html "tab-content-members", :partial => 'projects/settings/members'
|
||||||
|
page.visual_effect(:highlight, "member-#{@member.id}")
|
||||||
|
}
|
||||||
|
}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -112,7 +112,7 @@ class ProjectsController < ApplicationController
|
||||||
redirect_to_project_menu_item(@project, params[:jump]) && return
|
redirect_to_project_menu_item(@project, params[:jump]) && return
|
||||||
end
|
end
|
||||||
|
|
||||||
@members_by_role = @project.members.find(:all, :include => [:user, :role], :order => 'position').group_by {|m| m.role}
|
@members_by_role = @project.members.find(:all, :include => [:user, :roles], :order => 'position').group_by {|m| m.roles.first}
|
||||||
@subprojects = @project.children.visible
|
@subprojects = @project.children.visible
|
||||||
@news = @project.news.find(:all, :limit => 5, :include => [ :author, :project ], :order => "#{News.table_name}.created_on DESC")
|
@news = @project.news.find(:all, :limit => 5, :include => [ :author, :project ], :order => "#{News.table_name}.created_on DESC")
|
||||||
@trackers = @project.rolled_up_trackers
|
@trackers = @project.rolled_up_trackers
|
||||||
|
|
|
@ -24,7 +24,7 @@ class QueriesController < ApplicationController
|
||||||
@query = Query.new(params[:query])
|
@query = Query.new(params[:query])
|
||||||
@query.project = params[:query_is_for_all] ? nil : @project
|
@query.project = params[:query_is_for_all] ? nil : @project
|
||||||
@query.user = User.current
|
@query.user = User.current
|
||||||
@query.is_public = false unless (@query.project && current_role.allowed_to?(:manage_public_queries)) || User.current.admin?
|
@query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin?
|
||||||
@query.column_names = nil if params[:default_columns]
|
@query.column_names = nil if params[:default_columns]
|
||||||
|
|
||||||
params[:fields].each do |field|
|
params[:fields].each do |field|
|
||||||
|
@ -48,7 +48,7 @@ class QueriesController < ApplicationController
|
||||||
end if params[:fields]
|
end if params[:fields]
|
||||||
@query.attributes = params[:query]
|
@query.attributes = params[:query]
|
||||||
@query.project = nil if params[:query_is_for_all]
|
@query.project = nil if params[:query_is_for_all]
|
||||||
@query.is_public = false unless (@query.project && current_role.allowed_to?(:manage_public_queries)) || User.current.admin?
|
@query.is_public = false unless User.current.allowed_to?(:manage_public_queries, @project) || User.current.admin?
|
||||||
@query.column_names = nil if params[:default_columns]
|
@query.column_names = nil if params[:default_columns]
|
||||||
|
|
||||||
if @query.save
|
if @query.save
|
||||||
|
|
|
@ -40,7 +40,7 @@ class RolesController < ApplicationController
|
||||||
@role.workflows.copy(copy_from)
|
@role.workflows.copy(copy_from)
|
||||||
end
|
end
|
||||||
flash[:notice] = l(:notice_successful_create)
|
flash[:notice] = l(:notice_successful_create)
|
||||||
redirect_to :action => 'list'
|
redirect_to :action => 'index'
|
||||||
end
|
end
|
||||||
@permissions = @role.setable_permissions
|
@permissions = @role.setable_permissions
|
||||||
@roles = Role.find :all, :order => 'builtin, position'
|
@roles = Role.find :all, :order => 'builtin, position'
|
||||||
|
@ -50,7 +50,7 @@ class RolesController < ApplicationController
|
||||||
@role = Role.find(params[:id])
|
@role = Role.find(params[:id])
|
||||||
if request.post? and @role.update_attributes(params[:role])
|
if request.post? and @role.update_attributes(params[:role])
|
||||||
flash[:notice] = l(:notice_successful_update)
|
flash[:notice] = l(:notice_successful_update)
|
||||||
redirect_to :action => 'list'
|
redirect_to :action => 'index'
|
||||||
end
|
end
|
||||||
@permissions = @role.setable_permissions
|
@permissions = @role.setable_permissions
|
||||||
end
|
end
|
||||||
|
@ -58,7 +58,7 @@ class RolesController < ApplicationController
|
||||||
def destroy
|
def destroy
|
||||||
@role = Role.find(params[:id])
|
@role = Role.find(params[:id])
|
||||||
@role.destroy
|
@role.destroy
|
||||||
redirect_to :action => 'list'
|
redirect_to :action => 'index'
|
||||||
rescue
|
rescue
|
||||||
flash[:error] = 'This role is in use and can not be deleted.'
|
flash[:error] = 'This role is in use and can not be deleted.'
|
||||||
redirect_to :action => 'index'
|
redirect_to :action => 'index'
|
||||||
|
@ -73,7 +73,7 @@ class RolesController < ApplicationController
|
||||||
role.save
|
role.save
|
||||||
end
|
end
|
||||||
flash[:notice] = l(:notice_successful_update)
|
flash[:notice] = l(:notice_successful_update)
|
||||||
redirect_to :action => 'list'
|
redirect_to :action => 'index'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -86,10 +86,7 @@ class UsersController < ApplicationController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@auth_sources = AuthSource.find(:all)
|
@auth_sources = AuthSource.find(:all)
|
||||||
@roles = Role.find_all_givable
|
|
||||||
@projects = Project.active.find(:all, :order => 'lft')
|
|
||||||
@membership ||= Member.new
|
@membership ||= Member.new
|
||||||
@memberships = @user.memberships
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def edit_membership
|
def edit_membership
|
||||||
|
@ -97,12 +94,23 @@ class UsersController < ApplicationController
|
||||||
@membership = params[:membership_id] ? Member.find(params[:membership_id]) : Member.new(:user => @user)
|
@membership = params[:membership_id] ? Member.find(params[:membership_id]) : Member.new(:user => @user)
|
||||||
@membership.attributes = params[:membership]
|
@membership.attributes = params[:membership]
|
||||||
@membership.save if request.post?
|
@membership.save if request.post?
|
||||||
redirect_to :action => 'edit', :id => @user, :tab => 'memberships'
|
respond_to do |format|
|
||||||
|
format.html { redirect_to :controller => 'users', :action => 'edit', :id => @user, :tab => 'memberships' }
|
||||||
|
format.js {
|
||||||
|
render(:update) {|page|
|
||||||
|
page.replace_html "tab-content-memberships", :partial => 'users/memberships'
|
||||||
|
page.visual_effect(:highlight, "member-#{@membership.id}")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy_membership
|
def destroy_membership
|
||||||
@user = User.find(params[:id])
|
@user = User.find(params[:id])
|
||||||
Member.find(params[:membership_id]).destroy if request.post?
|
Member.find(params[:membership_id]).destroy if request.post?
|
||||||
redirect_to :action => 'edit', :id => @user, :tab => 'memberships'
|
respond_to do |format|
|
||||||
|
format.html { redirect_to :controller => 'users', :action => 'edit', :id => @user, :tab => 'memberships' }
|
||||||
|
format.js { render(:update) {|page| page.replace_html "tab-content-memberships", :partial => 'users/memberships'} }
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -28,10 +28,6 @@ module ApplicationHelper
|
||||||
extend Forwardable
|
extend Forwardable
|
||||||
def_delegators :wiki_helper, :wikitoolbar_for, :heads_for_wiki_formatter
|
def_delegators :wiki_helper, :wikitoolbar_for, :heads_for_wiki_formatter
|
||||||
|
|
||||||
def current_role
|
|
||||||
@current_role ||= User.current.role_for_project(@project)
|
|
||||||
end
|
|
||||||
|
|
||||||
# Return true if user is authorized for controller/action, otherwise false
|
# Return true if user is authorized for controller/action, otherwise false
|
||||||
def authorize_for(controller, action)
|
def authorize_for(controller, action)
|
||||||
User.current.allowed_to?({:controller => controller, :action => action}, @project)
|
User.current.allowed_to?({:controller => controller, :action => action}, @project)
|
||||||
|
|
|
@ -205,7 +205,7 @@ class Issue < ActiveRecord::Base
|
||||||
|
|
||||||
# Returns an array of status that user is able to apply
|
# Returns an array of status that user is able to apply
|
||||||
def new_statuses_allowed_to(user)
|
def new_statuses_allowed_to(user)
|
||||||
statuses = status.find_new_statuses_allowed_to(user.role_for_project(project), tracker)
|
statuses = status.find_new_statuses_allowed_to(user.roles_for_project(project), tracker)
|
||||||
statuses << status unless statuses.empty?
|
statuses << status unless statuses.empty?
|
||||||
statuses.uniq.sort
|
statuses.uniq.sort
|
||||||
end
|
end
|
||||||
|
|
|
@ -36,24 +36,34 @@ class IssueStatus < ActiveRecord::Base
|
||||||
|
|
||||||
# Returns an array of all statuses the given role can switch to
|
# Returns an array of all statuses the given role can switch to
|
||||||
# Uses association cache when called more than one time
|
# Uses association cache when called more than one time
|
||||||
def new_statuses_allowed_to(role, tracker)
|
def new_statuses_allowed_to(roles, tracker)
|
||||||
new_statuses = workflows.select {|w| w.role_id == role.id && w.tracker_id == tracker.id}.collect{|w| w.new_status} if role && tracker
|
if roles && tracker
|
||||||
new_statuses ? new_statuses.compact.sort{|x, y| x.position <=> y.position } : []
|
role_ids = roles.collect(&:id)
|
||||||
|
new_statuses = workflows.select {|w| role_ids.include?(w.role_id) && w.tracker_id == tracker.id}.collect{|w| w.new_status}.compact.sort
|
||||||
|
else
|
||||||
|
[]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Same thing as above but uses a database query
|
# Same thing as above but uses a database query
|
||||||
# More efficient than the previous method if called just once
|
# More efficient than the previous method if called just once
|
||||||
def find_new_statuses_allowed_to(role, tracker)
|
def find_new_statuses_allowed_to(roles, tracker)
|
||||||
new_statuses = workflows.find(:all,
|
if roles && tracker
|
||||||
:include => :new_status,
|
workflows.find(:all,
|
||||||
:conditions => ["role_id=? and tracker_id=?", role.id, tracker.id]).collect{ |w| w.new_status }.compact if role && tracker
|
:include => :new_status,
|
||||||
new_statuses ? new_statuses.sort{|x, y| x.position <=> y.position } : []
|
:conditions => { :role_id => roles.collect(&:id),
|
||||||
|
:tracker_id => tracker.id}).collect{ |w| w.new_status }.compact.sort
|
||||||
|
else
|
||||||
|
[]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def new_status_allowed_to?(status, role, tracker)
|
def new_status_allowed_to?(status, roles, tracker)
|
||||||
status && role && tracker ?
|
if status && roles && tracker
|
||||||
!workflows.find(:first, :conditions => {:new_status_id => status.id, :role_id => role.id, :tracker_id => tracker.id}).nil? :
|
!workflows.find(:first, :conditions => {:new_status_id => status.id, :role_id => roles.collect(&:id), :tracker_id => tracker.id}).nil?
|
||||||
|
else
|
||||||
false
|
false
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def <=>(status)
|
def <=>(status)
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
# redMine - project management software
|
# Redmine - project management software
|
||||||
# Copyright (C) 2006 Jean-Philippe Lang
|
# Copyright (C) 2006-2009 Jean-Philippe Lang
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or
|
# This program is free software; you can redistribute it and/or
|
||||||
# modify it under the terms of the GNU General Public License
|
# modify it under the terms of the GNU General Public License
|
||||||
|
@ -17,15 +17,12 @@
|
||||||
|
|
||||||
class Member < ActiveRecord::Base
|
class Member < ActiveRecord::Base
|
||||||
belongs_to :user
|
belongs_to :user
|
||||||
belongs_to :role
|
has_many :member_roles, :dependent => :delete_all
|
||||||
|
has_many :roles, :through => :member_roles
|
||||||
belongs_to :project
|
belongs_to :project
|
||||||
|
|
||||||
validates_presence_of :role, :user, :project
|
validates_presence_of :user, :project
|
||||||
validates_uniqueness_of :user_id, :scope => :project_id
|
validates_uniqueness_of :user_id, :scope => :project_id
|
||||||
|
|
||||||
def validate
|
|
||||||
errors.add :role_id, :invalid if role && !role.member?
|
|
||||||
end
|
|
||||||
|
|
||||||
def name
|
def name
|
||||||
self.user.name
|
self.user.name
|
||||||
|
@ -42,11 +39,18 @@ class Member < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
|
|
||||||
def <=>(member)
|
def <=>(member)
|
||||||
role == member.role ? (user <=> member.user) : (role <=> member.role)
|
a, b = roles.sort.first, member.roles.sort.first
|
||||||
|
a == b ? (user <=> member.user) : (a <=> b)
|
||||||
end
|
end
|
||||||
|
|
||||||
def before_destroy
|
def before_destroy
|
||||||
# remove category based auto assignments for this member
|
# remove category based auto assignments for this member
|
||||||
IssueCategory.update_all "assigned_to_id = NULL", ["project_id = ? AND assigned_to_id = ?", project.id, user.id]
|
IssueCategory.update_all "assigned_to_id = NULL", ["project_id = ? AND assigned_to_id = ?", project.id, user.id]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
protected
|
||||||
|
|
||||||
|
def validate
|
||||||
|
errors.add_to_base "Role can't be blank" if roles.empty?
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,27 @@
|
||||||
|
# Redmine - project management software
|
||||||
|
# Copyright (C) 2006-2009 Jean-Philippe Lang
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License
|
||||||
|
# as published by the Free Software Foundation; either version 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
|
class MemberRole < ActiveRecord::Base
|
||||||
|
belongs_to :member
|
||||||
|
belongs_to :role
|
||||||
|
|
||||||
|
validates_presence_of :role
|
||||||
|
|
||||||
|
def validate
|
||||||
|
errors.add :role_id, :invalid if role && !role.member?
|
||||||
|
end
|
||||||
|
end
|
|
@ -135,7 +135,7 @@ class Project < ActiveRecord::Base
|
||||||
statements << "1=0"
|
statements << "1=0"
|
||||||
if user.logged?
|
if user.logged?
|
||||||
statements << "#{Project.table_name}.is_public = #{connection.quoted_true}" if Role.non_member.allowed_to?(permission)
|
statements << "#{Project.table_name}.is_public = #{connection.quoted_true}" if Role.non_member.allowed_to?(permission)
|
||||||
allowed_project_ids = user.memberships.select {|m| m.role.allowed_to?(permission)}.collect {|m| m.project_id}
|
allowed_project_ids = user.memberships.select {|m| m.roles.detect {|role| role.allowed_to?(permission)}}.collect {|m| m.project_id}
|
||||||
statements << "#{Project.table_name}.id IN (#{allowed_project_ids.join(',')})" if allowed_project_ids.any?
|
statements << "#{Project.table_name}.id IN (#{allowed_project_ids.join(',')})" if allowed_project_ids.any?
|
||||||
elsif Role.anonymous.allowed_to?(permission)
|
elsif Role.anonymous.allowed_to?(permission)
|
||||||
# anonymous user allowed on public project
|
# anonymous user allowed on public project
|
||||||
|
@ -247,12 +247,14 @@ class Project < ActiveRecord::Base
|
||||||
|
|
||||||
# Deletes all project's members
|
# Deletes all project's members
|
||||||
def delete_all_members
|
def delete_all_members
|
||||||
|
me, mr = Member.table_name, MemberRole.table_name
|
||||||
|
connection.delete("DELETE FROM #{mr} WHERE #{mr}.member_id IN (SELECT #{me}.id FROM #{me} WHERE #{me}.project_id = #{id})")
|
||||||
Member.delete_all(['project_id = ?', id])
|
Member.delete_all(['project_id = ?', id])
|
||||||
end
|
end
|
||||||
|
|
||||||
# Users issues can be assigned to
|
# Users issues can be assigned to
|
||||||
def assignable_users
|
def assignable_users
|
||||||
members.select {|m| m.role.assignable?}.collect {|m| m.user}.sort
|
members.select {|m| m.roles.detect {|role| role.assignable?}}.collect {|m| m.user}.sort
|
||||||
end
|
end
|
||||||
|
|
||||||
# Returns the mail adresses of users that should be always notified on project events
|
# Returns the mail adresses of users that should be always notified on project events
|
||||||
|
|
|
@ -38,7 +38,8 @@ class Role < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
has_many :members
|
has_many :member_roles, :dependent => :destroy
|
||||||
|
has_many :members, :through => :member_roles
|
||||||
acts_as_list
|
acts_as_list
|
||||||
|
|
||||||
serialize :permissions, Array
|
serialize :permissions, Array
|
||||||
|
@ -82,7 +83,11 @@ class Role < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
|
|
||||||
def <=>(role)
|
def <=>(role)
|
||||||
position <=> role.position
|
role ? position <=> role.position : -1
|
||||||
|
end
|
||||||
|
|
||||||
|
def to_s
|
||||||
|
name
|
||||||
end
|
end
|
||||||
|
|
||||||
# Return true if the role is a builtin role
|
# Return true if the role is a builtin role
|
||||||
|
|
|
@ -33,7 +33,7 @@ class User < ActiveRecord::Base
|
||||||
:username => '#{login}'
|
:username => '#{login}'
|
||||||
}
|
}
|
||||||
|
|
||||||
has_many :memberships, :class_name => 'Member', :include => [ :project, :role ], :conditions => "#{Project.table_name}.status=#{Project::STATUS_ACTIVE}", :order => "#{Project.table_name}.name"
|
has_many :memberships, :class_name => 'Member', :include => [ :project, :roles ], :conditions => "#{Project.table_name}.status=#{Project::STATUS_ACTIVE}", :order => "#{Project.table_name}.name"
|
||||||
has_many :members, :dependent => :delete_all
|
has_many :members, :dependent => :delete_all
|
||||||
has_many :projects, :through => :memberships
|
has_many :projects, :through => :memberships
|
||||||
has_many :issue_categories, :foreign_key => 'assigned_to_id', :dependent => :nullify
|
has_many :issue_categories, :foreign_key => 'assigned_to_id', :dependent => :nullify
|
||||||
|
@ -229,26 +229,30 @@ class User < ActiveRecord::Base
|
||||||
!logged?
|
!logged?
|
||||||
end
|
end
|
||||||
|
|
||||||
# Return user's role for project
|
# Return user's roles for project
|
||||||
def role_for_project(project)
|
def roles_for_project(project)
|
||||||
|
roles = []
|
||||||
# No role on archived projects
|
# No role on archived projects
|
||||||
return nil unless project && project.active?
|
return roles unless project && project.active?
|
||||||
if logged?
|
if logged?
|
||||||
# Find project membership
|
# Find project membership
|
||||||
membership = memberships.detect {|m| m.project_id == project.id}
|
membership = memberships.detect {|m| m.project_id == project.id}
|
||||||
if membership
|
if membership
|
||||||
membership.role
|
roles = membership.roles
|
||||||
else
|
else
|
||||||
@role_non_member ||= Role.non_member
|
@role_non_member ||= Role.non_member
|
||||||
|
roles << @role_non_member
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
@role_anonymous ||= Role.anonymous
|
@role_anonymous ||= Role.anonymous
|
||||||
|
roles << @role_anonymous
|
||||||
end
|
end
|
||||||
|
roles
|
||||||
end
|
end
|
||||||
|
|
||||||
# Return true if the user is a member of project
|
# Return true if the user is a member of project
|
||||||
def member_of?(project)
|
def member_of?(project)
|
||||||
role_for_project(project).member?
|
!roles_for_project(project).detect {|role| role.member?}.nil?
|
||||||
end
|
end
|
||||||
|
|
||||||
# Return true if the user is allowed to do the specified action on project
|
# Return true if the user is allowed to do the specified action on project
|
||||||
|
@ -264,13 +268,13 @@ class User < ActiveRecord::Base
|
||||||
# Admin users are authorized for anything else
|
# Admin users are authorized for anything else
|
||||||
return true if admin?
|
return true if admin?
|
||||||
|
|
||||||
role = role_for_project(project)
|
roles = roles_for_project(project)
|
||||||
return false unless role
|
return false unless roles
|
||||||
role.allowed_to?(action) && (project.is_public? || role.member?)
|
roles.detect {|role| (project.is_public? || role.member?) && role.allowed_to?(action)}
|
||||||
|
|
||||||
elsif options[:global]
|
elsif options[:global]
|
||||||
# authorize if user has at least one role that has this permission
|
# authorize if user has at least one role that has this permission
|
||||||
roles = memberships.collect {|m| m.role}.uniq
|
roles = memberships.collect {|m| m.roles}.flatten.uniq
|
||||||
roles.detect {|r| r.allowed_to?(action)} || (self.logged? ? Role.non_member.allowed_to?(action) : Role.anonymous.allowed_to?(action))
|
roles.detect {|r| r.allowed_to?(action)} || (self.logged? ? Role.non_member.allowed_to?(action) : Role.anonymous.allowed_to?(action))
|
||||||
else
|
else
|
||||||
false
|
false
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
<ul>
|
<ul>
|
||||||
<% for membership in @memberships %>
|
<% for membership in @memberships %>
|
||||||
<li><%= link_to(h(membership.project.name), :controller => 'projects', :action => 'show', :id => membership.project) %>
|
<li><%= link_to(h(membership.project.name), :controller => 'projects', :action => 'show', :id => membership.project) %>
|
||||||
(<%=h membership.role.name %>, <%= format_date(membership.created_on) %>)</li>
|
(<%=h membership.roles.collect(&:to_s).join(', ') %>, <%= format_date(membership.created_on) %>)</li>
|
||||||
<% end %>
|
<% end %>
|
||||||
</ul>
|
</ul>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
|
@ -1,36 +1,43 @@
|
||||||
<%= error_messages_for 'member' %>
|
<%= error_messages_for 'member' %>
|
||||||
<% roles = Role.find_all_givable
|
<% roles = Role.find_all_givable
|
||||||
members = @project.members.find(:all, :include => [:role, :user]).sort %>
|
members = @project.members.find(:all, :include => [:roles, :user]).sort %>
|
||||||
|
|
||||||
<div class="splitcontentleft">
|
<div class="splitcontentleft">
|
||||||
<% if members.any? %>
|
<% if members.any? %>
|
||||||
<table class="list">
|
<table class="list members">
|
||||||
<thead>
|
<thead>
|
||||||
<th><%= l(:label_user) %></th>
|
<th><%= l(:label_user) %></th>
|
||||||
<th><%= l(:label_role) %></th>
|
<th><%= l(:label_role_plural) %></th>
|
||||||
<th style="width:15%"></th>
|
<th style="width:15%"></th>
|
||||||
<%= call_hook(:view_projects_settings_members_table_header, :project => @project) %>
|
<%= call_hook(:view_projects_settings_members_table_header, :project => @project) %>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<% members.each do |member| %>
|
<% members.each do |member| %>
|
||||||
<% next if member.new_record? %>
|
<% next if member.new_record? %>
|
||||||
<tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %>">
|
<tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member">
|
||||||
<td><%=h member.name %></td>
|
<td class="user"><%= link_to_user member.user %></td>
|
||||||
<td align="center">
|
<td class="roles">
|
||||||
|
<span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
||||||
<% if authorize_for('members', 'edit') %>
|
<% if authorize_for('members', 'edit') %>
|
||||||
<% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member}, :method => :post) do |f| %>
|
<% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
|
||||||
<%= f.select :role_id, roles.collect{|role| [role.name, role.id]}, {}, :class => "small" %>
|
:method => :post,
|
||||||
<%= submit_tag l(:button_change), :class => "small" %>
|
:html => { :id => "member-#{member.id}-roles-form", :style => 'display:none;' }) do |f| %>
|
||||||
|
<p><% roles.each do |role| %>
|
||||||
|
<label><%= check_box_tag 'member[role_ids][]', role.id, member.roles.include?(role) %> <%=h role %></label><br />
|
||||||
|
<% end %></p>
|
||||||
|
<p><%= submit_tag l(:button_change), :class => "small" %>
|
||||||
|
<%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
<% end %>
|
||||||
</td>
|
</td>
|
||||||
<td align="center">
|
<td class="buttons">
|
||||||
|
<%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
|
||||||
<%= link_to_remote l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
|
<%= link_to_remote l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
|
||||||
:method => :post
|
:method => :post
|
||||||
}, :title => l(:button_delete),
|
}, :title => l(:button_delete),
|
||||||
:class => 'icon icon-del' %>
|
:class => 'icon icon-del' %>
|
||||||
</td>
|
</td>
|
||||||
<%= call_hook(:view_projects_settings_members_table_row, { :project => @project, :member => member}) %>
|
<%= call_hook(:view_projects_settings_members_table_row, { :project => @project, :member => member}) %>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
<% end; reset_cycle %>
|
<% end; reset_cycle %>
|
||||||
|
@ -58,8 +65,11 @@
|
||||||
<% end -%>
|
<% end -%>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
<p><%= l(:label_role) %>: <%= f.select :role_id, roles.collect{|role| [role.name, role.id]}, :selected => nil %>
|
<p><%= l(:label_role_plural) %>:
|
||||||
<%= submit_tag l(:button_add) %></p>
|
<% roles.each do |role| %>
|
||||||
|
<label><%= check_box_tag 'member[role_ids][]', role.id %> <%=h role %></label>
|
||||||
|
<% end %></p>
|
||||||
|
<p><%= submit_tag l(:button_add) %></p>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<p><label for="query_name"><%=l(:field_name)%></label>
|
<p><label for="query_name"><%=l(:field_name)%></label>
|
||||||
<%= text_field 'query', 'name', :size => 80 %></p>
|
<%= text_field 'query', 'name', :size => 80 %></p>
|
||||||
|
|
||||||
<% if User.current.admin? || (@project && current_role.allowed_to?(:manage_public_queries)) %>
|
<% if User.current.admin? || User.current.allowed_to?(:manage_public_queries, @project) %>
|
||||||
<p><label for="query_is_public"><%=l(:field_is_public)%></label>
|
<p><label for="query_is_public"><%=l(:field_is_public)%></label>
|
||||||
<%= check_box 'query', 'is_public',
|
<%= check_box 'query', 'is_public',
|
||||||
:onchange => (User.current.admin? ? nil : 'if (this.checked) {$("query_is_for_all").checked = false; $("query_is_for_all").disabled = true;} else {$("query_is_for_all").disabled = false;}') %></p>
|
:onchange => (User.current.admin? ? nil : 'if (this.checked) {$("query_is_for_all").checked = false; $("query_is_for_all").disabled = true;} else {$("query_is_for_all").disabled = false;}') %></p>
|
||||||
|
|
|
@ -1,24 +1,36 @@
|
||||||
<% if @memberships.any? %>
|
<% roles = Role.find_all_givable %>
|
||||||
|
<% projects = Project.active.find(:all, :order => 'lft') %>
|
||||||
|
|
||||||
|
<div class="splitcontentleft">
|
||||||
|
<% if @user.memberships.any? %>
|
||||||
<table class="list memberships">
|
<table class="list memberships">
|
||||||
<thead>
|
<thead>
|
||||||
<th><%= l(:label_project) %></th>
|
<th><%= l(:label_project) %></th>
|
||||||
<th><%= l(:label_role) %></th>
|
<th><%= l(:label_role_plural) %></th>
|
||||||
<th style="width:15%"></th>
|
<th style="width:15%"></th>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<% @memberships.each do |membership| %>
|
<% @user.memberships.each do |membership| %>
|
||||||
<% next if membership.new_record? %>
|
<% next if membership.new_record? %>
|
||||||
<tr class="<%= cycle 'odd', 'even' %>">
|
<tr id="member-<%= membership.id %>" class="<%= cycle 'odd', 'even' %> class">
|
||||||
<td><%=h membership.project %></td>
|
<td class="project"><%=h membership.project %></td>
|
||||||
<td align="center">
|
<td class="roles">
|
||||||
<% form_tag({ :action => 'edit_membership', :id => @user, :membership_id => membership }) do %>
|
<span id="member-<%= membership.id %>-roles"><%=h membership.roles.sort.collect(&:to_s).join(', ') %></span>
|
||||||
<%= select_tag 'membership[role_id]', options_from_collection_for_select(@roles, "id", "name", membership.role_id) %>
|
<% remote_form_for(:membership, :url => { :action => 'edit_membership', :id => @user, :membership_id => membership },
|
||||||
<%= submit_tag l(:button_change), :class => "small" %>
|
:html => { :id => "member-#{membership.id}-roles-form", :style => 'display:none;'}) do %>
|
||||||
|
<p><% roles.each do |role| %>
|
||||||
|
<label><%= check_box_tag 'membership[role_ids][]', role.id, membership.roles.include?(role) %> <%=h role %></label><br />
|
||||||
|
<% end %></p>
|
||||||
|
<p><%= submit_tag l(:button_change) %>
|
||||||
|
<%= link_to_function l(:button_cancel), "$('member-#{membership.id}-roles').show(); $('member-#{membership.id}-roles-form').hide(); return false;" %></p>
|
||||||
<% end %>
|
<% end %>
|
||||||
</td>
|
</td>
|
||||||
<td align="center">
|
<td class="buttons">
|
||||||
<%= link_to l(:button_delete), {:action => 'destroy_membership', :id => @user, :membership_id => membership }, :method => :post, :class => 'icon icon-del' %>
|
<%= link_to_function l(:button_edit), "$('member-#{membership.id}-roles').hide(); $('member-#{membership.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
|
||||||
</td>
|
<%= link_to_remote l(:button_delete), { :url => { :controller => 'users', :action => 'destroy_membership', :id => @user, :membership_id => membership },
|
||||||
|
:method => :post },
|
||||||
|
:class => 'icon icon-del' %>
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
<% end; reset_cycle %>
|
<% end; reset_cycle %>
|
||||||
|
@ -26,15 +38,19 @@
|
||||||
<% else %>
|
<% else %>
|
||||||
<p class="nodata"><%= l(:label_no_data) %></p>
|
<p class="nodata"><%= l(:label_no_data) %></p>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
||||||
<% if @projects.any? %>
|
<div class="splitcontentright">
|
||||||
<p>
|
<% if projects.any? %>
|
||||||
<label><%=l(:label_project_new)%></label><br/>
|
<fieldset><legend><%=l(:label_project_new)%></legend>
|
||||||
<% form_tag({ :action => 'edit_membership', :id => @user }) do %>
|
<% remote_form_for(:membership, :url => { :action => 'edit_membership', :id => @user }) do %>
|
||||||
<%= select_tag 'membership[project_id]', options_for_membership_project_select(@user, @projects) %>
|
<%= select_tag 'membership[project_id]', options_for_membership_project_select(@user, projects) %>
|
||||||
<%= l(:label_role) %>:
|
<p><%= l(:label_role_plural) %>:
|
||||||
<%= select_tag 'membership[role_id]', options_from_collection_for_select(@roles, "id", "name") %>
|
<% roles.each do |role| %>
|
||||||
<%= submit_tag l(:button_add) %>
|
<label><%= check_box_tag 'membership[role_ids][]', role.id %> <%=h role %></label>
|
||||||
|
<% end %></p>
|
||||||
|
<p><%= submit_tag l(:button_add) %></p>
|
||||||
<% end %>
|
<% end %>
|
||||||
</p>
|
</fieldset>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
|
@ -43,7 +43,7 @@
|
||||||
<% for old_status in @statuses %>
|
<% for old_status in @statuses %>
|
||||||
<tr class="<%= cycle("odd", "even") %>">
|
<tr class="<%= cycle("odd", "even") %>">
|
||||||
<td><%= old_status.name %></td>
|
<td><%= old_status.name %></td>
|
||||||
<% new_status_ids_allowed = old_status.find_new_statuses_allowed_to(@role, @tracker).collect(&:id) -%>
|
<% new_status_ids_allowed = old_status.find_new_statuses_allowed_to([@role], @tracker).collect(&:id) -%>
|
||||||
<% for new_status in @statuses -%>
|
<% for new_status in @statuses -%>
|
||||||
<td align="center">
|
<td align="center">
|
||||||
<input type="checkbox"
|
<input type="checkbox"
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
class CreateMemberRoles < ActiveRecord::Migration
|
||||||
|
def self.up
|
||||||
|
create_table :member_roles do |t|
|
||||||
|
t.column :member_id, :integer, :null => false
|
||||||
|
t.column :role_id, :integer, :null => false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.down
|
||||||
|
drop_table :member_roles
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,11 @@
|
||||||
|
class PopulateMemberRoles < ActiveRecord::Migration
|
||||||
|
def self.up
|
||||||
|
Member.find(:all).each do |member|
|
||||||
|
MemberRole.create!(:member_id => member.id, :role_id => member.role_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.down
|
||||||
|
MemberRole.delete_all
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,9 @@
|
||||||
|
class DropMembersRoleId < ActiveRecord::Migration
|
||||||
|
def self.up
|
||||||
|
remove_column :members, :role_id
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.down
|
||||||
|
raise IrreversibleMigration
|
||||||
|
end
|
||||||
|
end
|
|
@ -87,6 +87,8 @@ table.list th { background-color:#EEEEEE; padding: 4px; white-space:nowrap; }
|
||||||
table.list td { vertical-align: top; }
|
table.list td { vertical-align: top; }
|
||||||
table.list td.id { width: 2%; text-align: center;}
|
table.list td.id { width: 2%; text-align: center;}
|
||||||
table.list td.checkbox { width: 15px; padding: 0px;}
|
table.list td.checkbox { width: 15px; padding: 0px;}
|
||||||
|
table.list td.buttons { width: 15%; white-space:nowrap; text-align: right; }
|
||||||
|
table.list td.buttons a { padding-right: 0.6em; }
|
||||||
|
|
||||||
tr.project td.name a { padding-left: 16px; white-space:nowrap; }
|
tr.project td.name a { padding-left: 16px; white-space:nowrap; }
|
||||||
tr.project.parent td.name a { background: url('../images/bullet_toggle_minus.png') no-repeat; }
|
tr.project.parent td.name a { background: url('../images/bullet_toggle_minus.png') no-repeat; }
|
||||||
|
@ -114,6 +116,8 @@ table.files tr.file td { text-align: center; }
|
||||||
table.files tr.file td.filename { text-align: left; padding-left: 24px; }
|
table.files tr.file td.filename { text-align: left; padding-left: 24px; }
|
||||||
table.files tr.file td.digest { font-size: 80%; }
|
table.files tr.file td.digest { font-size: 80%; }
|
||||||
|
|
||||||
|
table.members td.roles, table.memberships td.roles { width: 45%; }
|
||||||
|
|
||||||
tr.message { height: 2.6em; }
|
tr.message { height: 2.6em; }
|
||||||
tr.message td.last_message { font-size: 80%; }
|
tr.message td.last_message { font-size: 80%; }
|
||||||
tr.message.locked td.subject a { background-image: url(../images/locked.png); }
|
tr.message.locked td.subject a { background-image: url(../images/locked.png); }
|
||||||
|
@ -333,11 +337,11 @@ p.other-formats { text-align: right; font-size:0.9em; color: #666; }
|
||||||
a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
|
a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
|
||||||
|
|
||||||
/* Project members tab */
|
/* Project members tab */
|
||||||
div#tab-content-members .splitcontentleft { width: 64% }
|
div#tab-content-members .splitcontentleft, div#tab-content-memberships .splitcontentleft { width: 64% }
|
||||||
div#tab-content-members .splitcontentright { width: 34% }
|
div#tab-content-members .splitcontentright, div#tab-content-memberships .splitcontentright { width: 34% }
|
||||||
div#tab-content-members fieldset { padding:1em; margin-bottom: 1em; }
|
div#tab-content-members fieldset, div#tab-content-memberships fieldset { padding:1em; margin-bottom: 1em; }
|
||||||
div#tab-content-members fieldset legend { font-weight: bold; }
|
div#tab-content-members fieldset legend, div#tab-content-memberships fieldset legend { font-weight: bold; }
|
||||||
div#tab-content-members fieldset label { display: block; }
|
div#tab-content-members fieldset label, div#tab-content-memberships fieldset label { display: block; }
|
||||||
div#tab-content-members fieldset div { max-height: 400px; overflow:auto; }
|
div#tab-content-members fieldset div { max-height: 400px; overflow:auto; }
|
||||||
|
|
||||||
* html div#tab-content-members fieldset div { height: 450px; }
|
* html div#tab-content-members fieldset div { height: 450px; }
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
---
|
||||||
|
member_roles_001:
|
||||||
|
id: 1
|
||||||
|
role_id: 1
|
||||||
|
member_id: 1
|
||||||
|
member_roles_002:
|
||||||
|
id: 2
|
||||||
|
role_id: 2
|
||||||
|
member_id: 2
|
||||||
|
member_roles_003:
|
||||||
|
id: 3
|
||||||
|
role_id: 2
|
||||||
|
member_id: 3
|
||||||
|
member_roles_004:
|
||||||
|
id: 4
|
||||||
|
role_id: 2
|
||||||
|
member_id: 4
|
||||||
|
member_roles_005:
|
||||||
|
id: 5
|
||||||
|
role_id: 1
|
||||||
|
member_id: 5
|
||||||
|
|
||||||
|
|
|
@ -2,21 +2,18 @@
|
||||||
members_001:
|
members_001:
|
||||||
created_on: 2006-07-19 19:35:33 +02:00
|
created_on: 2006-07-19 19:35:33 +02:00
|
||||||
project_id: 1
|
project_id: 1
|
||||||
role_id: 1
|
|
||||||
id: 1
|
id: 1
|
||||||
user_id: 2
|
user_id: 2
|
||||||
mail_notification: true
|
mail_notification: true
|
||||||
members_002:
|
members_002:
|
||||||
created_on: 2006-07-19 19:35:36 +02:00
|
created_on: 2006-07-19 19:35:36 +02:00
|
||||||
project_id: 1
|
project_id: 1
|
||||||
role_id: 2
|
|
||||||
id: 2
|
id: 2
|
||||||
user_id: 3
|
user_id: 3
|
||||||
mail_notification: true
|
mail_notification: true
|
||||||
members_003:
|
members_003:
|
||||||
created_on: 2006-07-19 19:35:36 +02:00
|
created_on: 2006-07-19 19:35:36 +02:00
|
||||||
project_id: 2
|
project_id: 2
|
||||||
role_id: 2
|
|
||||||
id: 3
|
id: 3
|
||||||
user_id: 2
|
user_id: 2
|
||||||
mail_notification: true
|
mail_notification: true
|
||||||
|
@ -24,7 +21,6 @@ members_004:
|
||||||
id: 4
|
id: 4
|
||||||
created_on: 2006-07-19 19:35:36 +02:00
|
created_on: 2006-07-19 19:35:36 +02:00
|
||||||
project_id: 1
|
project_id: 1
|
||||||
role_id: 2
|
|
||||||
# Locked user
|
# Locked user
|
||||||
user_id: 5
|
user_id: 5
|
||||||
mail_notification: true
|
mail_notification: true
|
||||||
|
@ -32,7 +28,6 @@ members_005:
|
||||||
id: 5
|
id: 5
|
||||||
created_on: 2006-07-19 19:35:33 +02:00
|
created_on: 2006-07-19 19:35:33 +02:00
|
||||||
project_id: 5
|
project_id: 5
|
||||||
role_id: 1
|
|
||||||
user_id: 2
|
user_id: 2
|
||||||
mail_notification: true
|
mail_notification: true
|
||||||
|
|
|
@ -23,7 +23,7 @@ class AttachmentsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
|
|
||||||
class AttachmentsControllerTest < Test::Unit::TestCase
|
class AttachmentsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :users, :projects, :roles, :members, :enabled_modules, :issues, :trackers, :attachments,
|
fixtures :users, :projects, :roles, :members, :member_roles, :enabled_modules, :issues, :trackers, :attachments,
|
||||||
:versions, :wiki_pages, :wikis, :documents
|
:versions, :wiki_pages, :wikis, :documents
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'boards_controller'
|
||||||
class BoardsController; def rescue_action(e) raise e end; end
|
class BoardsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class BoardsControllerTest < Test::Unit::TestCase
|
class BoardsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :members, :roles, :boards, :messages, :enabled_modules
|
fixtures :projects, :users, :members, :member_roles, :roles, :boards, :messages, :enabled_modules
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = BoardsController.new
|
@controller = BoardsController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'documents_controller'
|
||||||
class DocumentsController; def rescue_action(e) raise e end; end
|
class DocumentsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class DocumentsControllerTest < Test::Unit::TestCase
|
class DocumentsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules, :documents, :enumerations
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules, :documents, :enumerations
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = DocumentsController.new
|
@controller = DocumentsController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'issue_categories_controller'
|
||||||
class IssueCategoriesController; def rescue_action(e) raise e end; end
|
class IssueCategoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class IssueCategoriesControllerTest < Test::Unit::TestCase
|
class IssueCategoriesControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :members, :roles, :enabled_modules, :issue_categories
|
fixtures :projects, :users, :members, :member_roles, :roles, :enabled_modules, :issue_categories
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = IssueCategoriesController.new
|
@controller = IssueCategoriesController.new
|
||||||
|
|
|
@ -10,6 +10,7 @@ class IssueRelationsControllerTest < Test::Unit::TestCase
|
||||||
:users,
|
:users,
|
||||||
:roles,
|
:roles,
|
||||||
:members,
|
:members,
|
||||||
|
:member_roles,
|
||||||
:issues,
|
:issues,
|
||||||
:issue_statuses,
|
:issue_statuses,
|
||||||
:enabled_modules,
|
:enabled_modules,
|
||||||
|
|
|
@ -26,6 +26,7 @@ class IssuesControllerTest < Test::Unit::TestCase
|
||||||
:users,
|
:users,
|
||||||
:roles,
|
:roles,
|
||||||
:members,
|
:members,
|
||||||
|
:member_roles,
|
||||||
:issues,
|
:issues,
|
||||||
:issue_statuses,
|
:issue_statuses,
|
||||||
:versions,
|
:versions,
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'journals_controller'
|
||||||
class JournalsController; def rescue_action(e) raise e end; end
|
class JournalsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class JournalsControllerTest < Test::Unit::TestCase
|
class JournalsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :members, :roles, :issues, :journals, :journal_details, :enabled_modules
|
fixtures :projects, :users, :members, :member_roles, :roles, :issues, :journals, :journal_details, :enabled_modules
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = JournalsController.new
|
@controller = JournalsController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'mail_handler_controller'
|
||||||
class MailHandlerController; def rescue_action(e) raise e end; end
|
class MailHandlerController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class MailHandlerControllerTest < Test::Unit::TestCase
|
class MailHandlerControllerTest < Test::Unit::TestCase
|
||||||
fixtures :users, :projects, :enabled_modules, :roles, :members, :issues, :issue_statuses, :trackers, :enumerations
|
fixtures :users, :projects, :enabled_modules, :roles, :members, :member_roles, :issues, :issue_statuses, :trackers, :enumerations
|
||||||
|
|
||||||
FIXTURES_PATH = File.dirname(__FILE__) + '/../fixtures/mail_handler'
|
FIXTURES_PATH = File.dirname(__FILE__) + '/../fixtures/mail_handler'
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@ class MembersController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
|
|
||||||
class MembersControllerTest < Test::Unit::TestCase
|
class MembersControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :members, :roles, :users
|
fixtures :projects, :members, :member_roles, :roles, :users
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = MembersController.new
|
@controller = MembersController.new
|
||||||
|
@ -42,7 +42,7 @@ class MembersControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_create
|
def test_create
|
||||||
assert_difference 'Member.count' do
|
assert_difference 'Member.count' do
|
||||||
post :new, :id => 1, :member => {:role_id => 1, :user_id => 7}
|
post :new, :id => 1, :member => {:role_ids => [1], :user_id => 7}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
|
@ -50,7 +50,7 @@ class MembersControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_create_by_user_login
|
def test_create_by_user_login
|
||||||
assert_difference 'Member.count' do
|
assert_difference 'Member.count' do
|
||||||
post :new, :id => 1, :member => {:role_id => 1, :user_login => 'someone'}
|
post :new, :id => 1, :member => {:role_ids => [1], :user_login => 'someone'}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
|
@ -58,7 +58,7 @@ class MembersControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_create_multiple
|
def test_create_multiple
|
||||||
assert_difference 'Member.count', 3 do
|
assert_difference 'Member.count', 3 do
|
||||||
post :new, :id => 1, :member => {:role_id => 1, :user_ids => [7, 8, 9]}
|
post :new, :id => 1, :member => {:role_ids => [1], :user_ids => [7, 8, 9]}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
|
@ -66,7 +66,7 @@ class MembersControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_edit
|
def test_edit
|
||||||
assert_no_difference 'Member.count' do
|
assert_no_difference 'Member.count' do
|
||||||
post :edit, :id => 2, :member => {:role_id => 1, :user_id => 3}
|
post :edit, :id => 2, :member => {:role_ids => [1], :user_id => 3}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
end
|
end
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'messages_controller'
|
||||||
class MessagesController; def rescue_action(e) raise e end; end
|
class MessagesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class MessagesControllerTest < Test::Unit::TestCase
|
class MessagesControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :members, :roles, :boards, :messages, :enabled_modules
|
fixtures :projects, :users, :members, :member_roles, :roles, :boards, :messages, :enabled_modules
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = MessagesController.new
|
@controller = MessagesController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'news_controller'
|
||||||
class NewsController; def rescue_action(e) raise e end; end
|
class NewsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class NewsControllerTest < Test::Unit::TestCase
|
class NewsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules, :news, :comments
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules, :news, :comments
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = NewsController.new
|
@controller = NewsController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'projects_controller'
|
||||||
class ProjectsController; def rescue_action(e) raise e end; end
|
class ProjectsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class ProjectsControllerTest < Test::Unit::TestCase
|
class ProjectsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :versions, :users, :roles, :members, :issues, :journals, :journal_details,
|
fixtures :projects, :versions, :users, :roles, :members, :member_roles, :issues, :journals, :journal_details,
|
||||||
:trackers, :projects_trackers, :issue_statuses, :enabled_modules, :enumerations, :boards, :messages,
|
:trackers, :projects_trackers, :issue_statuses, :enabled_modules, :enumerations, :boards, :messages,
|
||||||
:attachments
|
:attachments
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'queries_controller'
|
||||||
class QueriesController; def rescue_action(e) raise e end; end
|
class QueriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class QueriesControllerTest < Test::Unit::TestCase
|
class QueriesControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :members, :roles, :trackers, :issue_statuses, :issue_categories, :enumerations, :issues, :custom_fields, :custom_values, :queries
|
fixtures :projects, :users, :members, :member_roles, :roles, :trackers, :issue_statuses, :issue_categories, :enumerations, :issues, :custom_fields, :custom_values, :queries
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = QueriesController.new
|
@controller = QueriesController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'repositories_controller'
|
||||||
class RepositoriesController; def rescue_action(e) raise e end; end
|
class RepositoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RepositoriesBazaarControllerTest < Test::Unit::TestCase
|
class RepositoriesBazaarControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :repositories, :enabled_modules
|
fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules
|
||||||
|
|
||||||
# No '..' in the repository path
|
# No '..' in the repository path
|
||||||
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/bazaar_repository'
|
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/bazaar_repository'
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'repositories_controller'
|
||||||
class RepositoriesController; def rescue_action(e) raise e end; end
|
class RepositoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RepositoriesControllerTest < Test::Unit::TestCase
|
class RepositoriesControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :repositories, :issues, :issue_statuses, :changesets, :changes, :issue_categories, :enumerations, :custom_fields, :custom_values, :trackers
|
fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :issues, :issue_statuses, :changesets, :changes, :issue_categories, :enumerations, :custom_fields, :custom_values, :trackers
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = RepositoriesController.new
|
@controller = RepositoriesController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'repositories_controller'
|
||||||
class RepositoriesController; def rescue_action(e) raise e end; end
|
class RepositoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RepositoriesDarcsControllerTest < Test::Unit::TestCase
|
class RepositoriesDarcsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :repositories, :enabled_modules
|
fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules
|
||||||
|
|
||||||
# No '..' in the repository path
|
# No '..' in the repository path
|
||||||
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/darcs_repository'
|
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/darcs_repository'
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'repositories_controller'
|
||||||
class RepositoriesController; def rescue_action(e) raise e end; end
|
class RepositoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RepositoriesGitControllerTest < Test::Unit::TestCase
|
class RepositoriesGitControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :repositories, :enabled_modules
|
fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules
|
||||||
|
|
||||||
# No '..' in the repository path
|
# No '..' in the repository path
|
||||||
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/git_repository'
|
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/git_repository'
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'repositories_controller'
|
||||||
class RepositoriesController; def rescue_action(e) raise e end; end
|
class RepositoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RepositoriesMercurialControllerTest < Test::Unit::TestCase
|
class RepositoriesMercurialControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :repositories, :enabled_modules
|
fixtures :projects, :users, :roles, :members, :member_roles, :repositories, :enabled_modules
|
||||||
|
|
||||||
# No '..' in the repository path
|
# No '..' in the repository path
|
||||||
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/mercurial_repository'
|
REPOSITORY_PATH = RAILS_ROOT.gsub(%r{config\/\.\.}, '') + '/tmp/test/mercurial_repository'
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'repositories_controller'
|
||||||
class RepositoriesController; def rescue_action(e) raise e end; end
|
class RepositoriesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RepositoriesSubversionControllerTest < Test::Unit::TestCase
|
class RepositoriesSubversionControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules,
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules,
|
||||||
:repositories, :issues, :issue_statuses, :changesets, :changes,
|
:repositories, :issues, :issue_statuses, :changesets, :changes,
|
||||||
:issue_categories, :enumerations, :custom_fields, :custom_values, :trackers
|
:issue_categories, :enumerations, :custom_fields, :custom_values, :trackers
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'roles_controller'
|
||||||
class RolesController; def rescue_action(e) raise e end; end
|
class RolesController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class RolesControllerTest < Test::Unit::TestCase
|
class RolesControllerTest < Test::Unit::TestCase
|
||||||
fixtures :roles, :users, :members, :workflows
|
fixtures :roles, :users, :members, :member_roles, :workflows
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = RolesController.new
|
@controller = RolesController.new
|
||||||
|
@ -65,7 +65,7 @@ class RolesControllerTest < Test::Unit::TestCase
|
||||||
:permissions => ['add_issues', 'edit_issues', 'log_time', ''],
|
:permissions => ['add_issues', 'edit_issues', 'log_time', ''],
|
||||||
:assignable => '0'}
|
:assignable => '0'}
|
||||||
|
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
role = Role.find_by_name('RoleWithoutWorkflowCopy')
|
role = Role.find_by_name('RoleWithoutWorkflowCopy')
|
||||||
assert_not_nil role
|
assert_not_nil role
|
||||||
assert_equal [:add_issues, :edit_issues, :log_time], role.permissions
|
assert_equal [:add_issues, :edit_issues, :log_time], role.permissions
|
||||||
|
@ -78,7 +78,7 @@ class RolesControllerTest < Test::Unit::TestCase
|
||||||
:assignable => '0'},
|
:assignable => '0'},
|
||||||
:copy_workflow_from => '1'
|
:copy_workflow_from => '1'
|
||||||
|
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
role = Role.find_by_name('RoleWithWorkflowCopy')
|
role = Role.find_by_name('RoleWithWorkflowCopy')
|
||||||
assert_not_nil role
|
assert_not_nil role
|
||||||
assert_equal Role.find(1).workflows.size, role.workflows.size
|
assert_equal Role.find(1).workflows.size, role.workflows.size
|
||||||
|
@ -97,7 +97,7 @@ class RolesControllerTest < Test::Unit::TestCase
|
||||||
:permissions => ['edit_project', ''],
|
:permissions => ['edit_project', ''],
|
||||||
:assignable => '0'}
|
:assignable => '0'}
|
||||||
|
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
role = Role.find(1)
|
role = Role.find(1)
|
||||||
assert_equal [:edit_project], role.permissions
|
assert_equal [:edit_project], role.permissions
|
||||||
end
|
end
|
||||||
|
@ -107,7 +107,7 @@ class RolesControllerTest < Test::Unit::TestCase
|
||||||
assert r.save
|
assert r.save
|
||||||
|
|
||||||
post :destroy, :id => r
|
post :destroy, :id => r
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
assert_nil Role.find_by_id(r.id)
|
assert_nil Role.find_by_id(r.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -139,7 +139,7 @@ class RolesControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_post_report
|
def test_post_report
|
||||||
post :report, :permissions => { '0' => '', '1' => ['edit_issues'], '3' => ['add_issues', 'delete_issues']}
|
post :report, :permissions => { '0' => '', '1' => ['edit_issues'], '3' => ['add_issues', 'delete_issues']}
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
|
|
||||||
assert_equal [:edit_issues], Role.find(1).permissions
|
assert_equal [:edit_issues], Role.find(1).permissions
|
||||||
assert_equal [:add_issues, :delete_issues], Role.find(3).permissions
|
assert_equal [:add_issues, :delete_issues], Role.find(3).permissions
|
||||||
|
@ -148,33 +148,33 @@ class RolesControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_clear_all_permissions
|
def test_clear_all_permissions
|
||||||
post :report, :permissions => { '0' => '' }
|
post :report, :permissions => { '0' => '' }
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
assert Role.find(1).permissions.empty?
|
assert Role.find(1).permissions.empty?
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_move_highest
|
def test_move_highest
|
||||||
post :edit, :id => 3, :role => {:move_to => 'highest'}
|
post :edit, :id => 3, :role => {:move_to => 'highest'}
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
assert_equal 1, Role.find(3).position
|
assert_equal 1, Role.find(3).position
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_move_higher
|
def test_move_higher
|
||||||
position = Role.find(3).position
|
position = Role.find(3).position
|
||||||
post :edit, :id => 3, :role => {:move_to => 'higher'}
|
post :edit, :id => 3, :role => {:move_to => 'higher'}
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
assert_equal position - 1, Role.find(3).position
|
assert_equal position - 1, Role.find(3).position
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_move_lower
|
def test_move_lower
|
||||||
position = Role.find(2).position
|
position = Role.find(2).position
|
||||||
post :edit, :id => 2, :role => {:move_to => 'lower'}
|
post :edit, :id => 2, :role => {:move_to => 'lower'}
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
assert_equal position + 1, Role.find(2).position
|
assert_equal position + 1, Role.find(2).position
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_move_lowest
|
def test_move_lowest
|
||||||
post :edit, :id => 2, :role => {:move_to => 'lowest'}
|
post :edit, :id => 2, :role => {:move_to => 'lowest'}
|
||||||
assert_redirected_to 'roles/list'
|
assert_redirected_to 'roles'
|
||||||
assert_equal Role.count, Role.find(2).position
|
assert_equal Role.count, Role.find(2).position
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -5,7 +5,7 @@ require 'search_controller'
|
||||||
class SearchController; def rescue_action(e) raise e end; end
|
class SearchController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class SearchControllerTest < Test::Unit::TestCase
|
class SearchControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :enabled_modules, :roles, :users,
|
fixtures :projects, :enabled_modules, :roles, :users, :members, :member_roles,
|
||||||
:issues, :trackers, :issue_statuses,
|
:issues, :trackers, :issue_statuses,
|
||||||
:custom_fields, :custom_values,
|
:custom_fields, :custom_values,
|
||||||
:repositories, :changesets
|
:repositories, :changesets
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'timelog_controller'
|
||||||
class TimelogController; def rescue_action(e) raise e end; end
|
class TimelogController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class TimelogControllerTest < Test::Unit::TestCase
|
class TimelogControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :enabled_modules, :roles, :members, :issues, :time_entries, :users, :trackers, :enumerations, :issue_statuses, :custom_fields, :custom_values
|
fixtures :projects, :enabled_modules, :roles, :members, :member_roles, :issues, :time_entries, :users, :trackers, :enumerations, :issue_statuses, :custom_fields, :custom_values
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = TimelogController.new
|
@controller = TimelogController.new
|
||||||
|
|
|
@ -24,7 +24,7 @@ class UsersController; def rescue_action(e) raise e end; end
|
||||||
class UsersControllerTest < Test::Unit::TestCase
|
class UsersControllerTest < Test::Unit::TestCase
|
||||||
include Redmine::I18n
|
include Redmine::I18n
|
||||||
|
|
||||||
fixtures :users, :projects, :members
|
fixtures :users, :projects, :members, :member_roles, :roles
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = UsersController.new
|
@controller = UsersController.new
|
||||||
|
@ -123,9 +123,9 @@ class UsersControllerTest < Test::Unit::TestCase
|
||||||
|
|
||||||
def test_edit_membership
|
def test_edit_membership
|
||||||
post :edit_membership, :id => 2, :membership_id => 1,
|
post :edit_membership, :id => 2, :membership_id => 1,
|
||||||
:membership => { :role_id => 2}
|
:membership => { :role_ids => [2]}
|
||||||
assert_redirected_to :action => 'edit', :id => '2', :tab => 'memberships'
|
assert_redirected_to :action => 'edit', :id => '2', :tab => 'memberships'
|
||||||
assert_equal 2, Member.find(1).role_id
|
assert_equal [2], Member.find(1).role_ids
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_edit_with_activation_should_send_a_notification
|
def test_edit_with_activation_should_send_a_notification
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'versions_controller'
|
||||||
class VersionsController; def rescue_action(e) raise e end; end
|
class VersionsController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class VersionsControllerTest < Test::Unit::TestCase
|
class VersionsControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :versions, :issues, :users, :roles, :members, :enabled_modules
|
fixtures :projects, :versions, :issues, :users, :roles, :members, :member_roles, :enabled_modules
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = VersionsController.new
|
@controller = VersionsController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'watchers_controller'
|
||||||
class WatchersController; def rescue_action(e) raise e end; end
|
class WatchersController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class WatchersControllerTest < Test::Unit::TestCase
|
class WatchersControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules,
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules,
|
||||||
:issues, :trackers, :projects_trackers, :issue_statuses, :enumerations, :watchers
|
:issues, :trackers, :projects_trackers, :issue_statuses, :enumerations, :watchers
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'wiki_controller'
|
||||||
class WikiController; def rescue_action(e) raise e end; end
|
class WikiController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class WikiControllerTest < Test::Unit::TestCase
|
class WikiControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules, :wikis, :wiki_pages, :wiki_contents, :wiki_content_versions, :attachments
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules, :wikis, :wiki_pages, :wiki_contents, :wiki_content_versions, :attachments
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = WikiController.new
|
@controller = WikiController.new
|
||||||
|
|
|
@ -22,7 +22,7 @@ require 'wikis_controller'
|
||||||
class WikisController; def rescue_action(e) raise e end; end
|
class WikisController; def rescue_action(e) raise e end; end
|
||||||
|
|
||||||
class WikisControllerTest < Test::Unit::TestCase
|
class WikisControllerTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules, :wikis
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules, :wikis
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@controller = WikisController.new
|
@controller = WikisController.new
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class ActivityTest < Test::Unit::TestCase
|
class ActivityTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :versions, :attachments, :users, :roles, :members, :issues, :journals, :journal_details,
|
fixtures :projects, :versions, :attachments, :users, :roles, :members, :member_roles, :issues, :journals, :journal_details,
|
||||||
:trackers, :projects_trackers, :issue_statuses, :enabled_modules, :enumerations, :boards, :messages
|
:trackers, :projects_trackers, :issue_statuses, :enabled_modules, :enumerations, :boards, :messages
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class ChangesetTest < Test::Unit::TestCase
|
class ChangesetTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :repositories, :issues, :issue_statuses, :changesets, :changes, :issue_categories, :enumerations, :custom_fields, :custom_values, :users, :members, :trackers
|
fixtures :projects, :repositories, :issues, :issue_statuses, :changesets, :changes, :issue_categories, :enumerations, :custom_fields, :custom_values, :users, :members, :member_roles, :trackers
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class IssueTest < Test::Unit::TestCase
|
class IssueTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :members,
|
fixtures :projects, :users, :members, :member_roles,
|
||||||
:trackers, :projects_trackers,
|
:trackers, :projects_trackers,
|
||||||
:issue_statuses, :issue_categories,
|
:issue_statuses, :issue_categories,
|
||||||
:enumerations,
|
:enumerations,
|
||||||
|
@ -242,6 +242,10 @@ class IssueTest < Test::Unit::TestCase
|
||||||
assert !Issue.new(:due_date => 1.day.ago.to_date, :status => IssueStatus.find(:first, :conditions => {:is_closed => true})).overdue?
|
assert !Issue.new(:due_date => 1.day.ago.to_date, :status => IssueStatus.find(:first, :conditions => {:is_closed => true})).overdue?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_assignable_users
|
||||||
|
assert_kind_of User, Issue.find(1).assignable_users.first
|
||||||
|
end
|
||||||
|
|
||||||
def test_create_should_send_email_notification
|
def test_create_should_send_email_notification
|
||||||
ActionMailer::Base.deliveries.clear
|
ActionMailer::Base.deliveries.clear
|
||||||
issue = Issue.new(:project_id => 1, :tracker_id => 1, :author_id => 3, :status_id => 1, :priority => Enumeration.priorities.first, :subject => 'test_create', :estimated_hours => '1:30')
|
issue = Issue.new(:project_id => 1, :tracker_id => 1, :author_id => 3, :status_id => 1, :priority => Enumeration.priorities.first, :subject => 'test_create', :estimated_hours => '1:30')
|
||||||
|
|
|
@ -22,6 +22,7 @@ class MailHandlerTest < Test::Unit::TestCase
|
||||||
:enabled_modules,
|
:enabled_modules,
|
||||||
:roles,
|
:roles,
|
||||||
:members,
|
:members,
|
||||||
|
:member_roles,
|
||||||
:issues,
|
:issues,
|
||||||
:issue_statuses,
|
:issue_statuses,
|
||||||
:workflows,
|
:workflows,
|
||||||
|
|
|
@ -19,7 +19,7 @@ require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class MailerTest < Test::Unit::TestCase
|
class MailerTest < Test::Unit::TestCase
|
||||||
include Redmine::I18n
|
include Redmine::I18n
|
||||||
fixtures :projects, :issues, :users, :members, :documents, :attachments, :news, :tokens, :journals, :journal_details, :changesets, :trackers, :issue_statuses, :enumerations, :messages, :boards, :repositories
|
fixtures :projects, :issues, :users, :members, :member_roles, :documents, :attachments, :news, :tokens, :journals, :journal_details, :changesets, :trackers, :issue_statuses, :enumerations, :messages, :boards, :repositories
|
||||||
|
|
||||||
def test_generated_links_in_emails
|
def test_generated_links_in_emails
|
||||||
ActionMailer::Base.deliveries.clear
|
ActionMailer::Base.deliveries.clear
|
||||||
|
|
|
@ -18,34 +18,54 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class MemberTest < Test::Unit::TestCase
|
class MemberTest < Test::Unit::TestCase
|
||||||
fixtures :users, :projects, :roles, :members
|
fixtures :users, :projects, :roles, :members, :member_roles
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@jsmith = Member.find(1)
|
@jsmith = Member.find(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_create
|
def test_create
|
||||||
member = Member.new(:project_id => 1, :user_id => 4, :role_id => 1)
|
member = Member.new(:project_id => 1, :user_id => 4, :role_ids => [1, 2])
|
||||||
assert member.save
|
assert member.save
|
||||||
|
member.reload
|
||||||
|
|
||||||
|
assert_equal 2, member.roles.size
|
||||||
|
assert_equal Role.find(1), member.roles.sort.first
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_update
|
def test_update
|
||||||
assert_equal "eCookbook", @jsmith.project.name
|
assert_equal "eCookbook", @jsmith.project.name
|
||||||
assert_equal "Manager", @jsmith.role.name
|
assert_equal "Manager", @jsmith.roles.first.name
|
||||||
assert_equal "jsmith", @jsmith.user.login
|
assert_equal "jsmith", @jsmith.user.login
|
||||||
|
|
||||||
@jsmith.role = Role.find(2)
|
@jsmith.mail_notification = !@jsmith.mail_notification
|
||||||
assert @jsmith.save
|
assert @jsmith.save
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_update_roles
|
||||||
|
assert_equal 1, @jsmith.roles.size
|
||||||
|
@jsmith.role_ids = [1, 2]
|
||||||
|
assert @jsmith.save
|
||||||
|
assert_equal 2, @jsmith.reload.roles.size
|
||||||
|
end
|
||||||
|
|
||||||
def test_validate
|
def test_validate
|
||||||
member = Member.new(:project_id => 1, :user_id => 2, :role_id =>2)
|
member = Member.new(:project_id => 1, :user_id => 2, :role_ids => [2])
|
||||||
# same use can't have more than one role for a project
|
# same use can't have more than one membership for a project
|
||||||
|
assert !member.save
|
||||||
|
|
||||||
|
member = Member.new(:project_id => 1, :user_id => 2, :role_ids => [])
|
||||||
|
# must have one role at least
|
||||||
assert !member.save
|
assert !member.save
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_destroy
|
def test_destroy
|
||||||
@jsmith.destroy
|
assert_difference 'Member.count', -1 do
|
||||||
|
assert_difference 'MemberRole.count', -1 do
|
||||||
|
@jsmith.destroy
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
assert_raise(ActiveRecord::RecordNotFound) { Member.find(@jsmith.id) }
|
assert_raise(ActiveRecord::RecordNotFound) { Member.find(@jsmith.id) }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class MessageTest < Test::Unit::TestCase
|
class MessageTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :roles, :members, :boards, :messages, :users, :watchers
|
fixtures :projects, :roles, :members, :member_roles, :boards, :messages, :users, :watchers
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@board = Board.find(1)
|
@board = Board.find(1)
|
||||||
|
@ -116,7 +116,7 @@ class MessageTest < Test::Unit::TestCase
|
||||||
author = message.author
|
author = message.author
|
||||||
assert message.editable_by?(author)
|
assert message.editable_by?(author)
|
||||||
|
|
||||||
author.role_for_project(message.project).remove_permission!(:edit_own_messages)
|
author.roles_for_project(message.project).first.remove_permission!(:edit_own_messages)
|
||||||
assert !message.reload.editable_by?(author.reload)
|
assert !message.reload.editable_by?(author.reload)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ class MessageTest < Test::Unit::TestCase
|
||||||
author = message.author
|
author = message.author
|
||||||
assert message.destroyable_by?(author)
|
assert message.destroyable_by?(author)
|
||||||
|
|
||||||
author.role_for_project(message.project).remove_permission!(:delete_own_messages)
|
author.roles_for_project(message.project).first.remove_permission!(:delete_own_messages)
|
||||||
assert !message.reload.destroyable_by?(author.reload)
|
assert !message.reload.destroyable_by?(author.reload)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class NewsTest < Test::Unit::TestCase
|
class NewsTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :users, :roles, :members, :enabled_modules, :news
|
fixtures :projects, :users, :roles, :members, :member_roles, :enabled_modules, :news
|
||||||
|
|
||||||
def valid_news
|
def valid_news
|
||||||
{ :title => 'Test news', :description => 'Lorem ipsum etc', :author => User.find(:first) }
|
{ :title => 'Test news', :description => 'Lorem ipsum etc', :author => User.find(:first) }
|
||||||
|
|
|
@ -20,8 +20,8 @@ require File.dirname(__FILE__) + '/../test_helper'
|
||||||
class ProjectTest < Test::Unit::TestCase
|
class ProjectTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :enabled_modules,
|
fixtures :projects, :enabled_modules,
|
||||||
:issues, :issue_statuses, :journals, :journal_details,
|
:issues, :issue_statuses, :journals, :journal_details,
|
||||||
:users, :members, :roles, :projects_trackers, :trackers, :boards,
|
:users, :members, :member_roles, :roles, :projects_trackers, :trackers, :boards,
|
||||||
:queries
|
:queries
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@ecookbook = Project.find(1)
|
@ecookbook = Project.find(1)
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class QueryTest < Test::Unit::TestCase
|
class QueryTest < Test::Unit::TestCase
|
||||||
fixtures :projects, :enabled_modules, :users, :members, :roles, :trackers, :issue_statuses, :issue_categories, :enumerations, :issues, :watchers, :custom_fields, :custom_values, :versions, :queries
|
fixtures :projects, :enabled_modules, :users, :members, :member_roles, :roles, :trackers, :issue_statuses, :issue_categories, :enumerations, :issues, :watchers, :custom_fields, :custom_values, :versions, :queries
|
||||||
|
|
||||||
def test_custom_fields_for_all_projects_should_be_available_in_global_queries
|
def test_custom_fields_for_all_projects_should_be_available_in_global_queries
|
||||||
query = Query.new(:project => nil, :name => '_')
|
query = Query.new(:project => nil, :name => '_')
|
||||||
|
|
|
@ -19,7 +19,8 @@ require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class SearchTest < Test::Unit::TestCase
|
class SearchTest < Test::Unit::TestCase
|
||||||
fixtures :users,
|
fixtures :users,
|
||||||
:members,
|
:members,
|
||||||
|
:member_roles,
|
||||||
:projects,
|
:projects,
|
||||||
:roles,
|
:roles,
|
||||||
:enabled_modules,
|
:enabled_modules,
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
require File.dirname(__FILE__) + '/../test_helper'
|
require File.dirname(__FILE__) + '/../test_helper'
|
||||||
|
|
||||||
class UserTest < Test::Unit::TestCase
|
class UserTest < Test::Unit::TestCase
|
||||||
fixtures :users, :members, :projects
|
fixtures :users, :members, :projects, :roles, :member_roles
|
||||||
|
|
||||||
def setup
|
def setup
|
||||||
@admin = User.find(1)
|
@admin = User.find(1)
|
||||||
|
@ -130,14 +130,14 @@ class UserTest < Test::Unit::TestCase
|
||||||
assert_equal key, @jsmith.rss_key
|
assert_equal key, @jsmith.rss_key
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_role_for_project
|
def test_roles_for_project
|
||||||
# user with a role
|
# user with a role
|
||||||
role = @jsmith.role_for_project(Project.find(1))
|
roles = @jsmith.roles_for_project(Project.find(1))
|
||||||
assert_kind_of Role, role
|
assert_kind_of Role, roles.first
|
||||||
assert_equal "Manager", role.name
|
assert_equal "Manager", roles.first.name
|
||||||
|
|
||||||
# user with no role
|
# user with no role
|
||||||
assert !@dlopper.role_for_project(Project.find(2)).member?
|
assert_nil @dlopper.roles_for_project(Project.find(2)).detect {|role| role.member?}
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_mail_notification_all
|
def test_mail_notification_all
|
||||||
|
|
Loading…
Reference in New Issue