diff --git a/composer.json b/composer.json index 4bdf779..18ffb80 100644 --- a/composer.json +++ b/composer.json @@ -13,6 +13,11 @@ "name": "Julius Liebert", "email": "julius.liebert@joblocal.de", "role": "Developer" + }, + { + "name": "Bastian Hofmann", + "email": "bastian.hofmann@joblocal.de", + "role": "Developer" } ], "require": { @@ -39,10 +44,10 @@ }, "scripts": { "lint": [ - "./vendor/bin/phpcs --standard=phpcs.xml --colors -p ." + "phpcs --standard=phpcs.xml --colors -p ." ], "test": [ - "./vendor/bin/phpunit-randomizer -c phpunit.xml --order rand" + "phpunit-randomizer -c phpunit.xml --order rand" ] }, "minimum-stability": "stable" diff --git a/src/Queue/Jobs/SqsSnsJob.php b/src/Queue/Jobs/SqsSnsJob.php index 2d1b57a..bd83e43 100644 --- a/src/Queue/Jobs/SqsSnsJob.php +++ b/src/Queue/Jobs/SqsSnsJob.php @@ -18,9 +18,16 @@ class SqsSnsJob extends SqsJob * @param array $job * @param string $connectionName * @param array $routes + * @return void */ - public function __construct(Container $container, SqsClient $sqs, array $job, $connectionName, $queue, array $routes) - { + public function __construct( + Container $container, + SqsClient $sqs, + array $job, + $connectionName, + $queue, + array $routes + ) { parent::__construct($container, $sqs, $job, $connectionName, $queue); $this->job = $this->resolveSnsSubscription($this->job, $routes); @@ -33,7 +40,7 @@ public function __construct(Container $container, SqsClient $sqs, array $job, $c * @param array $routes * @return array */ - private function resolveSnsSubscription(array $job, array $routes) + protected function resolveSnsSubscription(array $job, array $routes) { $body = json_decode($job['Body'], true); @@ -51,22 +58,47 @@ private function resolveSnsSubscription(array $job, array $routes) } if ($commandName !== null) { - // restructure job body + // If there is a command available, we will resolve the job instance for it from + // the service container, passing in the subject and the payload of the + // notification. + + $command = $this->makeCommand($commandName, $body); + + // The instance for the job will then be serialized and the body of + // the job is reconstructed. + $job['Body'] = json_encode([ 'job' => CallQueuedHandler::class . '@call', - 'data' => [ - 'commandName' => $commandName, - 'command' => serialize(new $commandName( - $body['Subject'], - json_decode($body['Message'], true) - )) - ], + 'data' => compact('commandName', 'command'), ]); } return $job; } + /** + * Make the serialized command. + * + * @param string $commandName + * @param array $body + * @return string + */ + protected function makeCommand($commandName, $body) + { + $payload = json_decode($body['Message'], true); + + $data = [ + 'subject' => $body['Subject'], + 'payload' => $payload + ]; + + $instance = $this->container->make($commandName, $data); + + return serialize($instance); + } + + + /** * Get the underlying raw SQS job. * diff --git a/tests/SqsSnsJobTest.php b/tests/SqsSnsJobTest.php index 8bef652..82c4343 100644 --- a/tests/SqsSnsJobTest.php +++ b/tests/SqsSnsJobTest.php @@ -19,7 +19,7 @@ protected function setUp() ->disableOriginalConstructor() ->getMock(); - $this->container = $this->createMock(Container::class); + $this->container = new Container; } private function createSqsSnsJob($routes = []) diff --git a/tests/SqsSnsQueueTest.php b/tests/SqsSnsQueueTest.php index ecf6105..f2bf969 100644 --- a/tests/SqsSnsQueueTest.php +++ b/tests/SqsSnsQueueTest.php @@ -46,7 +46,10 @@ public function testWillSetRoutes() public function testWillCallReceiveMessage() { $this->sqsClient->expects($this->once()) - ->method('receiveMessage'); + ->method('receiveMessage') + ->willReturn([ + 'Messages' => [], + ]); $queue = new SqsSnsQueue($this->sqsClient, 'default_queue'); $queue->setContainer($this->createMock(Container::class));