Я учусь делать одновременно в amphp.Только что нашел вариант использования, чтобы использовать его в моем тесте.Но, судя по выводу, мой код выполняется синхронно.
Вот мой код:
<?php
public function testPutDocument()
{
// sync all mapping
$service = app(SearchService::class);
$result = $service->syncMapping();
$this->assertInternalType('array', $result);
Loop::run(function () use ($service) {
foreach (array_keys($this->domainProvider()) as $domain) {
var_dump("dispatching $domain test..");
Loop::defer(function () use ($domain, $service) {
var_dump("running $domain test..");
// build model
$class = __NAMESPACE__."\ModelBuilder\\".ucfirst($domain);
$message = "Please create '$class' class for testing '$domain' domain mapping.";
$this->assertTrue(class_exists($class), $message);
$this->buildModels(new $class)
->each(function ($model) use ($domain, $service) {
// put document
try {
$result = $service->storeDocument($domain, $model);
$this->assertInstanceOf(Result::class, $result);
} catch (CredentialException $e) {
$message = $e->getMessage();
$message = "Failed put document for '$domain' domain. Details:\n\n$message";
$this->assertTrue(false, $message);
}
// delete document
try {
$result = $service->deleteDocument($domain, $model->id);
$this->assertInstanceOf(Result::class, $result);
} catch (CredentialException $e) {
$message = $e->getMessage();
$message = "Failed delete document for '$domain' domain. Details:\n\n$message";
$this->assertTrue(false, $message);
}
});
var_dump("done $domain test..");
});
var_dump("dispatched $domain test.");
}
});
}
Вывод:
string(26) "dispatching contact test.."
string(24) "dispatched contact test."
string(30) "dispatching interaction test.."
string(28) "dispatched interaction test."
string(27) "dispatching timeline test.."
string(25) "dispatched timeline test."
string(26) "dispatching insight test.."
string(24) "dispatched insight test."
string(22) "running contact test.."
string(19) "done contact test.."
string(26) "running interaction test.."
string(23) "done interaction test.."
string(23) "running timeline test.."
string(20) "done timeline test.."
string(22) "running insight test.."
string(19) "done insight test.."
Я подумал, если код запускался одновременно, результат будет примерно таким:
string(26) "dispatching contact test.."
string(24) "dispatched contact test."
string(30) "dispatching interaction test.."
string(28) "dispatched interaction test."
string(27) "dispatching timeline test.."
string(25) "dispatched timeline test."
string(26) "dispatching insight test.."
string(24) "dispatched insight test."
string(22) "running contact test.."
string(26) "running interaction test.."
string(23) "running timeline test.."
string(22) "running insight test.."
string(19) "done contact test.."
string(23) "done interaction test.."
string(20) "done timeline test.."
string(19) "done insight test.."
Кроме того, строка блокировки - это строка:
$result = $service->storeDocument($domain, $model);
Это запрос POST
$result = $service->deleteDocument($domain, $model->id);
Этозапрос DELETE
Что мне не хватает?