1
0
mirror of https://github.com/Seldaek/monolog.git synced 2025-08-06 21:26:43 +02:00

Fix syslog transport to follow the spec closer, fixes #476

This commit is contained in:
Jordi Boggiano
2014-12-17 10:46:48 +00:00
parent ebd0f73fbe
commit 5bee6fe56c
2 changed files with 13 additions and 40 deletions

View File

@@ -18,7 +18,7 @@ use Monolog\TestCase;
*/
class UdpSocketTest extends TestCase
{
public function testWeDoNotSplitShortMessages()
public function testWeDoNotTruncateShortMessages()
{
$socket = $this->getMock('\Monolog\Handler\SyslogUdp\UdpSocket', array('send'), array('lol', 'lol'));
@@ -29,29 +29,18 @@ class UdpSocketTest extends TestCase
$socket->write("The quick brown fox jumps over the lazy dog", "HEADER: ");
}
public function testWeSplitLongMessages()
public function testLongMessagesAreTruncated()
{
$socket = $this->getMock('\Monolog\Handler\SyslogUdp\UdpSocket', array('send'), array('lol', 'lol'));
$socket->expects($this->at(1))
$truncatedString = str_repeat("derp", 16254).'d';
$socket->expects($this->exactly(1))
->method('send')
->with("The quick brown fox jumps over the lazy dog");
->with("HEADER" . $truncatedString);
$aStringOfLength2048 = str_repeat("derp", 2048/4);
$longString = str_repeat("derp", 20000);
$socket->write($aStringOfLength2048."The quick brown fox jumps over the lazy dog");
}
public function testAllSplitMessagesHasAHeader()
{
$socket = $this->getMock('\Monolog\Handler\SyslogUdp\UdpSocket', array('send'), array('lol', 'lol'));
$socket->expects($this->exactly(5))
->method('send')
->with($this->stringStartsWith("HEADER"));
$aStringOfLength8192 = str_repeat("derp", 2048);
$socket->write($aStringOfLength8192, "HEADER");
$socket->write($longString, "HEADER");
}
}