J'essaie d'implémenter des promesses de type js avec reactPHP. Mais pour une raison quelconque les méthodes exécutées de façon synchrone, le end_at
imprimé seulement après que la promesse est résolue.Les promesses de reactPHP sont exécutées de façon synchrone
code:
function iterate() {
$deferred = new \React\Promise\Deferred();
sleep(2);
$deferred->resolve();
return $deferred->promise();
}
Route::get('test/async', function() {
echo "start execution at ".time()."<br>"; // this executed first
iterate()->then(function($result) {
echo "got result result at ". time() . "<br>"; // this is second
}, function($error) {
}, function ($finally) {
});
echo "end at " . time(); // this is executed only after then().
});