mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-25 10:36:33 +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());
 | |
|     }
 | |
| }
 |