-
Notifications
You must be signed in to change notification settings - Fork 141
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[2.x] Fixes
escapeshellarg: argument exceeds the allowed length
(#113)
* Fixes `escapeshellarg: argument exceeds the allowed length` causing thousands of queue invocations * Fixes tests * Adds queue handler test * Apply fixes from StyleCI Co-authored-by: Taylor Otwell <taylorotwell@users.noreply.github.com>
- Loading branch information
1 parent
ce1e96a
commit 553d210
Showing
7 changed files
with
286 additions
and
48 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
<?php | ||
|
||
namespace Laravel\Vapor\Events; | ||
|
||
use ArrayAccess; | ||
use Illuminate\Contracts\Support\Arrayable; | ||
use Illuminate\Support\Arr; | ||
|
||
class LambdaEvent implements ArrayAccess, Arrayable | ||
{ | ||
/** | ||
* The underlying event. | ||
* | ||
* @var array | ||
*/ | ||
protected $event; | ||
|
||
/** | ||
* Creates a new event instance. | ||
* | ||
* @param array $event | ||
* @return void | ||
*/ | ||
public function __construct($event) | ||
{ | ||
$this->event = $event; | ||
} | ||
|
||
/** | ||
* Determine if an item exists at an offset. | ||
* | ||
* @param string $key | ||
* @return bool | ||
*/ | ||
#[\ReturnTypeWillChange] | ||
public function offsetExists($key) | ||
{ | ||
return Arr::exists($this->event, $key); | ||
} | ||
|
||
/** | ||
* Get an item at a given offset. | ||
* | ||
* @param string $key | ||
* @return array|string|int | ||
*/ | ||
#[\ReturnTypeWillChange] | ||
public function offsetGet($key) | ||
{ | ||
return Arr::get($this->event, $key); | ||
} | ||
|
||
/** | ||
* Set the item at a given offset. | ||
* | ||
* @param string $key | ||
* @param array|string|int $value | ||
* @return void | ||
*/ | ||
#[\ReturnTypeWillChange] | ||
public function offsetSet($key, $value) | ||
{ | ||
Arr::set($this->event, $key, $value); | ||
} | ||
|
||
/** | ||
* Unset the item at a given offset. | ||
* | ||
* @param string $key | ||
* @return void | ||
*/ | ||
#[\ReturnTypeWillChange] | ||
public function offsetUnset($key) | ||
{ | ||
Arr::forget($this->event, $key); | ||
} | ||
|
||
/** | ||
* Get the instance as an array. | ||
* | ||
* @return array | ||
*/ | ||
public function toArray() | ||
{ | ||
return $this->event; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
{ | ||
"Records":[ | ||
{ | ||
"messageId":"58600123-d011-4d76-af5d-960159ca44aa", | ||
"receiptHandle":"AQEBberAbZm/iuRDZevRaZ1cd1arwj3mHxvAZo/972KO8UH+HiNMTOMl66TPi/pZUbNYu+owiBzhyVGafAJuGDz9+LoyzEt6JqxMrzOKV7C3IO6wRZsUKRBKrlfr42KKP/+KS8zQUJE3QIgWiAwEfEwTnbSLhsxfqGxTFWzLh5+Or7u8U10p3K8tdDozssv2Hr39RhkiOKbuE2CS1U6f1oUvHowIr6o5vqNy9xxEiYr/XDXqbsReBE5zw531guvXxJagJjjKhxaNJoIozuYotF/+TeAz8/0Y0kuQTHZY0/tgS79MWGIPEL6izkF5uDm2lKo5PP4SKqfNMvNHS/i5u35mqzOQfHhJytLMWoRmCwUShI4KSaVNkkX+4ZyBpflOpLQl6u/DJ5TbfgkzWOJqhV+DQQ==", | ||
"body":"{\"uuid\":\"0a0bcc75-f78b-4f15-b834-78e71c56afa3\",\"displayName\":\"Closure (web.php:19)\",\"job\":\"Illuminate\\\\Queue\\\\CallQueuedHandler@call\",\"maxTries\":null,\"maxExceptions\":null,\"failOnTimeout\":false,\"backoff\":null,\"timeout\":null,\"retryUntil\":null,\"data\":{\"commandName\":\"Illuminate\\\\Queue\\\\CallQueuedClosure\",\"command\":\"O:34:\\\"Illuminate\\\\Queue\\\\CallQueuedClosure\\\":14:{s:7:\\\"closure\\\";O:47:\\\"Laravel\\\\SerializableClosure\\\\SerializableClosure\\\":1:{s:12:\\\"serializable\\\";O:46:\\\"Laravel\\\\SerializableClosure\\\\Serializers\\\\Signed\\\":2:{s:12:\\\"serializable\\\";s:432:\\\"O:46:\\\"Laravel\\\\SerializableClosure\\\\Serializers\\\\Native\\\":5:{s:3:\\\"use\\\";a:1:{s:10:\\\"collection\\\";O:29:\\\"Illuminate\\\\Support\\\\Collection\\\":2:{s:8:\\\"\\u0000*\\u0000items\\\";a:1:{i:0;s:4:\\\"nuno\\\";}s:28:\\\"\\u0000*\\u0000escapeWhenCastingToString\\\";b:0;}}s:8:\\\"function\\\";s:79:\\\"function () use ($collection) {\\n \\\\info($collection->implode(','));\\n }\\\";s:5:\\\"scope\\\";s:37:\\\"Illuminate\\\\Routing\\\\RouteFileRegistrar\\\";s:4:\\\"this\\\";N;s:4:\\\"self\\\";s:32:\\\"00000000000001a10000000000000000\\\";}\\\";s:4:\\\"hash\\\";s:44:\\\"bl2j1wIRyXIqlgbMDpY7+kCIUvwcJwhHde9gTY7Ma4E=\\\";}}s:16:\\\"failureCallbacks\\\";a:0:{}s:23:\\\"deleteWhenMissingModels\\\";b:1;s:7:\\\"batchId\\\";N;s:3:\\\"job\\\";N;s:10:\\\"connection\\\";N;s:5:\\\"queue\\\";N;s:15:\\\"chainConnection\\\";N;s:10:\\\"chainQueue\\\";N;s:19:\\\"chainCatchCallbacks\\\";N;s:5:\\\"delay\\\";N;s:11:\\\"afterCommit\\\";N;s:10:\\\"middleware\\\";a:0:{}s:7:\\\"chained\\\";a:0:{}}\"},\"attempts\":0}", | ||
"attributes":{ | ||
"ApproximateReceiveCount":"1", | ||
"SentTimestamp":"1639158884706", | ||
"SenderId":"AROATHDQZYADPZZTHGFLF:vapor-laravel-staging", | ||
"ApproximateFirstReceiveTimestamp":"1639158884710" | ||
}, | ||
"messageAttributes":[ | ||
|
||
], | ||
"md5OfBody":"28381da423cdb6fb5ba21f2eccb4fea1", | ||
"eventSource":"aws:sqs", | ||
"eventSourceARN":"arn:aws:sqs:eu-west-3:221427384326:laravel-staging", | ||
"awsRegion":"eu-west-3" | ||
} | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
<?php | ||
|
||
namespace Laravel\Vapor\Tests\Unit; | ||
|
||
use Laravel\Vapor\Events\LambdaEvent; | ||
use PHPUnit\Framework\TestCase; | ||
|
||
class LambdaEventTest extends TestCase | ||
{ | ||
public function test_to_array() | ||
{ | ||
$event = $this->getEvent(); | ||
|
||
$this->assertIsArray($event->toArray()); | ||
} | ||
|
||
public function test_array_access() | ||
{ | ||
$event = $this->getEvent(); | ||
|
||
$this->assertIsArray($event['Records']); | ||
|
||
$this->assertSame('58600123-d011-4d76-af5d-960159ca44aa', $event['Records.0.messageId']); | ||
$this->assertSame('1', $event['Records.0.attributes.ApproximateReceiveCount']); | ||
|
||
unset($event['Records']); | ||
$this->assertFalse(isset($event['Records'])); | ||
|
||
$event['Records'] = [['messageId' => 'foo']]; | ||
$this->assertTrue(isset($event['Records'])); | ||
$this->assertSame('foo', $event['Records.0.messageId']); | ||
} | ||
|
||
public function getEvent() | ||
{ | ||
return new LambdaEvent(json_decode( | ||
file_get_contents(__DIR__.'/../Fixtures/lambdaEvent.json'), | ||
true | ||
)); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
<?php | ||
|
||
namespace Laravel\Vapor\Tests\Unit; | ||
|
||
use Laravel\Vapor\Events\LambdaEvent; | ||
use Laravel\Vapor\Runtime\Handlers\QueueHandler; | ||
use Mockery; | ||
use Orchestra\Testbench\TestCase; | ||
|
||
class QueueHandlerTest extends TestCase | ||
{ | ||
protected function setUp(): void | ||
{ | ||
parent::setUp(); | ||
|
||
FakeJob::$handled = false; | ||
} | ||
|
||
protected function tearDown(): void | ||
{ | ||
Mockery::close(); | ||
} | ||
|
||
public function test_job_can_be_called() | ||
{ | ||
$this->assertFalse(FakeJob::$handled); | ||
|
||
$job = new FakeJob; | ||
|
||
$event = $this->getEvent(); | ||
|
||
$event['Records'][0]['body'] = json_encode([ | ||
'displayName' => FakeJob::class, | ||
'job' => 'Illuminate\Queue\CallQueuedHandler@call', | ||
'maxTries' => null, | ||
'timeout' => null, | ||
'timeoutAt' => null, | ||
'data' => [ | ||
'commandName' => FakeJob::class, | ||
'command' => serialize($job), | ||
], | ||
'attempts' => 0, | ||
]); | ||
|
||
QueueHandler::$app = $this->app; | ||
|
||
$queueHandler = new QueueHandler(); | ||
|
||
$this->assertFalse(QueueHandler::$app->bound(LambdaEvent::class)); | ||
$queueHandler->handle($event); | ||
$this->assertFalse(QueueHandler::$app->bound(LambdaEvent::class)); | ||
$this->assertTrue(FakeJob::$handled); | ||
} | ||
|
||
protected function getPackageProviders($app) | ||
{ | ||
return [ | ||
\Laravel\Vapor\VaporServiceProvider::class, | ||
]; | ||
} | ||
|
||
protected function getEnvironmentSetUp($app) | ||
{ | ||
$app['config']->set('queue.connections.vapor', [ | ||
'driver' => 'sqs', | ||
'key' => env('SQS_KEY', 'your-public-key'), | ||
'secret' => env('SQS_SECRET', 'your-secret-key'), | ||
'prefix' => env('SQS_PREFIX', 'https://sqs.us-east-1.amazonaws.com/your-account-id'), | ||
'queue' => env('SQS_QUEUE', 'your-queue-name'), | ||
'region' => env('SQS_REGION', 'us-east-1'), | ||
'delay' => env('SQS_DELAY', 0), | ||
'tries' => env('SQS_TRIES', 0), | ||
'force' => env('SQS_FORCE', false), | ||
]); | ||
} | ||
|
||
protected function getEvent() | ||
{ | ||
return json_decode( | ||
file_get_contents(__DIR__.'/../Fixtures/lambdaEvent.json'), | ||
true | ||
); | ||
} | ||
} |
Oops, something went wrong.