summaryrefslogtreecommitdiffstats
path: root/tests/018/process.tl
blob: 58a12fa2d05679bb97bb697cbf648f87b50569d2 (plain)
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
(load "../common")

(unless (path-executable-to-me-p "/bin/sh")
  (exit 0))

(defun cmd (c : (m "r"))
  (with-stream (s (open-command c m))
    (get-string s)))

(mtest
  (cmd "echo foo") "foo\n"
  (cmd "echo foo" ">1n") ""
  (cmd "echo foo 1>&2" ">21") "foo\n")

(defmacro fcmd (. forms)
  ^(with-stream (s (open-subprocess nil "r" nil (lambda () ,*forms)))
     (get-string s)))

(mtest
  (fcmd (let ((*stdout* *stdnull*)) (sh "echo foo"))) ""
  (fcmd (let ((*stderr* *stdout*)) (sh "echo foo 1>&2"))) "foo\n")

(caseq (os-symbol)
  ((:cygwin :cygnal))
  (t (mtest
       (let ((*child-env* '("a=b")))
         (get-lines (open-process "/usr/bin/env" "r")))
       ("a=b")
       (let ((*child-env* nil))
         (get-lines (open-process "/usr/bin/env" "r")))
       nil)
     (test
       (fcmd
         (let ((*child-env* '("a=b")))
           (run "/usr/bin/env")))
       "a=b\n")))