## tests of options in system() and system2. options(warn = 1) opts <- list("", NULL, FALSE, TRUE, "o1.txt", "o2.txt") outs <- c("o1.txt", "o2.txt") process <- function(res) { unlink(outs) if(is.character(res)) { cat("value:\n") writeLines(res) } for(f in outs) if(file.exists(f)) { cat(f, ":\n", sep = "") writeLines(readLines(f)) } } for(out in opts) for(err in opts) { ## skip this for the sake of Unix-alikes if(identical(err, TRUE) && !identical(out,TRUE)) next cat(sprintf("\ntesting stdout = %s, stderr = %s\n", deparse(out), deparse(err))) process(system2("test-system2", stdout = out, stderr = err)) } process(system("test-system2")) process(system("test-system2", ignore.stdout = TRUE)) process(system("test-system2", ignore.stderr = TRUE)) process(system("test-system2", ignore.stdout = TRUE, ignore.stderr = TRUE)) process(system("test-system2", TRUE)) process(system("test-system2", TRUE, ignore.stdout = TRUE)) process(system("test-system2", TRUE, ignore.stdout = TRUE, ignore.stderr = TRUE)) process(system2("test-system2", "1", input=letters[1:4])) process(system2("test-system2", "1", input=letters[1:4], stdout = TRUE)) process(system("test-system2 1", input=letters[1:4])) process(system("test-system2 1", input=letters[1:4], intern = TRUE)) tmp <- tempfile() writeLines(letters[5:7], tmp) process(system2("test-system2", "1", stdin = tmp)) process(system2("test-system2", "1", stdin = tmp, stdout = TRUE)) process(system2("test-system2", "1", stdin = tmp, stdout = TRUE, stderr = TRUE)) process(system2("test-system2", "1", stdin = tmp, stdout = "o1.txt", stderr = "o1.txt")) process(system2("test-system2", "1", stdin = tmp, stdout = "o1.txt", stderr = "o2.txt")) unlink(c(tmp, outs)) print(system("test-system2 5")) system("test-system2 6", intern = TRUE) print(system2("test-system2", "7")) system2("test-system2", "8", stdout=TRUE)