[Rt-commit] r18900 - rt/3.8/trunk/t/customfields
ruz at bestpractical.com
ruz at bestpractical.com
Fri Mar 20 17:06:00 EDT 2009
Author: ruz
Date: Fri Mar 20 17:05:58 2009
New Revision: 18900
Added:
rt/3.8/trunk/t/customfields/sort_order.t
Log:
* check ordering of custom fields
Added: rt/3.8/trunk/t/customfields/sort_order.t
==============================================================================
--- (empty file)
+++ rt/3.8/trunk/t/customfields/sort_order.t Fri Mar 20 17:05:58 2009
@@ -0,0 +1,93 @@
+#!/usr/bin/perl -w
+
+use strict;
+use warnings;
+
+use Test::More tests => 18;
+use RT::Test;
+use RT::Ticket;
+use RT::CustomField;
+
+my $queue_name = "CFSortQueue-$$";
+my $queue = RT::Test->load_or_create_queue( Name => $queue_name );
+ok($queue && $queue->id, "$queue_name - test queue creation");
+
+diag "create multiple CFs: B, A and C" if $ENV{TEST_VERBOSE};
+my @cfs = ();
+{
+ my $cf = RT::CustomField->new( $RT::SystemUser );
+ my ($ret, $msg) = $cf->Create(
+ Name => "CF B",
+ Queue => $queue->id,
+ Type => 'FreeformSingle',
+ );
+ ok($ret, "Custom Field Order created");
+ push @cfs, $cf;
+}
+{
+ my $cf = RT::CustomField->new( $RT::SystemUser );
+ my ($ret, $msg) = $cf->Create(
+ Name => "CF A",
+ Queue => $queue->id,
+ Type => 'FreeformSingle',
+ );
+ ok($ret, "Custom Field Order created");
+ push @cfs, $cf;
+}
+{
+ my $cf = RT::CustomField->new( $RT::SystemUser );
+ my ($ret, $msg) = $cf->Create(
+ Name => "CF C",
+ Queue => $queue->id,
+ Type => 'FreeformSingle',
+ );
+ ok($ret, "Custom Field Order created");
+ push @cfs, $cf;
+}
+
+my ($baseurl, $m) = RT::Test->started_ok;
+ok $m->login( root => 'password' ), 'logged in';
+
+diag "reorder CFs: C, A and B" if $ENV{TEST_VERBOSE};
+{
+ $m->get( '/Admin/Queues/' );
+ $m->follow_link_ok( {text => $queue->id} );
+ $m->follow_link_ok( {text => 'Ticket Custom Fields'} );
+
+ my @tmp = ($m->content =~ /(CF [ABC])/g);
+ is_deeply(\@tmp, ['CF B', 'CF A', 'CF C']);
+
+ $m->follow_link_ok( {text => 'Move up', n => 2} );
+ $m->follow_link_ok( {text => 'Move up', n => 1} );
+ $m->follow_link_ok( {text => 'Move up', n => 2} );
+
+ @tmp = ($m->content =~ /(CF [ABC])/g);
+ is_deeply(\@tmp, ['CF C', 'CF A', 'CF B']);
+}
+
+diag "check ticket create, display and edit pages" if $ENV{TEST_VERBOSE};
+{
+ $m->submit_form(
+ form_name => "CreateTicketInQueue",
+ fields => { Queue => $queue->Name },
+ );
+
+ my @tmp = ($m->content =~ /(CF [ABC])/g);
+ is_deeply(\@tmp, ['CF C', 'CF A', 'CF B']);
+
+ $m->submit_form(
+ form_name => "TicketCreate",
+ fields => { Subject => 'test' },
+ );
+ my ($tid) = ($m->content =~ /Ticket (\d+) created/i);
+ ok $tid, "created a ticket succesfully";
+
+ @tmp = ($m->content =~ /(CF [ABC])/g);
+ is_deeply(\@tmp, ['CF C', 'CF A', 'CF B']);
+
+ $m->follow_link_ok( {text => 'Custom Fields'} );
+
+ @tmp = ($m->content =~ /(CF [ABC])/g);
+ is_deeply(\@tmp, ['CF C', 'CF A', 'CF B']);
+}
+
More information about the Rt-commit
mailing list