@@ -1,43 +1,44 | |||
|
1 | 1 | class ContextMenusController < ApplicationController |
|
2 | 2 | helper :watchers |
|
3 | 3 | |
|
4 | 4 | def issues |
|
5 |
@issues = Issue. |
|
|
5 | @issues = Issue.visible.all(:conditions => {:id => params[:ids]}, :include => :project) | |
|
6 | ||
|
6 | 7 | if (@issues.size == 1) |
|
7 | 8 | @issue = @issues.first |
|
8 | 9 | @allowed_statuses = @issue.new_statuses_allowed_to(User.current) |
|
9 | 10 | else |
|
10 | 11 | @allowed_statuses = @issues.map do |i| |
|
11 | 12 | i.new_statuses_allowed_to(User.current) |
|
12 | 13 | end.inject do |memo,s| |
|
13 | 14 | memo & s |
|
14 | 15 | end |
|
15 | 16 | end |
|
16 | 17 | @projects = @issues.collect(&:project).compact.uniq |
|
17 | 18 | @project = @projects.first if @projects.size == 1 |
|
18 | 19 | |
|
19 | 20 | @can = {:edit => User.current.allowed_to?(:edit_issues, @projects), |
|
20 | 21 | :log_time => (@project && User.current.allowed_to?(:log_time, @project)), |
|
21 | 22 | :update => (User.current.allowed_to?(:edit_issues, @projects) || (User.current.allowed_to?(:change_status, @projects) && !@allowed_statuses.blank?)), |
|
22 | 23 | :move => (@project && User.current.allowed_to?(:move_issues, @project)), |
|
23 | 24 | :copy => (@issue && @project.trackers.include?(@issue.tracker) && User.current.allowed_to?(:add_issues, @project)), |
|
24 | 25 | :delete => User.current.allowed_to?(:delete_issues, @projects) |
|
25 | 26 | } |
|
26 | 27 | if @project |
|
27 | 28 | @assignables = @project.assignable_users |
|
28 | 29 | @assignables << @issue.assigned_to if @issue && @issue.assigned_to && !@assignables.include?(@issue.assigned_to) |
|
29 | 30 | @trackers = @project.trackers |
|
30 | 31 | else |
|
31 | 32 | #when multiple projects, we only keep the intersection of each set |
|
32 | 33 | @assignables = @projects.map(&:assignable_users).inject{|memo,a| memo & a} |
|
33 | 34 | @trackers = @projects.map(&:trackers).inject{|memo,t| memo & t} |
|
34 | 35 | end |
|
35 | 36 | |
|
36 | 37 | @priorities = IssuePriority.all.reverse |
|
37 | 38 | @statuses = IssueStatus.find(:all, :order => 'position') |
|
38 | 39 | @back = back_url |
|
39 | 40 | |
|
40 | 41 | render :layout => false |
|
41 | 42 | end |
|
42 | 43 | |
|
43 | 44 | end |
@@ -1,105 +1,111 | |||
|
1 | 1 | require File.expand_path('../../test_helper', __FILE__) |
|
2 | 2 | |
|
3 | 3 | class ContextMenusControllerTest < ActionController::TestCase |
|
4 | 4 | fixtures :all |
|
5 | 5 | |
|
6 | 6 | def test_context_menu_one_issue |
|
7 | 7 | @request.session[:user_id] = 2 |
|
8 | 8 | get :issues, :ids => [1] |
|
9 | 9 | assert_response :success |
|
10 | 10 | assert_template 'context_menu' |
|
11 | 11 | assert_tag :tag => 'a', :content => 'Edit', |
|
12 | 12 | :attributes => { :href => '/issues/1/edit', |
|
13 | 13 | :class => 'icon-edit' } |
|
14 | 14 | assert_tag :tag => 'a', :content => 'Closed', |
|
15 | 15 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&issue%5Bstatus_id%5D=5', |
|
16 | 16 | :class => '' } |
|
17 | 17 | assert_tag :tag => 'a', :content => 'Immediate', |
|
18 | 18 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&issue%5Bpriority_id%5D=8', |
|
19 | 19 | :class => '' } |
|
20 | 20 | # Versions |
|
21 | 21 | assert_tag :tag => 'a', :content => '2.0', |
|
22 | 22 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&issue%5Bfixed_version_id%5D=3', |
|
23 | 23 | :class => '' } |
|
24 | 24 | assert_tag :tag => 'a', :content => 'eCookbook Subproject 1 - 2.0', |
|
25 | 25 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&issue%5Bfixed_version_id%5D=4', |
|
26 | 26 | :class => '' } |
|
27 | 27 | |
|
28 | 28 | assert_tag :tag => 'a', :content => 'Dave Lopper', |
|
29 | 29 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&issue%5Bassigned_to_id%5D=3', |
|
30 | 30 | :class => '' } |
|
31 | 31 | assert_tag :tag => 'a', :content => 'Duplicate', |
|
32 | 32 | :attributes => { :href => '/projects/ecookbook/issues/1/copy', |
|
33 | 33 | :class => 'icon-duplicate' } |
|
34 | 34 | assert_tag :tag => 'a', :content => 'Copy', |
|
35 | 35 | :attributes => { :href => '/issues/move/new?copy_options%5Bcopy%5D=t&ids%5B%5D=1', |
|
36 | 36 | :class => 'icon-copy' } |
|
37 | 37 | assert_tag :tag => 'a', :content => 'Move', |
|
38 | 38 | :attributes => { :href => '/issues/move/new?ids%5B%5D=1', |
|
39 | 39 | :class => 'icon-move' } |
|
40 | 40 | assert_tag :tag => 'a', :content => 'Delete', |
|
41 | 41 | :attributes => { :href => '/issues/destroy?ids%5B%5D=1', |
|
42 | 42 | :class => 'icon-del' } |
|
43 | 43 | end |
|
44 | 44 | |
|
45 | 45 | def test_context_menu_one_issue_by_anonymous |
|
46 | 46 | get :issues, :ids => [1] |
|
47 | 47 | assert_response :success |
|
48 | 48 | assert_template 'context_menu' |
|
49 | 49 | assert_tag :tag => 'a', :content => 'Delete', |
|
50 | 50 | :attributes => { :href => '#', |
|
51 | 51 | :class => 'icon-del disabled' } |
|
52 | 52 | end |
|
53 | 53 | |
|
54 | 54 | def test_context_menu_multiple_issues_of_same_project |
|
55 | 55 | @request.session[:user_id] = 2 |
|
56 | 56 | get :issues, :ids => [1, 2] |
|
57 | 57 | assert_response :success |
|
58 | 58 | assert_template 'context_menu' |
|
59 | 59 | assert_tag :tag => 'a', :content => 'Edit', |
|
60 | 60 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&ids%5B%5D=2', |
|
61 | 61 | :class => 'icon-edit' } |
|
62 | 62 | assert_tag :tag => 'a', :content => 'Closed', |
|
63 | 63 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&ids%5B%5D=2&issue%5Bstatus_id%5D=5', |
|
64 | 64 | :class => '' } |
|
65 | 65 | assert_tag :tag => 'a', :content => 'Immediate', |
|
66 | 66 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&ids%5B%5D=2&issue%5Bpriority_id%5D=8', |
|
67 | 67 | :class => '' } |
|
68 | 68 | assert_tag :tag => 'a', :content => 'Dave Lopper', |
|
69 | 69 | :attributes => { :href => '/issues/bulk_edit?ids%5B%5D=1&ids%5B%5D=2&issue%5Bassigned_to_id%5D=3', |
|
70 | 70 | :class => '' } |
|
71 | 71 | assert_tag :tag => 'a', :content => 'Copy', |
|
72 | 72 | :attributes => { :href => '/issues/move/new?copy_options%5Bcopy%5D=t&ids%5B%5D=1&ids%5B%5D=2', |
|
73 | 73 | :class => 'icon-copy' } |
|
74 | 74 | assert_tag :tag => 'a', :content => 'Move', |
|
75 | 75 | :attributes => { :href => '/issues/move/new?ids%5B%5D=1&ids%5B%5D=2', |
|
76 | 76 | :class => 'icon-move' } |
|
77 | 77 | assert_tag :tag => 'a', :content => 'Delete', |
|
78 | 78 | :attributes => { :href => '/issues/destroy?ids%5B%5D=1&ids%5B%5D=2', |
|
79 | 79 | :class => 'icon-del' } |
|
80 | 80 | end |
|
81 | 81 | |
|
82 | 82 | def test_context_menu_multiple_issues_of_different_projects |
|
83 | 83 | @request.session[:user_id] = 2 |
|
84 | 84 | get :issues, :ids => [1, 2, 6] |
|
85 | 85 | assert_response :success |
|
86 | 86 | assert_template 'context_menu' |
|
87 | 87 | ids = "ids%5B%5D=1&ids%5B%5D=2&ids%5B%5D=6" |
|
88 | 88 | assert_tag :tag => 'a', :content => 'Edit', |
|
89 | 89 | :attributes => { :href => "/issues/bulk_edit?#{ids}", |
|
90 | 90 | :class => 'icon-edit' } |
|
91 | 91 | assert_tag :tag => 'a', :content => 'Closed', |
|
92 | 92 | :attributes => { :href => "/issues/bulk_edit?#{ids}&issue%5Bstatus_id%5D=5", |
|
93 | 93 | :class => '' } |
|
94 | 94 | assert_tag :tag => 'a', :content => 'Immediate', |
|
95 | 95 | :attributes => { :href => "/issues/bulk_edit?#{ids}&issue%5Bpriority_id%5D=8", |
|
96 | 96 | :class => '' } |
|
97 | 97 | assert_tag :tag => 'a', :content => 'John Smith', |
|
98 | 98 | :attributes => { :href => "/issues/bulk_edit?#{ids}&issue%5Bassigned_to_id%5D=2", |
|
99 | 99 | :class => '' } |
|
100 | 100 | assert_tag :tag => 'a', :content => 'Delete', |
|
101 | 101 | :attributes => { :href => "/issues/destroy?#{ids}", |
|
102 | 102 | :class => 'icon-del' } |
|
103 | 103 | end |
|
104 | 104 | |
|
105 | def test_context_menu_issue_visibility | |
|
106 | get :issues, :ids => [1, 4] | |
|
107 | assert_response :success | |
|
108 | assert_template 'context_menu' | |
|
109 | assert_equal [1], assigns(:issues).collect(&:id) | |
|
110 | end | |
|
105 | 111 | end |
General Comments 0
You need to be logged in to leave comments.
Login now