|
| 1 | +--TEST-- |
| 2 | +swoole_server: http request & response |
| 3 | +--SKIPIF-- |
| 4 | +<?php |
| 5 | +require __DIR__ . '/../include/skipif.inc'; |
| 6 | +?> |
| 7 | +--FILE-- |
| 8 | +<?php |
| 9 | +require __DIR__ . '/../include/bootstrap.php'; |
| 10 | + |
| 11 | +use Swoole\Server; |
| 12 | +use Swoole\Constant; |
| 13 | +use Swoole\Http\Request; |
| 14 | +use Swoole\Http\Response; |
| 15 | +use Swoole\Coroutine\Http\Client; |
| 16 | +use function Swoole\Coroutine\run; |
| 17 | + |
| 18 | +define('GREETER', 'hello world'); |
| 19 | + |
| 20 | +$pm = new SwooleTest\ProcessManager; |
| 21 | + |
| 22 | +$pm->parentFunc = function ($pid) use ($pm) { |
| 23 | + run(function () use ($pm) { |
| 24 | + $httpClient = new Client(HTTP_SERVER_HOST, $pm->getFreePort(), false); |
| 25 | + $httpClient->setMethod("POST"); |
| 26 | + $httpClient->setData("HELLO"); |
| 27 | + $ok = $httpClient->execute("/rawcookie?hello=world&value=1"); |
| 28 | + Assert::assert($ok); |
| 29 | + Assert::same($httpClient->statusCode, 200); |
| 30 | + Assert::same($httpClient->errCode, 0); |
| 31 | + Assert::eq($httpClient->getHeaders()['x-server'], 'swoole'); |
| 32 | + Assert::same($httpClient->getBody(), GREETER); |
| 33 | + echo "DONE\n"; |
| 34 | + }); |
| 35 | + $pm->kill(); |
| 36 | +}; |
| 37 | + |
| 38 | +$pm->childFunc = function () use ($pm) { |
| 39 | + $serv = new Server('127.0.0.1', $pm->getFreePort(), SERVER_MODE_RANDOM); |
| 40 | + $serv->set([ |
| 41 | + 'worker_num' => 1, |
| 42 | + 'log_file' => '/dev/null', |
| 43 | + ]); |
| 44 | + $serv->on("Start", function ($serv) use ($pm) { |
| 45 | + $pm->wakeup(); |
| 46 | + }); |
| 47 | + $serv->on('receive', function (Server $serv, $fd, $reactor_id, $data) { |
| 48 | + $req = Request::create(); |
| 49 | + Assert::eq($req->parse($data), strlen($data)); |
| 50 | + |
| 51 | + $resp = Response::create([$serv, $req], $fd); |
| 52 | + $resp->header('X-Server', 'swoole'); |
| 53 | + $resp->end(GREETER); |
| 54 | + Assert::eq($resp->fd, $fd); |
| 55 | + Assert::eq($req->fd, $fd); |
| 56 | + }); |
| 57 | + $serv->on(Constant::EVENT_CLOSE, function (Server $serv, $fd, $reactor_id) { |
| 58 | + }); |
| 59 | + $serv->start(); |
| 60 | +}; |
| 61 | + |
| 62 | +$pm->childFirst(); |
| 63 | +$pm->run(); |
| 64 | +?> |
| 65 | +--EXPECT-- |
| 66 | +DONE |
0 commit comments