Skip to content

Commit

Permalink
adding Logging spec
Browse files Browse the repository at this point in the history
  • Loading branch information
samsonasik committed Nov 12, 2016
1 parent ac4ef4f commit 8ed58ab
Showing 1 changed file with 153 additions and 0 deletions.
153 changes: 153 additions & 0 deletions spec/Handler/LoggingSpec.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,153 @@
<?php

namespace ErrorHeroModule\Spec\Handler;

use ErrorHeroModule\Handler\Logging;
use Kahlan\Plugin\Double;
use ReflectionProperty;
use Zend\Http\PhpEnvironment\Request;
use Zend\Log\Logger;
use Zend\Mail\Message;
use Zend\Mail\Transport\TransportInterface;
use Zend\Stdlib\SplPriorityQueue;
use Zend\Log\Writer\Db as DbWriter;
use Zend\Db\TableGateway\TableGateway;
use Zend\Db\Sql\Select;
use Zend\Db\Sql\Sql;
use Zend\Db\ResultSet\HydratingResultSet;

describe('LoggingSpec', function () {

beforeAll(function () {
$this->logger = Double::instance(['extends' => Logger::class]);
$this->serverUrl = 'http://serverUrl';
$this->requestUri = '/';
$this->request = Double::instance(['extends' => Request::class, 'methods' => '__construct']);
$this->errorHeroModuleLocalConfig = [
'enable' => true,
'display-settings' => [

// excluded php errors
'exclude-php-errors' => [
E_USER_DEPRECATED
],

// show or not error
'display_errors' => 0,

// if enable and display_errors = 0, the page will bring layout and view
'template' => [
'layout' => 'layout/layout',
'view' => 'error-hero-module/error-default'
],

// if enable and display_errors = 0, the console will bring message
'console' => [
'message' => 'We have encountered a problem and we can not fulfill your request. An error report has been generated and send to the support team and someone will attend to this problem urgently. Please try again later. Thank you for your patience.',
],

],
'logging-settings' => [
'same-error-log-time-range' => 86400,
],
'email-notification-settings' => [
// set to true to activate email notification on log error
'enable' => false,

// Zend\Mail\Message instance registered at service manager
'mail-message' => 'YourMailMessageService',

// Zend\Mail\Transport\TransportInterface instance registered at service manager
'mail-transport' => 'YourMailTransportService',

// email sender
'email-from' => 'Sender Name <[email protected]>',

'email-to-send' => [
'[email protected]',
'[email protected]',
],
],
];
$this->logWritersConfig = [

[
'name' => 'db',
'options' => [
'db' => 'Zend\Db\Adapter\Adapter',
'table' => 'log',
'column' => [
'timestamp' => 'date',
'priority' => 'type',
'message' => 'event',
'extra' => [
'url' => 'url',
'file' => 'file',
'line' => 'line',
'error_type' => 'error_type',
'trace' => 'trace',
'request_data' => 'request_data',
],
],
],
],

];

$this->dbWriter = Double::instance(['extends' => DbWriter::class, 'methods' => '__construct']);
$reflectionProperty = new ReflectionProperty($this->dbWriter, 'db');
$reflectionProperty->setAccessible(true);
$reflectionProperty->setValue($this->dbWriter, Double::instance(['extends' => 'Zend\Db\Adapter\Adapter', 'methods' => '__construct']));

$splPriorityQueue = new SplPriorityQueue();
$splPriorityQueue->insert($this->dbWriter, 1);

$this->logger->setWriters($splPriorityQueue);
});

given('logging', function () {
return new Logging(
$this->logger,
$this->serverUrl,
$this->request,
$this->requestUri,
$this->errorHeroModuleLocalConfig,
$this->logWritersConfig,
null,
null
);
});

describe('->handleException()', function () {

it('not log if exists', function () {

$sql = Double::instance(['extends' => Sql::class, 'methods' => '__construct']);
allow(TableGateway::class)->toReceive('getSql')->andReturn($sql);

$select = Double::instance(['extends' => Select::class, 'methods' => '__construct']);
allow($select)->toReceive('where');
allow($select)->toReceive('order');
allow($select)->toReceive('limit');
allow($sql)->toReceive('select')->andReturn($select);

$resultSet = Double::instance(['extends' => HydratingResultSet::class, 'methods' => '__construct']);

allow($resultSet)->toReceive('toArray')->andReturn([
0 => [
'date' => date('Y-m-d H:i:s'),
],
]);
allow($resultSet)->toReceive('count')->andReturn(1);
allow(TableGateway::class)->toReceive('selectWith')->with($select)->andReturn($resultSet);

expect($this->logger)->not->toReceive('log');

$exception = new \Exception();
$this->logging->handleException($exception);

});

});

});

0 comments on commit 8ed58ab

Please sign in to comment.