|
|
|
@ -33,7 +33,7 @@ |
|
|
|
|
*/ |
|
|
|
|
class EndToEndTest extends PHPUnit_Framework_TestCase{ |
|
|
|
|
public function setUp() { |
|
|
|
|
$this->server = new Grpc\Server($this->server_queue, []); |
|
|
|
|
$this->server = new Grpc\Server([]); |
|
|
|
|
$port = $this->server->add_http2_port('0.0.0.0:0'); |
|
|
|
|
$this->channel = new Grpc\Channel('localhost:' . $port, []); |
|
|
|
|
$this->server->start(); |
|
|
|
@ -53,7 +53,7 @@ class EndToEndTest extends PHPUnit_Framework_TestCase{ |
|
|
|
|
'dummy_method', |
|
|
|
|
$deadline); |
|
|
|
|
|
|
|
|
|
$event = $this->call->start_batch([ |
|
|
|
|
$event = $call->start_batch([ |
|
|
|
|
Grpc\OP_SEND_INITIAL_METADATA => [], |
|
|
|
|
Grpc\OP_SEND_CLOSE_FROM_CLIENT => true |
|
|
|
|
]); |
|
|
|
@ -79,54 +79,17 @@ class EndToEndTest extends PHPUnit_Framework_TestCase{ |
|
|
|
|
$this->assertTrue($event->send_status); |
|
|
|
|
$this->assertFalse($event->cancelled); |
|
|
|
|
|
|
|
|
|
$tag = 1; |
|
|
|
|
$call->invoke($this->client_queue, $tag, $tag); |
|
|
|
|
$server_tag = 2; |
|
|
|
|
|
|
|
|
|
$call->writes_done($tag); |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\FINISH_ACCEPTED, $event->type); |
|
|
|
|
$this->assertSame(Grpc\OP_OK, $event->data); |
|
|
|
|
|
|
|
|
|
// check that a server rpc new was received |
|
|
|
|
$this->server->request_call($server_tag); |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\SERVER_RPC_NEW, $event->type); |
|
|
|
|
$server_call = $event->call; |
|
|
|
|
$this->assertNotNull($server_call); |
|
|
|
|
$server_call->server_accept($this->server_queue, $server_tag); |
|
|
|
|
|
|
|
|
|
$server_call->server_end_initial_metadata(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// the server sends the status |
|
|
|
|
$server_call->start_write_status(Grpc\STATUS_OK, $status_text, $server_tag); |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\FINISH_ACCEPTED, $event->type); |
|
|
|
|
$this->assertSame(Grpc\OP_OK, $event->data); |
|
|
|
|
|
|
|
|
|
// the client gets CLIENT_METADATA_READ |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\CLIENT_METADATA_READ, $event->type); |
|
|
|
|
$event = $call->start_batch([ |
|
|
|
|
Grpc\OP_RECV_INITIAL_METADATA => true, |
|
|
|
|
Grpc\OP_RECV_STATUS_ON_CLIENT => true, |
|
|
|
|
]); |
|
|
|
|
|
|
|
|
|
// the client gets FINISHED |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\FINISHED, $event->type); |
|
|
|
|
$status = $event->data; |
|
|
|
|
$this->assertSame([], $event->metadata); |
|
|
|
|
$status = $event->status; |
|
|
|
|
$this->assertSame([], $status->metadata); |
|
|
|
|
$this->assertSame(Grpc\STATUS_OK, $status->code); |
|
|
|
|
$this->assertSame($status_text, $status->details); |
|
|
|
|
|
|
|
|
|
// and the server gets FINISHED |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\FINISHED, $event->type); |
|
|
|
|
$status = $event->data; |
|
|
|
|
|
|
|
|
|
unset($call); |
|
|
|
|
unset($server_call); |
|
|
|
|
} |
|
|
|
@ -140,79 +103,52 @@ class EndToEndTest extends PHPUnit_Framework_TestCase{ |
|
|
|
|
$call = new Grpc\Call($this->channel, |
|
|
|
|
'dummy_method', |
|
|
|
|
$deadline); |
|
|
|
|
$tag = 1; |
|
|
|
|
$call->invoke($this->client_queue, $tag, $tag); |
|
|
|
|
|
|
|
|
|
$server_tag = 2; |
|
|
|
|
$event = $call->start_batch([ |
|
|
|
|
Grpc\OP_SEND_INITIAL_METADATA => [], |
|
|
|
|
Grpc\OP_SEND_CLOSE_FROM_CLIENT => true, |
|
|
|
|
Grpc\OP_SEND_MESSAGE => $req_text |
|
|
|
|
]); |
|
|
|
|
|
|
|
|
|
// the client writes |
|
|
|
|
$call->start_write($req_text, $tag); |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\WRITE_ACCEPTED, $event->type); |
|
|
|
|
$this->assertTrue($event->send_metadata); |
|
|
|
|
$this->assertTrue($event->send_close); |
|
|
|
|
$this->assertTrue($event->send_message); |
|
|
|
|
|
|
|
|
|
// check that a server rpc new was received |
|
|
|
|
$this->server->start(); |
|
|
|
|
$this->server->request_call($server_tag); |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\SERVER_RPC_NEW, $event->type); |
|
|
|
|
$event = $this->server->request_call(); |
|
|
|
|
$this->assertSame('dummy_method', $event->method); |
|
|
|
|
$server_call = $event->call; |
|
|
|
|
$this->assertNotNull($server_call); |
|
|
|
|
$server_call->server_accept($this->server_queue, $server_tag); |
|
|
|
|
|
|
|
|
|
$server_call->server_end_initial_metadata(); |
|
|
|
|
|
|
|
|
|
// start the server read |
|
|
|
|
$server_call->start_read($server_tag); |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\READ, $event->type); |
|
|
|
|
$this->assertSame($req_text, $event->data); |
|
|
|
|
|
|
|
|
|
// the server replies |
|
|
|
|
$server_call->start_write($reply_text, $server_tag); |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\WRITE_ACCEPTED, $event->type); |
|
|
|
|
|
|
|
|
|
// the client reads the metadata |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\CLIENT_METADATA_READ, $event->type); |
|
|
|
|
|
|
|
|
|
// the client reads the reply |
|
|
|
|
$call->start_read($tag); |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\READ, $event->type); |
|
|
|
|
$this->assertSame($reply_text, $event->data); |
|
|
|
|
|
|
|
|
|
// the client sends writes done |
|
|
|
|
$call->writes_done($tag); |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertSame(Grpc\FINISH_ACCEPTED, $event->type); |
|
|
|
|
$this->assertSame(Grpc\OP_OK, $event->data); |
|
|
|
|
|
|
|
|
|
// the server sends the status |
|
|
|
|
$server_call->start_write_status(GRPC\STATUS_OK, $status_text, $server_tag); |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertSame(Grpc\FINISH_ACCEPTED, $event->type); |
|
|
|
|
$this->assertSame(Grpc\OP_OK, $event->data); |
|
|
|
|
|
|
|
|
|
// the client gets FINISHED |
|
|
|
|
$event = $this->client_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\FINISHED, $event->type); |
|
|
|
|
$status = $event->data; |
|
|
|
|
|
|
|
|
|
$event = $server_call->start_batch([ |
|
|
|
|
Grpc\OP_SEND_INITIAL_METADATA => [], |
|
|
|
|
Grpc\OP_SEND_MESSAGE => $reply_text, |
|
|
|
|
Grpc\OP_SEND_STATUS_FROM_SERVER => [ |
|
|
|
|
'metadata' => [], |
|
|
|
|
'code' => Grpc\STATUS_OK, |
|
|
|
|
'details' => $status_text |
|
|
|
|
], |
|
|
|
|
Grpc\OP_RECV_MESSAGE => true, |
|
|
|
|
Grpc\OP_RECV_CLOSE_ON_SERVER => true, |
|
|
|
|
]); |
|
|
|
|
|
|
|
|
|
$this->assertTrue($event->send_metadata); |
|
|
|
|
$this->assertTrue($event->send_status); |
|
|
|
|
$this->assertTrue($event->send_message); |
|
|
|
|
$this->assertFalse($event->cancelled); |
|
|
|
|
$this->assertSame($req_text, $event->read); |
|
|
|
|
|
|
|
|
|
$event = $call->start_batch([ |
|
|
|
|
Grpc\OP_RECV_INITIAL_METADATA => true, |
|
|
|
|
Grpc\OP_RECV_MESSAGE => true, |
|
|
|
|
Grpc\OP_RECV_STATUS_ON_CLIENT => true, |
|
|
|
|
]); |
|
|
|
|
|
|
|
|
|
$this->assertSame([], $event->metadata); |
|
|
|
|
$this->assertSame($reply_text, $event->read); |
|
|
|
|
$status = $event->status; |
|
|
|
|
$this->assertSame([], $status->metadata); |
|
|
|
|
$this->assertSame(Grpc\STATUS_OK, $status->code); |
|
|
|
|
$this->assertSame($status_text, $status->details); |
|
|
|
|
|
|
|
|
|
// and the server gets FINISHED |
|
|
|
|
$event = $this->server_queue->next($deadline); |
|
|
|
|
$this->assertNotNull($event); |
|
|
|
|
$this->assertSame(Grpc\FINISHED, $event->type); |
|
|
|
|
|
|
|
|
|
unset($call); |
|
|
|
|
unset($server_call); |
|
|
|
|
} |
|
|
|
|