X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=ccan%2Fio%2Ftest%2Frun-01-start-finish.c;h=eb2c90a68b77f21bab857d250085efa94baf14d2;hb=94dd4c2bddd0dc080ad5b85465fa3f45f486967a;hp=a63baf7706c12970ed25b27e84c0cec76328c65d;hpb=641b511049e5c03d45ada0c3fd829691b173e5d1;p=ccan diff --git a/ccan/io/test/run-01-start-finish.c b/ccan/io/test/run-01-start-finish.c index a63baf77..eb2c90a6 100644 --- a/ccan/io/test/run-01-start-finish.c +++ b/ccan/io/test/run-01-start-finish.c @@ -9,19 +9,24 @@ #ifndef PORT #define PORT "65001" #endif +static int expected_fd; static void finish_ok(struct io_conn *conn, int *state) { ok1(*state == 1); + ok1(io_conn_fd(conn) == expected_fd); (*state)++; - io_break(state + 1, io_idle()); + io_break(state + 1); } -static void init_conn(int fd, int *state) +static struct io_plan *init_conn(struct io_conn *conn, int *state) { ok1(*state == 0); (*state)++; - io_set_finish(io_new_conn(fd, io_close()), finish_ok, state); + expected_fd = io_conn_fd(conn); + io_set_finish(conn, finish_ok, state); + + return io_close(conn); } static int make_listen_fd(const char *port, struct addrinfo **info) @@ -64,10 +69,10 @@ int main(void) int fd; /* This is how many tests you plan to run */ - plan_tests(9); + plan_tests(10); fd = make_listen_fd(PORT, &addrinfo); ok1(fd >= 0); - l = io_new_listener(fd, init_conn, &state); + l = io_new_listener(NULL, fd, init_conn, &state); ok1(l); fflush(stdout); if (!fork()) { @@ -83,7 +88,7 @@ int main(void) exit(0); } freeaddrinfo(addrinfo); - ok1(io_loop() == &state + 1); + ok1(io_loop(NULL, NULL) == &state + 1); ok1(state == 2); io_close_listener(l); ok1(wait(&state));