mirror of
https://github.com/Seldaek/monolog.git
synced 2025-10-24 10:06:08 +02:00
- [x] Exclude `extra`/`context`, `datetime`, `level` from message when attachment is used - [x] Use `ts` attachment key to display `datetime` considering user timezone - [x] [Support](https://github.com/Seldaek/monolog/pull/846#issuecomment-249528719) custom user images - [x] [Allow](https://github.com/Seldaek/monolog/pull/894#issuecomment-263532399) to setup username from slack - [x] [Improve](https://github.com/Seldaek/monolog/pull/846#issuecomment-261529198) array formatting within `context`/`extra` - [x] [Support](https://github.com/Seldaek/monolog/issues/745) `include_stacktraces` option when attachment is not used and always include stacktraces when attachment is used - [x] Support `extra`/`context` field exclusion - [x] Update tests
108 lines
3.1 KiB
PHP
108 lines
3.1 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;
|
|
use Monolog\Formatter\LineFormatter;
|
|
use Monolog\Handler\Slack\SlackRecord;
|
|
|
|
/**
|
|
* @author Haralan Dobrev <hkdobrev@gmail.com>
|
|
* @see https://api.slack.com/incoming-webhooks
|
|
* @coversDefaultClass Monolog\Handler\SlackWebhookHandler
|
|
*/
|
|
class SlackWebhookHandlerTest extends TestCase
|
|
{
|
|
const WEBHOOK_URL = 'https://hooks.slack.com/services/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E';
|
|
|
|
/**
|
|
* @covers ::__construct
|
|
* @covers ::getSlackRecord
|
|
*/
|
|
public function testConstructorMinimal()
|
|
{
|
|
$handler = new SlackWebhookHandler(self::WEBHOOK_URL);
|
|
$record = $this->getRecord();
|
|
$slackRecord = $handler->getSlackRecord();
|
|
$this->assertInstanceOf('Monolog\Handler\Slack\SlackRecord', $slackRecord);
|
|
$this->assertEquals(array(
|
|
'attachments' => array(
|
|
array(
|
|
'fallback' => 'test',
|
|
'text' => 'test',
|
|
'color' => SlackRecord::COLOR_WARNING,
|
|
'fields' => array(
|
|
array(
|
|
'title' => 'Level',
|
|
'value' => 'WARNING',
|
|
'short' => false,
|
|
),
|
|
),
|
|
'title' => 'Message',
|
|
'mrkdwn_in' => array('fields'),
|
|
'ts' => $record['datetime']->getTimestamp(),
|
|
),
|
|
),
|
|
), $slackRecord->getSlackData($record));
|
|
}
|
|
|
|
/**
|
|
* @covers ::__construct
|
|
* @covers ::getSlackRecord
|
|
*/
|
|
public function testConstructorFull()
|
|
{
|
|
$handler = new SlackWebhookHandler(
|
|
self::WEBHOOK_URL,
|
|
'test-channel',
|
|
'test-username',
|
|
false,
|
|
':ghost:',
|
|
false,
|
|
false,
|
|
Logger::DEBUG,
|
|
false
|
|
);
|
|
|
|
$slackRecord = $handler->getSlackRecord();
|
|
$this->assertInstanceOf('Monolog\Handler\Slack\SlackRecord', $slackRecord);
|
|
$this->assertEquals(array(
|
|
'username' => 'test-username',
|
|
'text' => 'test',
|
|
'channel' => 'test-channel',
|
|
'icon_emoji' => ':ghost:',
|
|
), $slackRecord->getSlackData($this->getRecord()));
|
|
}
|
|
|
|
/**
|
|
* @covers ::getFormatter
|
|
*/
|
|
public function testGetFormatter()
|
|
{
|
|
$handler = new SlackWebhookHandler(self::WEBHOOK_URL);
|
|
$formatter = $handler->getFormatter();
|
|
$this->assertInstanceOf('Monolog\Formatter\FormatterInterface', $formatter);
|
|
}
|
|
|
|
/**
|
|
* @covers ::setFormatter
|
|
*/
|
|
public function testSetFormatter()
|
|
{
|
|
$handler = new SlackWebhookHandler(self::WEBHOOK_URL);
|
|
$formatter = new LineFormatter();
|
|
$handler->setFormatter($formatter);
|
|
$this->assertSame($formatter, $handler->getFormatter());
|
|
}
|
|
}
|