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
|
# --
# 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 (AGPL). If you
# did not receive this file, see http://www.gnu.org/licenses/agpl.txt.
# --
use strict;
use warnings;
use utf8;
use vars (qw($Self));
use Kernel::System::PostMaster;
# get helper object
$Kernel::OM->ObjectParamAdd(
'Kernel::System::UnitTest::Helper' => {
RestoreDatabase => 1,
},
);
my $HelperObject = $Kernel::OM->Get('Kernel::System::UnitTest::Helper');
my $ConfigObject = $Kernel::OM->Get('Kernel::Config');
my $ServiceObject = $Kernel::OM->Get('Kernel::System::Service');
my $CommunicationDBObject = $Kernel::OM->Get('Kernel::System::CommunicationLog::DB');
my $TicketObject = $Kernel::OM->Get('Kernel::System::Ticket');
$ConfigObject->Set(
Key => 'Ticket::Service',
Value => 1,
);
my $ServiceID = $ServiceObject->ServiceAdd(
Name => 'InvalidServiceUnitTestService',
ValidID => 1,
UserID => 1,
);
my @Tests = (
{
ServiceName => 'NotExistingServiceUnitTest',
ExpectedTicketService => '',
InvalidServiceLogCount => 1,
},
{
ServiceName => 'InvalidServiceUnitTestService',
ExpectedTicketService => $ServiceID,
InvalidServiceLogCount => 0,
},
);
for my $Test (@Tests) {
my $CommunicationLogObject = $Kernel::OM->Create(
'Kernel::System::CommunicationLog',
ObjectParams => {
Transport => 'Email',
Direction => 'Incoming',
},
);
$CommunicationLogObject->ObjectLogStart( ObjectLogType => 'Message' );
my $PostMasterObject = Kernel::System::PostMaster->new(
CommunicationLogObject => $CommunicationLogObject,
Email => "From: Provider <customeruser\@unittest.com>
To: Agent <agent\@unittest.com>
Subject: InvalidServiceUnitTest
X-OTRS-Service: $Test->{ServiceName}
Some Content in Body",
);
my @Return = $PostMasterObject->Run();
$CommunicationLogObject->ObjectLogStop(
ObjectLogType => 'Message',
Status => 'Successful',
);
my $ObjectLogList = $CommunicationDBObject->ObjectLogList(
CommunicationID => $CommunicationLogObject->{CommunicationID}
);
my $ObjectLogEntryList = $CommunicationDBObject->ObjectLogEntryList(
CommunicationID => $CommunicationLogObject->{CommunicationID},
ObjectLogID => $ObjectLogList->[0]->{ObjectLogID}
);
my @InvalidServiceLogFound
= grep { $_->{LogValue} =~ /does not exist or is invalid or is a child of invalid service/ }
@{$ObjectLogEntryList};
$Self->Is(
scalar @InvalidServiceLogFound,
$Test->{InvalidServiceLogCount},
"Invalid service for new ticket blocked"
);
my %Ticket = $TicketObject->TicketGet(
TicketID => $Return[1],
UserID => 1,
);
$Self->Is(
$Ticket{ServiceID},
$Test->{ExpectedTicketService},
"Check if ticket has service set"
);
$CommunicationLogObject->CommunicationStop(
Status => 'Successful',
);
}
1;
|