1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
test_that("writing to extra connection", {
skip_on_cran()
msg <- "foobar"
cmd <- c(get_tool("px"), "echo", "3", "1", nchar(msg))
pipe <- conn_create_pipepair(nonblocking = c(FALSE, FALSE))
expect_silent(
p <- process$new(cmd[1], cmd[-1],
stdout = "|", stderr = "|", connections = list(pipe[[1]])
)
)
close(pipe[[1]])
on.exit(p$kill(), add = TRUE)
conn_write(pipe[[2]], msg)
p$poll_io(-1)
expect_equal(p$read_all_output_lines(), msg)
expect_equal(p$read_all_error_lines(), character())
close(pipe[[2]])
})
test_that("reading from extra connection", {
skip_on_cran()
cmd <- c(
get_tool("px"), "sleep", "0.5", "write", "3", "foobar\r\n", "out", "ok")
pipe <- conn_create_pipepair()
expect_silent(
p <- process$new(cmd[1], cmd[-1], stdout = "|", stderr = "|",
connections = list(pipe[[2]])
)
)
close(pipe[[2]])
on.exit(p$kill(), add = TRUE)
## Nothing to read yet
expect_equal(conn_read_lines(pipe[[1]]), character())
## Wait until there is output
ready <- poll(list(pipe[[1]]), 5000)[[1]]
expect_equal(ready, "ready")
expect_equal(conn_read_lines(pipe[[1]]), "foobar")
expect_equal(p$read_all_output_lines(), "ok")
expect_equal(p$read_all_error_lines(), character())
close(pipe[[1]])
})
test_that("reading and writing to extra connection", {
skip_on_cran()
msg <- "foobar\n"
cmd <- c(get_tool("px"), "echo", "3", "4", nchar(msg), "outln", "ok")
pipe1 <- conn_create_pipepair(nonblocking = c(FALSE, FALSE))
pipe2 <- conn_create_pipepair()
expect_silent(
p <- process$new(cmd[1], cmd[-1], stdout = "|", stderr = "|",
connections = list(pipe1[[1]], pipe2[[2]])
)
)
close(pipe1[[1]])
close(pipe2[[2]])
on.exit(p$kill(), add = TRUE)
conn_write(pipe1[[2]], msg)
p$poll_io(-1)
expect_equal(conn_read_chars(pipe2[[1]]), msg)
expect_equal(p$read_output_lines(), "ok")
close(pipe1[[2]])
close(pipe2[[1]])
})
|