summaryrefslogtreecommitdiff
path: root/vendor/github.com/AllenDang/w32/fork_test.go
diff options
context:
space:
mode:
authorKali Kaneko (leap communications) <kali@leap.se>2019-01-12 18:39:45 +0100
committerRuben Pollan <meskio@sindominio.net>2019-01-17 12:30:32 +0100
commitb1247d2d0d51108c910a73891ff3116e5f032ab1 (patch)
treee9948964f0bfb1ad2df3bc7bad02aa1f41ccfbd8 /vendor/github.com/AllenDang/w32/fork_test.go
parentefcb8312e31b5c2261b1a1e95ace55b322cfcc27 (diff)
[pkg] all your deps are vendored to us
Diffstat (limited to 'vendor/github.com/AllenDang/w32/fork_test.go')
-rw-r--r--vendor/github.com/AllenDang/w32/fork_test.go50
1 files changed, 50 insertions, 0 deletions
diff --git a/vendor/github.com/AllenDang/w32/fork_test.go b/vendor/github.com/AllenDang/w32/fork_test.go
new file mode 100644
index 0000000..47b52ba
--- /dev/null
+++ b/vendor/github.com/AllenDang/w32/fork_test.go
@@ -0,0 +1,50 @@
+package w32
+
+import (
+ "fmt"
+ "io/ioutil"
+ "os"
+ "path"
+ "strconv"
+ "testing"
+ "time"
+)
+
+var forkFn = path.Join(os.TempDir(), "forktest.pid")
+
+func TestFork(t *testing.T) {
+
+ ppid := os.Getpid()
+ t.Logf("[OK] I am PID %d", ppid)
+ pid, err := Fork()
+ if err != nil {
+ t.Fatalf("[!!] Failed to fork. PID: %d: %s", pid, err)
+ }
+
+ if pid == 0 {
+ // We can't log anything here because our stdout doesn't point
+ // to the same console as our parent.
+ //
+ // This process won't show up in Task Manager, and os.Getpid() won't
+ // work, I guess because we haven't told CSRSS we exist.
+ f, _ := os.Create(forkFn)
+ f.WriteString(fmt.Sprintf("%d", ppid))
+ f.Close()
+ } else {
+ t.Logf("[OK] Forked child with PID %d", pid)
+ t.Logf("[OK] Sleeping, then trying to read checkfile.")
+ time.Sleep(2 * time.Second)
+ raw, err := ioutil.ReadFile(forkFn)
+ if err != nil {
+ t.Fatalf("[!!] Failed to read PID checkfile: %s", err)
+ }
+ if string(raw) == strconv.Itoa(ppid) {
+ t.Logf("[OK] Found PID checkfile - PID matches!")
+ } else {
+ t.Errorf("[!] Child reported PID %q vs %q!", string(raw), strconv.Itoa(ppid))
+ }
+ os.Remove(forkFn)
+
+ }
+
+}