summaryrefslogtreecommitdiff
path: root/vendor/github.com/AllenDang/w32/fork_test.go
blob: 47b52ba3361fa0ed595905b359a8ee1ba47c2b6b (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
37
38
39
40
41
42
43
44
45
46
47
48
49
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)

	}

}