summaryrefslogtreecommitdiff
path: root/src/lib/exec/exec_test.go
diff options
context:
space:
mode:
authorRob Pike <r@golang.org>2009-05-05 17:05:39 -0700
committerRob Pike <r@golang.org>2009-05-05 17:05:39 -0700
commitb6708b2dad4af458e69fde7fc596ecdce03280d0 (patch)
tree11cfc1b980ecce9cb0eec06f49cc53ce05faf350 /src/lib/exec/exec_test.go
parent658b10477a16151de7e4d51657993f95445f11ee (diff)
downloadgolang-b6708b2dad4af458e69fde7fc596ecdce03280d0.tar.gz
directory-per-package step 1: move files from lib/X.go to lib/X/X.go
no substantive changes except: - new Makefiles, all auto-generated - go/src/lib/Makefile has been extensively edited R=rsc OCL=28310 CL=28310
Diffstat (limited to 'src/lib/exec/exec_test.go')
-rw-r--r--src/lib/exec/exec_test.go51
1 files changed, 51 insertions, 0 deletions
diff --git a/src/lib/exec/exec_test.go b/src/lib/exec/exec_test.go
new file mode 100644
index 000000000..a1bb1f50e
--- /dev/null
+++ b/src/lib/exec/exec_test.go
@@ -0,0 +1,51 @@
+// Copyright 2009 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package exec
+
+import (
+ "exec";
+ "io";
+ "testing";
+)
+
+func TestRunCat(t *testing.T) {
+ cmd, err := exec.Run("/bin/cat", []string{"cat"}, nil,
+ exec.Pipe, exec.Pipe, exec.DevNull);
+ if err != nil {
+ t.Fatalf("opencmd /bin/cat: %v", err);
+ }
+ io.WriteString(cmd.Stdin, "hello, world\n");
+ cmd.Stdin.Close();
+ var buf [64]byte;
+ n, err1 := io.FullRead(cmd.Stdout, &buf);
+ if err1 != nil && err1 != io.ErrEOF {
+ t.Fatalf("reading from /bin/cat: %v", err1);
+ }
+ if string(buf[0:n]) != "hello, world\n" {
+ t.Fatalf("reading from /bin/cat: got %q", buf[0:n]);
+ }
+ if err1 = cmd.Close(); err1 != nil {
+ t.Fatalf("closing /bin/cat: %v", err1);
+ }
+}
+
+func TestRunEcho(t *testing.T) {
+ cmd, err := Run("/bin/echo", []string{"echo", "hello", "world"}, nil,
+ exec.DevNull, exec.Pipe, exec.DevNull);
+ if err != nil {
+ t.Fatalf("opencmd /bin/echo: %v", err);
+ }
+ var buf [64]byte;
+ n, err1 := io.FullRead(cmd.Stdout, &buf);
+ if err1 != nil && err1 != io.ErrEOF {
+ t.Fatalf("reading from /bin/echo: %v", err1);
+ }
+ if string(buf[0:n]) != "hello world\n" {
+ t.Fatalf("reading from /bin/echo: got %q", buf[0:n]);
+ }
+ if err1 = cmd.Close(); err1 != nil {
+ t.Fatalf("closing /bin/echo: %v", err1);
+ }
+}