From 4bf02f476034f6a30a378769cda323e0ce5ae59f Mon Sep 17 00:00:00 2001 From: Jakob Unterwurzacher Date: Sun, 24 Jun 2018 19:53:08 +0200 Subject: [PATCH] trezor: add basic "-init -trezor" test Verify that the Trezor feature flag is set after "-init -trezor". --- tests/trezor/trezor_test.go | 44 +++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 tests/trezor/trezor_test.go diff --git a/tests/trezor/trezor_test.go b/tests/trezor/trezor_test.go new file mode 100644 index 0000000..ba468d9 --- /dev/null +++ b/tests/trezor/trezor_test.go @@ -0,0 +1,44 @@ +package trezor + +// Test operations with "-trezor". +// See also the "cli" package - the tests there are very similar. + +import ( + "os/exec" + "runtime" + "testing" + + "github.com/rfjakob/gocryptfs/internal/configfile" + + "github.com/rfjakob/gocryptfs/tests/test_helpers" +) + +func isTrezorConnected() bool { + if runtime.GOOS != "linux" { + return false + } + c := exec.Command("lsusb", "-d", "534c:0001") + err := c.Run() + if err != nil { + return false + } + return true +} + +// Test -init with -trezor +func TestInitTrezor(t *testing.T) { + if !isTrezorConnected() { + t.Skip("No Trezor device connected") + } + t.Log("Trying gocryptfs -init -trezor ...") + // vvvvvvvvvvvvv disable -extpass + dir := test_helpers.InitFS(t, "-trezor", "-extpass", "") + // The freshly created config file should have the Trezor feature flag set. + _, c, err := configfile.LoadConfFile(dir+"/"+configfile.ConfDefaultName, nil) + if err != nil { + t.Fatal(err) + } + if !c.IsFeatureFlagSet(configfile.FlagTrezor) { + t.Error("Trezor flag should be set but is not") + } +}