1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136
|
# --
# Copyright (C) 2001-2021 OTRS AG, https://otrs.com/
# Copyright (C) 2021 Znuny GmbH, https://znuny.org/
# --
# This software comes with ABSOLUTELY NO WARRANTY. For details, see
# the enclosed file COPYING for license information (GPL). If you
# did not receive this file, see https://www.gnu.org/licenses/gpl-3.0.txt.
# --
use strict;
use warnings;
use utf8;
use vars (qw($Self));
# get needed objects
my $DBObject = $Kernel::OM->Get('Kernel::System::DB');
my $XMLObject = $Kernel::OM->Get('Kernel::System::XML');
# get helper object
$Kernel::OM->ObjectParamAdd(
'Kernel::System::UnitTest::Helper' => {
RestoreDatabase => 1,
},
);
my $HelperObject = $Kernel::OM->Get('Kernel::System::UnitTest::Helper');
# ------------------------------------------------------------ #
# XML test 10 - SQL functions: LOWER(), UPPER()
# ------------------------------------------------------------ #
# test different sizes up to 3999.
# 4000 is a magic value, beyond which locator objects might be used
# and all bets regarding UPPER and LOWER are off
my $XML = '
<TableCreate Name="test_j">
<Column Name="name_a" Required="true" Size="6" Type="VARCHAR"/>
<Column Name="name_b" Required="true" Size="60" Type="VARCHAR"/>
<Column Name="name_c" Required="true" Size="600" Type="VARCHAR"/>
<Column Name="name_d" Required="true" Size="3998" Type="VARCHAR"/>
</TableCreate>
';
my @XMLARRAY = $XMLObject->XMLParse( String => $XML );
my @SQL = $DBObject->SQLProcessor( Database => \@XMLARRAY );
$Self->True(
$SQL[0],
'SQLProcessor() CREATE TABLE',
);
for my $SQL (@SQL) {
$Self->True(
$DBObject->Do( SQL => $SQL ) || 0,
"Do() CREATE TABLE ($SQL)",
);
}
# as 'Ab' is two chars, multiply half the sizes from test_j
my @Values = map { 'Ab' x $_ } ( 3, 30, 300, 1999 );
# insert
my $Result = $DBObject->Do(
SQL => 'INSERT INTO test_j (name_a, name_b, name_c, name_d) VALUES ( ?, ?, ?, ? )',
Bind => [ \(@Values) ],
);
$Self->True(
$Result,
"Do() INSERT",
);
my $SQL = 'SELECT LOWER(name_a), LOWER(name_b), LOWER(name_c), LOWER(name_d) FROM test_j';
$Result = $DBObject->Prepare(
SQL => $SQL,
Limit => 1,
);
$Self->True(
$Result,
'Prepare() - LOWER() - SELECT',
);
while ( my @Row = $DBObject->FetchrowArray() ) {
$Self->Is(
scalar(@Row),
scalar(@Values),
"- LOWER() - Check number of fetched elements",
);
for my $Index ( 0 .. 3 ) {
$Self->Is(
$Row[$Index],
lc( $Values[$Index] ),
"#10.$Index - LOWER() - result",
);
}
}
$SQL = 'SELECT UPPER(name_a), UPPER(name_b), UPPER(name_c), UPPER(name_d) FROM test_j';
$Result = $DBObject->Prepare(
SQL => $SQL,
Limit => 1,
);
$Self->True(
$Result,
'Prepare() - UPPER() - SELECT',
);
while ( my @Row = $DBObject->FetchrowArray() ) {
$Self->Is(
scalar(@Row),
scalar(@Values),
"UPPER() - Check number of fetched elements",
);
for my $Index ( 0 .. 3 ) {
$Self->Is(
$Row[$Index],
uc( $Values[$Index] ),
"$Index - UPPER() - result",
);
}
}
$XML = '<TableDrop Name="test_j"/>';
@XMLARRAY = $XMLObject->XMLParse( String => $XML );
@SQL = $DBObject->SQLProcessor( Database => \@XMLARRAY );
$Self->True(
$SQL[0],
'SQLProcessor() DROP TABLE',
);
for my $SQL (@SQL) {
$Self->True(
$DBObject->Do( SQL => $SQL ) || 0,
"Do() DROP TABLE ($SQL)",
);
}
# cleanup cache is done by RestoreDatabase.
1;
|