1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
|
<?php
use Laravel\SerializableClosure\Exceptions\InvalidSignatureException;
use Laravel\SerializableClosure\SerializableClosure;
test('secure closure integrity fail', function () {
$closure = function () {
/*x*/
};
SerializableClosure::setSecretKey('secret');
$value = serialize(new SerializableClosure($closure));
$value = str_replace('*x*', '*y*', $value);
unserialize($value);
})->throws(InvalidSignatureException::class);
test('unsigned closure with signer', function () {
SerializableClosure::setSecretKey(null);
$closure = function () {
/*x*/
};
$value = serialize(new SerializableClosure($closure));
SerializableClosure::setSecretKey('secret');
unserialize($value);
})->throws(InvalidSignatureException::class);
test('signed closure without signer', function () {
SerializableClosure::setSecretKey('secret');
$closure = function () {
return true;
};
$value = serialize(new SerializableClosure($closure));
SerializableClosure::setSecretKey(null);
$closure = unserialize($value)->getClosure();
expect($closure())->toBeTrue();
});
|