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) 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));
my $CommandObject = $Kernel::OM->Get('Kernel::System::Console::Command::Admin::Group::UserLink');
my ( $Result, $ExitCode );
# get helper object
$Kernel::OM->ObjectParamAdd(
'Kernel::System::UnitTest::Helper' => {
RestoreDatabase => 1,
},
);
my $HelperObject = $Kernel::OM->Get('Kernel::System::UnitTest::Helper');
my $RandomName = $HelperObject->GetRandomID();
# try to execute command without any options
$ExitCode = $CommandObject->Execute();
$Self->Is(
$ExitCode,
1,
"No options",
);
# provide minimum options (invalid user)
$ExitCode = $CommandObject->Execute( '--user-name', $RandomName, '--group-name', $RandomName, '--permission', 'ro' );
$Self->Is(
$ExitCode,
1,
"Minimum options (but user doesn't exist)",
);
# provide minimum options (invalid group)
$ExitCode
= $CommandObject->Execute( '--user-name', 'root@localhost', '--group-name', $RandomName, '--permission', 'ro' );
$Self->Is(
$ExitCode,
1,
"Minimum options (but group doesn't exist)",
);
# provide minimum options (invalid permission)
$ExitCode
= $CommandObject->Execute( '--user-name', 'root@localhost', '--group-name', $RandomName, '--permission', 'xx' );
$Self->Is(
$ExitCode,
1,
"Minimum options (but invalid permission parameter)",
);
# disable email checks to create new user
$Kernel::OM->Get('Kernel::Config')->Set(
Key => 'CheckEmailAddresses',
Value => 0,
);
# add users
my $UserRand = 'user' . $RandomName;
my $UserID = $Kernel::OM->Get('Kernel::System::User')->UserAdd(
UserFirstname => 'Firstname Test1',
UserLastname => 'Lastname Test1',
UserLogin => $UserRand,
UserEmail => $UserRand . '@example.com',
ValidID => 1,
ChangeUserID => 1,
);
$Self->True(
$UserID,
"Test user is created - $UserRand",
);
# add group
my $GroupRand = 'group' . $RandomName;
my $GroupID = $Kernel::OM->Get('Kernel::System::Group')->GroupAdd(
Name => $GroupRand,
ValidID => 1,
UserID => 1,
);
$Self->True(
$GroupID,
"Test group is created - $GroupRand",
);
# provide minimum options (okay)
$ExitCode = $CommandObject->Execute( '--user-name', $UserRand, '--group-name', $GroupRand, '--permission', 'ro' );
$Self->Is(
$ExitCode,
0,
"Minimum options (parameters okay - set 'ro' permission for test user in test group)",
);
# set to rw permission
$ExitCode = $CommandObject->Execute( '--user-name', $UserRand, '--group-name', $GroupRand, '--permission', 'rw' );
$Self->Is(
$ExitCode,
0,
"Minimum options (parameters okay - set 'rw' permission for test user in test group)",
);
# cleanup is done by RestoreDatabase
1;
|