|
13 | 13 |
|
14 | 14 | use Monolog\Attribute\AsMonologProcessor; |
15 | 15 | use Monolog\Attribute\WithMonologChannel; |
| 16 | +use Monolog\Handler\ElasticaHandler; |
| 17 | +use Monolog\Handler\ElasticsearchHandler; |
16 | 18 | use Monolog\Handler\FingersCrossed\ErrorLevelActivationStrategy; |
17 | 19 | use Monolog\Handler\RollbarHandler; |
18 | 20 | use Monolog\Logger; |
@@ -876,6 +878,60 @@ public function testWithLoggerChannelAutoconfiguration(): void |
876 | 878 | ], $container->getDefinition(ServiceWithChannel::class)->getTag('monolog.logger')); |
877 | 879 | } |
878 | 880 |
|
| 881 | + public function testElasticsearchAndElasticaHandlers() |
| 882 | + { |
| 883 | + if (Logger::API < 2) { |
| 884 | + $this->markTestSkipped('Monolog >= 2 is needed.'); |
| 885 | + } |
| 886 | + |
| 887 | + $container = new ContainerBuilder(); |
| 888 | + $container->setDefinition('elasticsearch.client', new Definition('Elasticsearch\\Client')); |
| 889 | + $container->setDefinition('elastica.client', new Definition('Elastica\\Client')); |
| 890 | + |
| 891 | + $config = [[ |
| 892 | + 'handlers' => [ |
| 893 | + 'es_handler' => [ |
| 894 | + 'type' => 'elastic_search', |
| 895 | + 'elasticsearch' => [ |
| 896 | + 'hosts' => ['es:9200'], |
| 897 | + ], |
| 898 | + 'index' => 'my-index', |
| 899 | + 'document_type' => 'my-type', |
| 900 | + ], |
| 901 | + 'elastica_handler' => [ |
| 902 | + 'type' => 'elastica', |
| 903 | + 'elasticsearch' => [ |
| 904 | + 'hosts' => ['es:9200'], |
| 905 | + ], |
| 906 | + 'index' => 'my-index', |
| 907 | + 'document_type' => 'my-type', |
| 908 | + ], |
| 909 | + ], |
| 910 | + ]]; |
| 911 | + |
| 912 | + $extension = new MonologExtension(); |
| 913 | + $extension->load($config, $container); |
| 914 | + |
| 915 | + $this->assertTrue($container->hasDefinition('monolog.handler.es_handler')); |
| 916 | + $this->assertTrue($container->hasDefinition('monolog.handler.elastica_handler')); |
| 917 | + |
| 918 | + // Elasticsearch handler should receive the elasticsearch.client as first argument |
| 919 | + $esHandler = $container->getDefinition('monolog.handler.es_handler'); |
| 920 | + $this->assertSame(ElasticsearchHandler::class,$esHandler->getClass()); |
| 921 | + $esClient = $esHandler->getArgument(0); |
| 922 | + $this->assertInstanceOf(Definition::class, $esClient); |
| 923 | + $this->assertStringEndsWith('Elasticsearch\Client', $esClient->getClass()); |
| 924 | + $this->assertSame(['hosts' => ['es:9200']], $esClient->getArgument(0)); |
| 925 | + |
| 926 | + // Elastica handler should receive the elastica.client as first argument |
| 927 | + $elasticaHandler = $container->getDefinition('monolog.handler.elastica_handler'); |
| 928 | + $this->assertSame(ElasticaHandler::class,$elasticaHandler->getClass()); |
| 929 | + $elasticaClient = $elasticaHandler->getArgument(0); |
| 930 | + $this->assertInstanceOf(Definition::class, $elasticaClient); |
| 931 | + $this->assertSame('Elastica\Client', $elasticaClient->getClass()); |
| 932 | + $this->assertSame(['hosts' => ['es:9200'], 'transport' => 'Http'], $elasticaClient->getArgument(0)); |
| 933 | + } |
| 934 | + |
879 | 935 | protected function getContainer(array $config = [], array $thirdPartyDefinitions = []): ContainerBuilder |
880 | 936 | { |
881 | 937 | $container = new ContainerBuilder(new EnvPlaceholderParameterBag()); |
|
0 commit comments