diff options
author | Jakob Unterwurzacher | 2015-11-03 21:06:52 +0100 |
---|---|---|
committer | Jakob Unterwurzacher | 2015-11-03 21:09:58 +0100 |
commit | 988e0a047c01b2f59c4e059876bfb2122981d605 (patch) | |
tree | 41a38ec1e985bace5b7900f33ffb89ebc1d796b0 /cryptfs/config_test.go | |
parent | 3e367b29b0d68b26c606231310e053ef9c8c48a9 (diff) |
tests: add config file and feature flags tests
Diffstat (limited to 'cryptfs/config_test.go')
-rw-r--r-- | cryptfs/config_test.go | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/cryptfs/config_test.go b/cryptfs/config_test.go new file mode 100644 index 0000000..2e46a25 --- /dev/null +++ b/cryptfs/config_test.go @@ -0,0 +1,71 @@ +package cryptfs + +import ( + "fmt" + "testing" + "time" +) + +func TestLoadV1(t *testing.T) { + _, _, err := LoadConfFile("config_test/v1.conf", "test") + if err == nil { + t.Errorf("Outdated v1 config file must fail to load but it didn't") + } else if testing.Verbose() { + fmt.Print(err) + } +} + +// Load a known-good config file and verify that it takes at least 100ms +// (brute-force protection) +func TestLoadV2(t *testing.T) { + t1 := time.Now() + + _, _, err := LoadConfFile("config_test/v2.conf", "foo") + if err != nil { + t.Errorf("Could not load v2 config file: %v", err) + } + + elapsed := time.Since(t1) + if elapsed < 100 *time.Millisecond { + t.Errorf("scrypt calculation runs too fast: %d ms", elapsed / time.Millisecond) + } +} + +func TestLoadV2PwdError(t *testing.T) { + if ! testing.Verbose() { + Warn.Disable() + } + _, _, err := LoadConfFile("config_test/v2.conf", "wrongpassword") + Warn.Enable() + if err == nil { + t.Errorf("Loading with wrong password must fail but it didn't") + } +} + +func TestLoadV2Feature(t *testing.T) { + _, _, err := LoadConfFile("config_test/PlaintextNames.conf", "test") + if err != nil { + t.Errorf("Could not load v2 PlaintextNames config file: %v", err) + } +} + +func TestLoadV2StrangeFeature(t *testing.T) { + _, _, err := LoadConfFile("config_test/StrangeFeature.conf", "test") + if err == nil { + t.Errorf("Loading unknown feature must fail but it didn't") + } else if testing.Verbose() { + fmt.Print(err) + } +} + +func TestCreateConfFile(t *testing.T) { + err := CreateConfFile("config_test/tmp.conf", "test", false) + if err != nil { + t.Fatal(err) + } + _, _, err = LoadConfFile("config_test/tmp.conf", "test") + if err != nil { + t.Fatal(err) + } + +} |