From 35126fdaf965376a42af17be590e8be33a0735ff Mon Sep 17 00:00:00 2001 From: Alexandre Segura Date: Mon, 11 Dec 2017 22:01:37 +0100 Subject: [PATCH 1/3] Handle decrement method. --- src/Client/Client.php | 4 +++- src/DependencyInjection/Configuration.php | 1 + 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/src/Client/Client.php b/src/Client/Client.php index 6e43180..8951fa9 100644 --- a/src/Client/Client.php +++ b/src/Client/Client.php @@ -104,6 +104,8 @@ public function handleEvent($event, $name = null) // increment if ('increment' === $conf) { $this->increment($this->replaceConfigPlaceholder($event, $name, $confValue), 1, $tags); + } elseif ('decrement' === $conf) { + $this->decrement($this->replaceConfigPlaceholder($event, $name, $confValue), 1, $tags); } elseif ('count' === $conf) { $value = $this->getEventValue($event, 'getValue'); $this->count($this->replaceConfigPlaceholder($event, $name, $confValue), $value, 1, $tags); @@ -202,7 +204,7 @@ private function replaceConfigPlaceholder($event, $eventName, $string) * * @param mixed $event * @param array $config - * + * * @return array of tags */ private function mergeTags($event, $config) diff --git a/src/DependencyInjection/Configuration.php b/src/DependencyInjection/Configuration.php index 0f757d8..d896f63 100644 --- a/src/DependencyInjection/Configuration.php +++ b/src/DependencyInjection/Configuration.php @@ -70,6 +70,7 @@ private function addClientsSection($rootNode) ->prototype('array') ->children() ->scalarNode('increment')->end() + ->scalarNode('decrement')->end() ->scalarNode('count')->end() ->scalarNode('gauge')->end() ->scalarNode('set')->end() From 0508049031a722b27f8398f63e79c64df319a52a Mon Sep 17 00:00:00 2001 From: Alexandre Segura Date: Mon, 11 Dec 2017 22:49:16 +0100 Subject: [PATCH 2/3] Add test for decrement method. --- src/Tests/Units/Client/Client.php | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/src/Tests/Units/Client/Client.php b/src/Tests/Units/Client/Client.php index a95afa1..c8b5576 100644 --- a/src/Tests/Units/Client/Client.php +++ b/src/Tests/Units/Client/Client.php @@ -20,6 +20,7 @@ protected function getMockedClient() { $this->mockGenerator->orphanize('__construct'); $this->mockGenerator->orphanize('increment'); + $this->mockGenerator->orphanize('decrement'); $this->mockGenerator->orphanize('timing'); $client = new \mock\M6Web\Bundle\StatsdBundle\Client\Client(); $client->clearToSend(); @@ -51,6 +52,29 @@ public function testHandleEventWithValidConfigIncrement() } + /** + * testHandleEventWithValidConfig + */ + public function testHandleEventWithValidConfigDecrement() + { + $client = $this->getMockedClient(); + + $event = new \Symfony\Component\EventDispatcher\Event(); + + $client->addEventToListen('test', array( + 'decrement' => 'stats.' + )); + + $this->if($client->handleEvent($event, 'test')) + ->then + ->mock($client) + ->call('decrement') + ->withArguments('stats.test') + ->once() + ->call('send') + ->never(); + } + /** * testHandleEventWithImmediateSend */ From 2f6e0f3e945aea3b4314a6d830d15aac9ed60a84 Mon Sep 17 00:00:00 2001 From: Alexandre Segura Date: Mon, 11 Dec 2017 22:49:38 +0100 Subject: [PATCH 3/3] Update CONTRIBUTING.md. --- CONTRIBUTING.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 790aeed..3f1382a 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -8,12 +8,12 @@ If you want to learn more about our opinion on open source, you can read the [OS The features available for now are only those we need, but you're welcome to open an issue or pull-request if you need more. -To ensure good code quality, we use our awesome tool "[coke](https://github.com/M6Web/Coke)" to check there is no coding standards violations. +To ensure good code quality, we use our awesome tool "[coke](https://github.com/M6Web/Coke)" to check there is no coding standards violations. We use [Symfony2 coding standards](https://github.com/M6Web/Symfony2-coding-standard). To execute coke, you need to install dependencies in dev mode ```bash -composer install --dev +composer install ``` And you can launch coke @@ -27,12 +27,12 @@ This bundle is tested with [atoum](https://github.com/atoum/atoum). To launch tests, you need to install dependencies in dev mode ```bash -composer install --dev +composer install ``` And you can now launch tests ```bash -./vendor/bin/atoum +bin/atoum ``` ## Pull-request