-
Notifications
You must be signed in to change notification settings - Fork 113
/
Copy pathtest-log-viewer.php
115 lines (94 loc) · 3.06 KB
/
test-log-viewer.php
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
<?php
/**
* Class LogViewerTest
*
* @package WPDiscourse
*/
namespace WPDiscourse\Test;
use DMS\PHPUnitExtensions\ArraySubset\ArraySubsetAsserts;
use WPDiscourse\Logs\FileManager;
use WPDiscourse\Logs\FileHandler;
use WPDiscourse\Logs\Logger;
use WPDiscourse\Admin\LogViewer;
use WPDiscourse\Admin\FormHelper;
use WPDiscourse\Test\UnitTest;
/**
* Logger test case.
*/
class LogViewerTest extends UnitTest {
use ArraySubsetAsserts;
/**
* Instance of LogViewer.
*
* @access protected
* @var \WPDiscourse\LogViewer\LogViewer
*/
protected $viewer;
/**
* Setup each test.
*/
public function setUp(): void {
parent::setUp();
$this->viewer = new LogViewer( FormHelper::get_instance() );
$this->viewer->setup_options( self::$plugin_options );
}
/**
* Teardown each test.
*/
public function tearDown(): void {
parent::tearDown();
self::$plugin_options['logs-enabled'] = 1;
$this->viewer->setup_options( self::$plugin_options );
}
/**
* It should be disabled if file handler is disabled
*/
public function test_file_handler_not_enabled() {
$handler = new FileHandler( new FileManager() );
$handler_double = \Mockery::mock( $handler )->makePartial();
$handler_double->shouldReceive( 'enabled' )->andReturn( false );
$this->viewer->setup_log_viewer( $handler_double );
$this->assertFalse( $this->viewer->is_enabled() );
ob_start();
$this->viewer->log_viewer_markup();
$markup = ob_get_contents();
ob_end_clean();
$this->assertXmlStringEqualsXmlString( $markup, '<div class="inline"><p>Logs are disabled.</p></div>' );
}
/**
* It should be disabled if logs are not enabled
*/
public function test_logs_not_enabled() {
self::$plugin_options['logs-enabled'] = 0;
$this->viewer->setup_options( self::$plugin_options );
$this->viewer->setup_log_viewer();
$this->assertFalse( $this->viewer->is_enabled() );
ob_start();
$this->viewer->log_viewer_markup();
$markup = ob_get_contents();
ob_end_clean();
$this->assertXmlStringEqualsXmlString( $markup, '<div class="inline"><p>Logs are disabled.</p></div>' );
}
/**
* It should retrieve logs and map them to date, number and file
*/
public function test_log_retrieval() {
$handler = new FileHandler( new FileManager() );
$logger = Logger::create( 'test', self::$plugin_options, $handler );
$logger->info( 'New Log' );
$this->viewer->setup_log_viewer();
$date = $handler->get_date();
$number = $handler->current_file_number();
$file = $handler->current_file_url();
$this->assertArraySubset(
array(
"$date-$number" => array(
'date' => $date,
'number' => $number,
'file' => $file,
),
),
$this->viewer->get_logs()
);
}
}