[Rt-commit] rt branch, 5.0-trunk, updated. rt-5.0.0alpha1-15-g129481bc0
? sunnavy
sunnavy at bestpractical.com
Thu Mar 5 13:56:38 EST 2020
The branch, 5.0-trunk has been updated
via 129481bc00ccfe555aa5d2809135f16bd86c4b19 (commit)
via aef6fdb99e8eced0a4924f83fedc41ea7ef50bf2 (commit)
via 6691e962d9a2c1f610655c9bd2f9e21a1c20cdb2 (commit)
via 0a6d54ad7bc8759bdc8fca2b1eaf1be8d618aacd (commit)
from 5a5cfcd8d3e44332ea0db53805f6f575e3c9ccfe (commit)
Summary of changes:
lib/RT.pm | 1 +
lib/RT/CustomRole.pm | 28 +++++
lib/RT/Interface/Web/MenuBuilder.pm | 5 +
lib/RT/Queue.pm | 76 ++++++++++++++
.../CustomRoles/{Objects.html => Visibility.html} | 115 +++++++++++----------
share/html/Elements/SelectWatcherType | 11 ++
share/html/Ticket/Create.html | 4 +
share/html/Ticket/Elements/EditBasics | 4 +
share/html/Ticket/Elements/EditPeople | 7 ++
share/html/Ticket/Elements/ShowPeople | 7 ++
t/web/customrole_visibility.t | 105 +++++++++++++++++++
11 files changed, 308 insertions(+), 55 deletions(-)
copy share/html/Admin/CustomRoles/{Objects.html => Visibility.html} (54%)
create mode 100644 t/web/customrole_visibility.t
- Log -----------------------------------------------------------------
commit 0a6d54ad7bc8759bdc8fca2b1eaf1be8d618aacd
Author: Blaine Motsinger <blaine at bestpractical.com>
Date: Tue Dec 24 12:35:06 2019 -0600
Core RT-Extension-CustomRole-Visibility
diff --git a/lib/RT.pm b/lib/RT.pm
index 6116333a4..cc32f730c 100644
--- a/lib/RT.pm
+++ b/lib/RT.pm
@@ -767,6 +767,7 @@ our %CORED_PLUGINS = (
'RT::Extension::AdminConditionsAndActions' => '4.4.2',
'RT::Extension::RightsInspector' => '5.0',
'RT::Extension::ConfigInDatabase' => '5.0',
+ 'RT::Extension::CustomRole::Visibility' => '5.0',
);
sub InitPlugins {
diff --git a/lib/RT/CustomRole.pm b/lib/RT/CustomRole.pm
index 5d1bfb3d6..230ecbae4 100644
--- a/lib/RT/CustomRole.pm
+++ b/lib/RT/CustomRole.pm
@@ -704,6 +704,34 @@ sub SetDisabled {
}
}
+sub HiddenForURLs {
+ my $self = shift;
+ my $attr = $self->FirstAttribute('HiddenForURLs');
+ return {} if !$attr;
+ return $attr->Content;
+}
+
+sub SetHiddenForURLs {
+ my $self = shift;
+ my $hidden = shift;
+
+ return $self->SetAttribute(
+ Name => 'HiddenForURLs',
+ Content => $hidden,
+ );
+}
+
+sub IsHiddenForURL {
+ my $self = shift;
+ my $url = shift;
+
+ my $current_url = $HTML::Mason::Commands::r->path_info;
+ $current_url =~ s!/{2,}!/!g;
+
+ $url //= $current_url;
+ return $self->HiddenForURLs->{$url};
+}
+
sub _CoreAccessible {
{
id =>
diff --git a/lib/RT/Interface/Web/MenuBuilder.pm b/lib/RT/Interface/Web/MenuBuilder.pm
index 565f74512..885211260 100644
--- a/lib/RT/Interface/Web/MenuBuilder.pm
+++ b/lib/RT/Interface/Web/MenuBuilder.pm
@@ -1199,6 +1199,11 @@ sub _BuildAdminMenu {
if ( $obj and $obj->id ) {
$page->child( basics => title => loc('Basics'), path => "/Admin/CustomRoles/Modify.html?id=".$id );
$page->child( 'applies-to' => title => loc('Applies to'), path => "/Admin/CustomRoles/Objects.html?id=" . $id );
+
+ if ( $current_user->HasRight( Object => $obj, Right => 'AdminCustomRoles' ) ) {
+ $page->child( 'visibility' => title => loc('Visibility'), path => "/Admin/CustomRoles/Visibility.html?id=" . $id );
+ }
+
}
}
}
diff --git a/lib/RT/Queue.pm b/lib/RT/Queue.pm
index 14d66885f..2b4d04706 100644
--- a/lib/RT/Queue.pm
+++ b/lib/RT/Queue.pm
@@ -1264,6 +1264,82 @@ sub SetSLA {
return ($status, $self->loc("Queue's default service level has been changed"));
}
+sub InitialPriority {
+ my $self = shift;
+ RT->Deprecated( Instead => "DefaultValue('InitialPriority')", Remove => '4.6' );
+ return $self->DefaultValue('InitialPriority');
+}
+
+sub FinalPriority {
+ my $self = shift;
+ RT->Deprecated( Instead => "DefaultValue('FinalPriority')", Remove => '4.6' );
+ return $self->DefaultValue('FinalPriority');
+}
+
+sub DefaultDueIn {
+ my $self = shift;
+ RT->Deprecated( Instead => "DefaultValue('Due')", Remove => '4.6' );
+
+ # DefaultDueIn used to be a number of days; so if the DefaultValue is,
+ # say, "3 days" then return 3
+ my $due = $self->DefaultValue('Due');
+ if (defined($due) && $due =~ /^(\d+) days?$/i) {
+ return $1;
+ }
+
+ return $due;
+}
+
+sub SetInitialPriority {
+ my $self = shift;
+ my $value = shift;
+ RT->Deprecated( Instead => "SetDefaultValue", Remove => '4.6' );
+ return $self->SetDefaultValue(
+ Name => 'InitialPriority',
+ Value => $value,
+ );
+}
+
+sub SetFinalPriority {
+ my $self = shift;
+ my $value = shift;
+ RT->Deprecated( Instead => "SetDefaultValue", Remove => '4.6' );
+ return $self->SetDefaultValue(
+ Name => 'FinalPriority',
+ Value => $value,
+ );
+}
+
+sub SetDefaultDueIn {
+ my $self = shift;
+ my $value = shift;
+
+ # DefaultDueIn used to be a number of days; so if we're setting to,
+ # say, "3" then add the word "days" to match the way the new
+ # DefaultValues works
+ $value .= " days" if defined($value) && $value =~ /^\d+$/;
+
+ RT->Deprecated( Instead => "SetDefaultValue", Remove => '4.6' );
+ return $self->SetDefaultValue(
+ Name => 'Due',
+ Value => $value,
+ );
+}
+
+sub HiddenCustomRoleIDsForURL {
+ my $self = shift;
+ my $url = shift;
+
+ my $roles = $self->CustomRoles;
+ my @ids;
+
+ while (my $role = $roles->Next) {
+ push @ids, $role->Id if $role->IsHiddenForURL($url);
+ }
+
+ return @ids;
+}
+
RT::Base->_ImportOverlays();
1;
diff --git a/share/html/Admin/CustomRoles/Visibility.html b/share/html/Admin/CustomRoles/Visibility.html
new file mode 100644
index 000000000..f739866dd
--- /dev/null
+++ b/share/html/Admin/CustomRoles/Visibility.html
@@ -0,0 +1,127 @@
+%# BEGIN BPS TAGGED BLOCK {{{
+%#
+%# COPYRIGHT:
+%#
+%# This software is Copyright (c) 1996-2019 Best Practical Solutions, LLC
+%# <sales at bestpractical.com>
+%#
+%# (Except where explicitly superseded by other copyright notices)
+%#
+%#
+%# LICENSE:
+%#
+%# This work is made available to you under the terms of Version 2 of
+%# the GNU General Public License. A copy of that license should have
+%# been provided with this software, but in any event can be snarfed
+%# from www.gnu.org.
+%#
+%# This work 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 or visit their web page on the internet at
+%# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
+%#
+%#
+%# CONTRIBUTION SUBMISSION POLICY:
+%#
+%# (The following paragraph is not intended to limit the rights granted
+%# to you to modify and distribute this software under the terms of
+%# the GNU General Public License and is only of importance to you if
+%# you choose to contribute your changes and enhancements to the
+%# community by submitting them to Best Practical Solutions, LLC.)
+%#
+%# By intentionally submitting any modifications, corrections or
+%# derivatives to this work, or any other work intended for use with
+%# Request Tracker, to Best Practical Solutions, LLC, you confirm that
+%# you are the copyright holder for those contributions and you grant
+%# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable,
+%# royalty-free, perpetual, license to use, copy, create derivative
+%# works based on those contributions, and sublicense and distribute
+%# those contributions and any derivatives thereof.
+%#
+%# END BPS TAGGED BLOCK }}}
+<& /Admin/Elements/Header, Title => $title &>
+<& /Elements/Tabs &>
+<& /Elements/ListActions &>
+
+<form action="Visibility.html" method="post" name="Visibility">
+<input type="hidden" class="hidden" name="id" value="<% $id %>" />
+
+<h2><&|/l, $role->Name &>Visibility for [_1]</&></h2>
+<table cellspacing=10>
+% for (@pages) {
+% my ($label, $url) = @$_;
+ <tr>
+ <td align="left"><% $label %></td>
+ <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="0" <% !$hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>show</&></label></td>
+ <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="1" <% $hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>hide</&></label></td>
+ </tr>
+% }
+</table>
+
+<& /Elements/Submit, Name => 'Update' &>
+
+</form>
+
+<%ARGS>
+$id => undef
+$Update => 0
+</%ARGS>
+<%INIT>
+my $role = RT::CustomRole->new( $session{'CurrentUser'} );
+$role->Load($id) or Abort(loc("Could not load custom role #[_1]", $id));
+$id = $role->id;
+
+if ($role->Disabled) {
+ Abort(loc("Cannot modify objects of disabled custom role #[_1]", $id));
+}
+
+my %hidden = %{ $role->HiddenForURLs };
+
+if ( $Update ) {
+ my (@results);
+
+ for my $key (%ARGS) {
+ if (my ($url) = $key =~ /^hide-(.*)$/) {
+ $hidden{$url} = $ARGS{$key};
+ }
+ }
+
+ my ($ok, $msg) = $role->SetHiddenForURLs(\%hidden);
+ if ($ok) {
+ push @results, loc('Updated visibility');
+ }
+ else {
+ push @results, loc('Unable to update visibility: [_1]', $msg);
+ %hidden = $role->HiddenForURLs;
+ }
+
+ MaybeRedirectForResults(
+ Actions => \@results,
+ Arguments => {
+ id => $id,
+ },
+ );
+}
+
+my @pages = (
+ [loc('Ticket create') => '/Ticket/Create.html'],
+ [loc('Ticket display') => '/Ticket/Display.html'],
+ [loc('Ticket modify people') => '/Ticket/ModifyPeople.html'],
+ [loc('Ticket jumbo') => '/Ticket/ModifyAll.html'],
+);
+
+if ($role->SingleValue) {
+ push @pages, (
+ [loc('Ticket modify basics') => '/Ticket/Modify.html'],
+ [loc('Ticket reply/comment') => '/Ticket/Update.html'],
+ );
+}
+
+my $title = loc('Modify visibility for [_1]', $role->Name);
+</%INIT>
diff --git a/share/html/Elements/SelectWatcherType b/share/html/Elements/SelectWatcherType
index 0fe850d0b..dcc966573 100644
--- a/share/html/Elements/SelectWatcherType
+++ b/share/html/Elements/SelectWatcherType
@@ -67,6 +67,17 @@ else {
@types = $Queue->Roles(Single => 0);
}
+my @NewTypes;
+for my $name (@types) {
+ if (my ($id) = $name =~ /^RT::CustomRole-(\d+)$/) {
+ my $role = RT::CustomRole->new($session{CurrentUser});
+ $role->Load($id);
+ next if $role->IsHiddenForURL;
+ }
+ push @NewTypes, $name;
+}
+ at types = @NewTypes;
+
$m->callback( Types => \@types, %ARGS, CallbackName => 'ModifyWatcherTypes' );
</%INIT>
<%ARGS>
diff --git a/share/html/Ticket/Create.html b/share/html/Ticket/Create.html
index e11f9fb6b..b26ec6bd0 100644
--- a/share/html/Ticket/Create.html
+++ b/share/html/Ticket/Create.html
@@ -176,6 +176,10 @@
% my $roles = $QueueObj->CustomRoles;
% $roles->LimitToMultipleValue;
+
+% my @hidden = $QueueObj->HiddenCustomRoleIDsForURL;
+% $roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
% $m->callback( CallbackName => 'ModifyCustomRoles', ARGSRef => \%ARGS, CustomRoles => $roles );
% while (my $role = $roles->Next) {
<div class="form-row">
diff --git a/share/html/Ticket/Elements/EditBasics b/share/html/Ticket/Elements/EditBasics
index 7f1551288..2ece8b3cd 100644
--- a/share/html/Ticket/Elements/EditBasics
+++ b/share/html/Ticket/Elements/EditBasics
@@ -141,6 +141,10 @@ my @role_fields;
unless ($ExcludeCustomRoles) {
my $roles = $QueueObj->CustomRoles;
$roles->LimitToSingleValue;
+
+ my @hidden = $QueueObj->HiddenCustomRoleIDsForURL;
+ $roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
$m->callback( CallbackName => 'ModifyCustomRoles', %ARGS, CustomRoles => $roles);
while (my $role = $roles->Next) {
push @role_fields, {
diff --git a/share/html/Ticket/Elements/EditPeople b/share/html/Ticket/Elements/EditPeople
index 862d5ed29..7899187d4 100644
--- a/share/html/Ticket/Elements/EditPeople
+++ b/share/html/Ticket/Elements/EditPeople
@@ -81,6 +81,10 @@
% my @role_fields;
% my $single_roles = $Ticket->QueueObj->CustomRoles;
% $single_roles->LimitToSingleValue;
+
+% my @hidden = $Ticket->QueueObj->HiddenCustomRoleIDsForURL;
+% $single_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
% $m->callback( CustomRoles => $single_roles, SingleRoles => 1, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
% while (my $role = $single_roles->Next) {
<div class="form-row">
@@ -125,6 +129,9 @@
% my $multi_roles = $Ticket->QueueObj->CustomRoles;
% $multi_roles->LimitToMultipleValue;
+
+% $multi_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
% $m->callback( CustomRoles => $multi_roles, SingleRoles => 0, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
% while (my $role = $multi_roles->Next) {
% my $group = $Ticket->RoleGroup($role->GroupType);
diff --git a/share/html/Ticket/Elements/ShowPeople b/share/html/Ticket/Elements/ShowPeople
index e9fe45a89..953cd807a 100644
--- a/share/html/Ticket/Elements/ShowPeople
+++ b/share/html/Ticket/Elements/ShowPeople
@@ -57,6 +57,10 @@
% my $single_roles = $Ticket->QueueObj->CustomRoles;
% $single_roles->LimitToSingleValue;
+
+% my @hidden = $Ticket->QueueObj->HiddenCustomRoleIDsForURL;
+% $single_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
% $m->callback( CustomRoles => $single_roles, SingleRoles => 1, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
% while (my $role = $single_roles->Next) {
% my $group = $Ticket->RoleGroup($role->GroupType);
@@ -88,6 +92,9 @@
% my $multi_roles = $Ticket->QueueObj->CustomRoles;
% $multi_roles->LimitToMultipleValue;
+
+% $multi_roles->Limit(FIELD => 'id', OPERATOR => 'NOT IN', VALUE => \@hidden) if @hidden;
+
% $m->callback( CustomRoles => $multi_roles, SingleRoles => 0, Ticket => $Ticket, %ARGS, CallbackName => 'ModifyCustomRoles' );
% while (my $role = $multi_roles->Next) {
<div class="form-row">
commit 6691e962d9a2c1f610655c9bd2f9e21a1c20cdb2
Author: Blaine Motsinger <blaine at bestpractical.com>
Date: Thu Dec 26 17:19:24 2019 -0600
Migrate Visibility.html to elevator themes
diff --git a/share/html/Admin/CustomRoles/Visibility.html b/share/html/Admin/CustomRoles/Visibility.html
index f739866dd..4423568e3 100644
--- a/share/html/Admin/CustomRoles/Visibility.html
+++ b/share/html/Admin/CustomRoles/Visibility.html
@@ -49,23 +49,41 @@
<& /Elements/Tabs &>
<& /Elements/ListActions &>
-<form action="Visibility.html" method="post" name="Visibility">
+<form action="Visibility.html" method="post" name="Visibility" class="mx-auto max-width-lg">
<input type="hidden" class="hidden" name="id" value="<% $id %>" />
-<h2><&|/l, $role->Name &>Visibility for [_1]</&></h2>
-<table cellspacing=10>
+<&| /Widgets/TitleBox, class => 'custom-role-info-visibility', content_class => 'mx-auto width-sm' &>
% for (@pages) {
% my ($label, $url) = @$_;
- <tr>
- <td align="left"><% $label %></td>
- <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="0" <% !$hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>show</&></label></td>
- <td><label><input type="radio" class="radio" name="hide-<% $url %>" value="1" <% $hidden{$url} ? qq[checked="checked"] : qq[] |n %>> <&|/l&>hide</&></label></td>
- </tr>
+ <div class="form-row boolean">
+ <div class="col-md-4 label">
+ <% $label %>:
+ </div>
+ <div class="col-md-8 value">
+ <div class="form-row">
+ <div class="col-md-auto">
+ <div class="custom-control custom-radio">
+ <input type="radio" class="custom-control-input" id="show-<% $url %>" name="hide-<% $url %>" value="0" <% !$hidden{$url} ? qq[checked="checked"] : qq[] |n %>>
+ <label class="custom-control-label" for="show-<% $url %>"><&|/l&>show</&></label>
+ </div>
+ </div>
+ <div class="col-md-auto">
+ <div class="custom-control custom-radio">
+ <input type="radio" class="custom-control-input" id="hide-<% $url %>" name="hide-<% $url %>" value="1" <% $hidden{$url} ? qq[checked="checked"] : qq[] |n %>>
+ <label class="custom-control-label" for="hide-<% $url %>"><&|/l&>hide</&></label>
+ </div>
+ </div>
+ </div>
+ </div>
+ </div>
% }
-</table>
-
-<& /Elements/Submit, Name => 'Update' &>
+</&>
+ <div class="form-row">
+ <div class="col-md-12">
+ <& /Elements/Submit, Name => loc('Update') &>
+ </div>
+ </div>
</form>
<%ARGS>
commit aef6fdb99e8eced0a4924f83fedc41ea7ef50bf2
Author: Blaine Motsinger <blaine at bestpractical.com>
Date: Fri Dec 27 19:52:06 2019 -0600
Add test for customrole visibility
diff --git a/t/web/customrole_visibility.t b/t/web/customrole_visibility.t
new file mode 100644
index 000000000..a9fcec5cc
--- /dev/null
+++ b/t/web/customrole_visibility.t
@@ -0,0 +1,105 @@
+use strict;
+use warnings;
+
+use RT::Test tests => undef;
+
+my ( $baseurl, $m ) = RT::Test->started_ok;
+ok $m->login, 'logged in as root';
+
+my $customrole_name = 'test customrole';
+
+diag( 'Create custom role' );
+
+# create custom role
+$m->follow_link_ok({ id => 'admin-custom-roles-create' }, "Followed link to 'Admin > Custom Roles > Create'" );
+$m->submit_form(
+ form_name => 'ModifyCustomRole',
+ fields => {
+ Name => $customrole_name,
+ },
+);
+$m->content_contains( 'Custom role created', 'Created customrole' );
+
+my $customrole_id = $m->form_name( 'ModifyCustomRole' )->value( 'id' );
+
+# set applies to
+$m->follow_link_ok({ id => 'page-applies-to' }, "Followed link to 'Applies to'" );
+$m->form_name( 'AddRemoveCustomRole' );
+$m->current_form->find_input( 'AddRole-1' )->check;
+$m->click_ok( 'Update', "Added '$customrole_name' to General queue" );
+$m->content_contains( "$customrole_name added to queue General" );
+
+diag( 'Verify visibility is shown by default' );
+
+# ensure all pages are set visible by default
+$m->follow_link_ok({ id => 'page-visibility' }, "Followed link to 'Visibility'" );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/Create.html' ), 'Ticket create is set visible by default' );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/Display.html' ), 'Ticket display is set visible by default' );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyPeople.html' ), 'Ticket modify people is set visible by default' );
+ok( !$m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyAll.html' ), 'Ticket jumbo is set visible by default' );
+
+# confirm each page is visible by default
+$m->get_ok( '/Ticket/Create.html?Queue=1' );
+$m->content_contains( "$customrole_name" );
+
+$m->submit_form(
+ form_name => 'TicketCreate',
+ fields => {
+ Subject => 'test ticket',
+ },
+);
+$m->content_contains( 'Ticket 1 created in queue', 'Created ticket' );
+
+$m->get_ok( '/Ticket/Display.html?id=1' );
+$m->content_contains( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyPeople.html?id=1' );
+$m->content_contains( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyAll.html?id=1' );
+$m->content_contains( "$customrole_name" );
+
+diag( 'Remove visibility' );
+
+# set each visibility to hidden
+$m->follow_link_ok({ id => 'admin-custom-roles-select' }, "Followed link to 'Admin > Custom Roles > Select'" );
+$m->follow_link_ok({ text => $customrole_name }, "Followed link to '$customrole_name'" );
+$m->follow_link_ok({ id => 'page-visibility' }, "Followed link to 'Visibility'" );
+$m->form_name( 'Visibility' );
+$m->current_form->find_input( 'hide-/Ticket/Create.html' )->check;
+$m->current_form->find_input( 'hide-/Ticket/Display.html' )->check;
+$m->current_form->find_input( 'hide-/Ticket/ModifyPeople.html' )->check;
+$m->current_form->find_input( 'hide-/Ticket/ModifyAll.html' )->check;
+$m->click_ok( 'Update', 'Set visibility to hide for all pages' );
+$m->content_contains( 'Updated visibility' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/Create.html' ), 'Ticket create is set hidden' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/Display.html' ), 'Ticket display is set hidden' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyPeople.html' ), 'Ticket modify people is set hidden' );
+ok( $m->form_name( 'Visibility' )->value( 'hide-/Ticket/ModifyAll.html' ), 'Ticket jumbo is set hidden' );
+
+diag( 'Verify visibility is hidden' );
+
+# confirm hidden on each page
+$m->get_ok( '/Ticket/Create.html?Queue=1' );
+$m->content_lacks( "$customrole_name" );
+
+$m->submit_form(
+ form_name => 'TicketCreate',
+ fields => {
+ Subject => 'test ticket 2',
+ },
+);
+$m->content_contains( 'Ticket 2 created in queue', 'Created ticket' );
+
+$m->get_ok( '/Ticket/Display.html?id=2' );
+$m->content_lacks( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyPeople.html?id=2' );
+$m->content_lacks( "$customrole_name" );
+$m->get_ok( '/Ticket/ModifyAll.html?id=2' );
+$m->content_lacks( "$customrole_name" );
+
+# TODO:
+# create customrole not for multiple users
+# verify additional pages customrole is visible for a single user
+# - Ticket modify basics
+# - Ticket reply/comment
+
+done_testing();
commit 129481bc00ccfe555aa5d2809135f16bd86c4b19
Merge: 5a5cfcd8d aef6fdb99
Author: sunnavy <sunnavy at bestpractical.com>
Date: Fri Mar 6 02:55:39 2020 +0800
Merge branch '4.6/core-customrole-visibility' into 5.0-trunk
-----------------------------------------------------------------------
More information about the rt-commit
mailing list