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
|
<?php
/*
** Zabbix
** Copyright (C) 2001-2022 Zabbix SIA
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
require_once dirname(__FILE__).'/../../include/CLegacyWebTest.php';
class testPageReportsActionLog extends CLegacyWebTest {
public function testPageReportsActionLog_CheckLayout() {
// dates can be in relative format, example: now-1y/y, now-1w, now
$this->zbxTestLogin('auditacts.php?from=now-2y&to=now');
$this->zbxTestCheckTitle('Action log');
$this->zbxTestAssertElementPresentId('config');
$this->zbxTestCheckHeader('Action log');
$this->zbxTestTextPresent('Recipient');
$this->zbxTestAssertElementPresentId('filter_userids__ms');
$this->zbxTestAssertElementPresentXpath("//button[@name='filter_set']");
$this->zbxTestAssertElementPresentXpath("//button[contains(text(),'Reset')]");
$this->zbxTestTextPresent(['Time', 'Action','Type', 'Status', 'Recipient', 'Message', 'Status', 'Info']);
}
public static function allAuditActions() {
return CDBHelper::getDataProvider('SELECT * FROM alerts ORDER BY alertid LIMIT 7');
}
/**
* @dataProvider allAuditActions
*/
public function testPageReportsActionLog_CheckValues($auditactions) {
$time = $auditactions['clock'];
$today = date("Y-m-d H:i:s", $time);
$this->zbxTestLogin('auditacts.php?'.http_build_query([
'from' => date('Y-m-d H:i:s', $time - 3600),
'to' => date('Y-m-d H:i:s', $time + 3600)
]));
$this->zbxTestCheckTitle('Action log');
$this->zbxTestAssertElementPresentId('config');
$this->zbxTestCheckHeader('Action log');
$status = '';
$type = '';
$retries = '';
if ($auditactions['status'] == 1 && $auditactions['alerttype'] == 0) {
$status = 'Sent';
}
if ($auditactions['status'] == 0 && $auditactions['alerttype'] == 0 && $auditactions['retries'] == 0) {
$status = 'Failed';
}
if ($auditactions['status'] == 0 && $auditactions['alerttype'] == 0 && $auditactions['retries'] <> 0) {
$status = 'In progress';
}
if ($auditactions['status'] == 1 && $auditactions['alerttype'] == 1) {
$status = 'Executed';
}
$sql = 'SELECT mt.name FROM media_type mt, alerts a WHERE a.mediatypeid = mt.mediatypeid AND a.alertid='.zbx_dbstr($auditactions['alertid']);
$type = DBfetch(DBselect($sql));
if ($auditactions['status'] == 1) {
$retries = '';
}
if ($status == 'In progress' || $status == 'not sent') {
$retries = $auditactions['retries'];
}
$message = str_replace('>', '>', $auditactions['message']);
$subject = str_replace('>', '>', $auditactions['subject']);
$info = str_replace('"', '&quot;', $auditactions['error']);
$this->zbxTestTextPresent(
[
$today,
CTestArrayHelper::get($type, 'name'),
$status,
$retries,
$auditactions['sendto'],
$subject,
$message,
$info
]
);
$this->zbxTestExpandFilterTab();
$this->zbxTestClickButtonMultiselect('filter_userids_');
$this->zbxTestLaunchOverlayDialog('Users');
$this->zbxTestClickLinkText('guest');
$this->zbxTestClickXpathWait("//button[@name='filter_set']");
$this->zbxTestTextPresent('No data found.');
$this->zbxTestClickButtonText('Reset');
}
}
|