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 137 138 139 140 141 142 143 144
|
# --
# 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 1 (XML:TableCreate, SQL:Insert, SQL:Select, SQL:Delete, XML:TableDrop)
# ------------------------------------------------------------ #
my $XML = '
<TableCreate Name="test_a">
<Column Name="name_a" Required="true" Size="60" Type="VARCHAR"/>
<Column Name="name_b" Required="true" Size="60" Type="VARCHAR"/>
<Index Name="index_test_name_a">
<IndexColumn Name="name_a"/>
</Index>
</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)",
);
}
$Self->True(
$DBObject->Do(
SQL => 'INSERT INTO test_a (name_a, name_b) VALUES (\'Some\', \'Lalala\')',
)
|| 0,
'Do() INSERT',
);
$Self->True(
$DBObject->Prepare(
SQL => 'SELECT * FROM test_a WHERE name_a = \'Some\'',
Limit => 1,
),
'Prepare() SELECT - Prepare',
);
$Self->True(
ref( $DBObject->FetchrowArray() ) eq '' &&
ref( $DBObject->FetchrowArray() ) eq '',
'FetchrowArray () SELECT',
);
# rename table
$XML = '<TableAlter NameOld="test_a" NameNew="test_aa"/>';
@XMLARRAY = $XMLObject->XMLParse( String => $XML );
@SQL = $DBObject->SQLProcessor( Database => \@XMLARRAY );
$Self->True(
$SQL[0],
'SQLProcessor() ALTER TABLE',
);
for my $SQL (@SQL) {
$Self->True(
$DBObject->Do( SQL => $SQL ) || 0,
"Do() ALTER TABLE ($SQL)",
);
}
$Self->True(
$DBObject->Prepare(
SQL => 'SELECT * FROM test_aa WHERE name_a = \'Some\'',
Limit => 1,
),
'Prepare() SELECT - Prepare',
);
$Self->True(
ref( $DBObject->FetchrowArray() ) eq '' &&
ref( $DBObject->FetchrowArray() ) eq '',
'FetchrowArray () SELECT',
);
$Self->True(
$DBObject->Prepare(
SQL => 'SELECT DISTINCT * FROM test_aa WHERE name_a = \'Some\'',
Limit => 1,
),
'Prepare() SELECT DISTINCT - Limit - Prepare',
);
$Self->True(
ref( $DBObject->FetchrowArray() ) eq '' &&
ref( $DBObject->FetchrowArray() ) eq '',
'FetchrowArray () SELECT DISTINCT - Limit',
);
$Self->True(
$DBObject->Do(
SQL => 'DELETE FROM valid WHERE name = \'Some\'',
)
|| 0,
'Do() DELETE',
);
$XML = '<TableDrop Name="test_aa"/>';
@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;
|