mirror of
https://github.com/Seldaek/monolog.git
synced 2025-10-24 18:16:10 +02:00
Adds a handler that is capable of sending notices into HipChat, the team communication system provided by Atlassian. This is based on the PushoverHandler and built on top of the socketHandler. The needed configuration is described in the docblock of the HipChatHandler file.
111 lines
3.6 KiB
PHP
111 lines
3.6 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Monolog package.
|
|
*
|
|
* (c) Jordi Boggiano <j.boggiano@seld.be>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Monolog\Handler;
|
|
|
|
use Monolog\TestCase;
|
|
use Monolog\Logger;
|
|
|
|
/**
|
|
* @author Rafael Dohms <rafael@doh.ms>
|
|
* @see https://www.hipchat.com/docs/api
|
|
*/
|
|
class HipChatHandlerTest extends TestCase
|
|
{
|
|
|
|
private $res;
|
|
private $handler;
|
|
|
|
public function testWriteHeader()
|
|
{
|
|
$this->createHandler();
|
|
$this->handler->handle($this->getRecord(Logger::CRITICAL, 'test1'));
|
|
fseek($this->res, 0);
|
|
$content = fread($this->res, 1024);
|
|
|
|
$this->assertRegexp('/POST \/v1\/rooms\/message\?format=json&auth_token=.* HTTP\/1.1\\r\\nHost: api.hipchat.com\\r\\nContent-Type: application\/x-www-form-urlencoded\\r\\nContent-Length: \d{2,4}\\r\\n\\r\\n/', $content);
|
|
|
|
return $content;
|
|
}
|
|
|
|
/**
|
|
* @depends testWriteHeader
|
|
*/
|
|
public function testWriteContent($content)
|
|
{
|
|
$this->assertRegexp('/from=Monolog&room_id=room1¬ify=0&message=test1&message_format=text&color=red$/', $content);
|
|
}
|
|
|
|
public function testWriteWithComplexMessage()
|
|
{
|
|
$this->createHandler();
|
|
$this->handler->handle($this->getRecord(Logger::CRITICAL, 'Backup of database "example" finished in 16 minutes.'));
|
|
fseek($this->res, 0);
|
|
$content = fread($this->res, 1024);
|
|
|
|
$this->assertRegexp('/message=Backup\+of\+database\+%22example%22\+finished\+in\+16\+minutes\./', $content);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideLevelColors
|
|
*/
|
|
public function testWriteWithErrorLevelsAndColors($level, $expectedColor)
|
|
{
|
|
$this->createHandler();
|
|
$this->handler->handle($this->getRecord($level, 'Backup of database "example" finished in 16 minutes.'));
|
|
fseek($this->res, 0);
|
|
$content = fread($this->res, 1024);
|
|
|
|
$this->assertRegexp('/color='.$expectedColor.'/', $content);
|
|
}
|
|
|
|
public function provideLevelColors()
|
|
{
|
|
return array(
|
|
array(Logger::DEBUG, 'gray'),
|
|
array(Logger::INFO, 'green'),
|
|
array(Logger::WARNING, 'yellow'),
|
|
array(Logger::ERROR, 'red'),
|
|
array(Logger::CRITICAL, 'red'),
|
|
array(Logger::ALERT, 'red'),
|
|
array(Logger::EMERGENCY,'red'),
|
|
array(Logger::NOTICE, 'green'),
|
|
);
|
|
}
|
|
|
|
private function createHandler($token = 'myToken', $room = 'room1', $name = 'Monolog', $notify = false)
|
|
{
|
|
$constructorArgs = array($token, $room, $name, $notify, Logger::DEBUG);
|
|
$this->res = fopen('php://memory', 'a');
|
|
$this->handler = $this->getMock(
|
|
'\Monolog\Handler\HipChatHandler',
|
|
array('fsockopen', 'streamSetTimeout', 'closeSocket'),
|
|
$constructorArgs
|
|
);
|
|
|
|
$reflectionProperty = new \ReflectionProperty('\Monolog\Handler\SocketHandler', 'connectionString');
|
|
$reflectionProperty->setAccessible(true);
|
|
$reflectionProperty->setValue($this->handler, 'localhost:1234');
|
|
|
|
$this->handler->expects($this->any())
|
|
->method('fsockopen')
|
|
->will($this->returnValue($this->res));
|
|
$this->handler->expects($this->any())
|
|
->method('streamSetTimeout')
|
|
->will($this->returnValue(true));
|
|
$this->handler->expects($this->any())
|
|
->method('closeSocket')
|
|
->will($this->returnValue(true));
|
|
|
|
$this->handler->setFormatter($this->getIdentityFormatter());
|
|
}
|
|
}
|