| 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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
 | package reverse_test
import (
	"bytes"
	"fmt"
	"os"
	"testing"
	"github.com/rfjakob/gocryptfs/v2/tests/test_helpers"
)
var x240 = string(bytes.Repeat([]byte("x"), 240))
// plaintextnames is true when the currently running test has -plaintextnames active
var plaintextnames bool
// deterministic_names is true when the currently running test has -deterministic-names active
var deterministic_names bool
// dirA is a normal directory
var dirA string
// dirB is the reverse mount backed by dirA
var dirB string
// dirC is a forward mount backed by dirB
var dirC string
// Create directory "dirA", mount it reverse to "dirB", mount it forward
// to "dirC".
func TestMain(m *testing.M) {
	var r int
	testcases := []struct {
		plaintextnames      bool
		deterministic_names bool
	}{
		{false, false},
		{true, false},
		{false, true},
	}
	for i, tc := range testcases {
		argsA := []string{"-reverse"}
		plaintextnames, deterministic_names = tc.plaintextnames, tc.deterministic_names
		if tc.plaintextnames {
			argsA = append(argsA, "-plaintextnames")
		} else if tc.deterministic_names {
			argsA = append(argsA, "-deterministic-names")
		}
		dirA = test_helpers.InitFS(nil, argsA...)
		dirB = test_helpers.TmpDir + "/b"
		dirC = test_helpers.TmpDir + "/c"
		if err := os.Mkdir(dirB, 0700); err != nil {
			panic(err)
		}
		if err := os.Mkdir(dirC, 0700); err != nil {
			panic(err)
		}
		test_helpers.MountOrExit(dirA, dirB, "-reverse", "-extpass", "echo test")
		test_helpers.MountOrExit(dirB, dirC, "-extpass", "echo test")
		r = m.Run()
		test_helpers.UnmountPanic(dirC)
		test_helpers.UnmountPanic(dirB)
		os.RemoveAll(dirA)
		os.RemoveAll(dirB)
		os.RemoveAll(dirC)
		if r != 0 {
			fmt.Printf("testcases[%d] = %#v failed\n", i, tc)
			os.Exit(r)
		}
	}
	os.Exit(r)
}
 |