| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- <?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 MongoDB\Driver\Manager;
- use Monolog\TestCase;
- use Monolog\Formatter\NormalizerFormatter;
- class MongoDBHandlerTest extends TestCase
- {
- /**
- * @expectedException InvalidArgumentException
- */
- public function testConstructorShouldThrowExceptionForInvalidMongo()
- {
- new MongoDBHandler(new \stdClass, 'db', 'collection');
- }
- public function testHandleWithLibraryClient()
- {
- if (!(class_exists('MongoDB\Client'))) {
- $this->markTestSkipped('mongodb/mongodb not installed');
- }
- $mongodb = $this->getMockBuilder('MongoDB\Client')
- ->disableOriginalConstructor()
- ->getMock();
- $collection = $this->getMockBuilder('MongoDB\Collection')
- ->disableOriginalConstructor()
- ->getMock();
- $mongodb->expects($this->once())
- ->method('selectCollection')
- ->with('db', 'collection')
- ->will($this->returnValue($collection));
- $record = $this->getRecord();
- $expected = $record;
- $expected['datetime'] = $record['datetime']->format(NormalizerFormatter::SIMPLE_DATE);
- $collection->expects($this->once())
- ->method('insertOne')
- ->with($expected);
- $handler = new MongoDBHandler($mongodb, 'db', 'collection');
- $handler->handle($record);
- }
- public function testHandleWithDriverManager()
- {
- if (!(class_exists('MongoDB\Driver\Manager'))) {
- $this->markTestSkipped('ext-mongodb not installed');
- }
- /* This can become a unit test once ManagerInterface can be mocked.
- * See: https://jira.mongodb.org/browse/PHPC-378
- */
- $mongodb = new Manager('mongodb://localhost:27017');
- $handler = new MongoDBHandler($mongodb, 'test', 'monolog');
- $record = $this->getRecord();
- try {
- $handler->handle($record);
- } catch (\RuntimeException $e) {
- $this->markTestSkipped('Could not connect to MongoDB server on mongodb://localhost:27017');
- }
- }
- }
|