aboutsummaryrefslogtreecommitdiff
path: root/actions/config_test.go
diff options
context:
space:
mode:
authorJoe Richey joerichey@google.com <joerichey@google.com>2017-06-21 10:03:44 -0700
committerJoe Richey joerichey@google.com <joerichey@google.com>2017-06-28 15:15:15 -0700
commit93415b198a3ef427c02893b8fdf036aa75ffe50f (patch)
tree419be5fa11e9102597d3409800a3d7df4138b05e /actions/config_test.go
parent77b226a90ef70b77ca556830528c013a23b01e57 (diff)
actions: error handling and API changed
This commit changes the error handling for the actions package to use the error handling library github.com/pkg/errors. This means replacing "errors" with "github.com/pkg/errors", reworking some of the error values, and wrapping some errors with additional context. This commit also changes the Protector/Policy API, moving most of the package functionality into Protector or Policy methods. These types are now "locked" when they are queried from the filesystem, and Unlock() must be used to get their corresponding keys. Note that only certain operations will require unlocking the keys. Certain unnecessary functions and methods are also removed. This CL also fixes two bugs reported by Tyler Hicks in CreateConfigFile. CPU time is used instead of wall time, and kiB is used instead of kB. Change-Id: I88f45659e9fe4938d148843e3289e7b6d5b698d8
Diffstat (limited to 'actions/config_test.go')
-rw-r--r--actions/config_test.go105
1 files changed, 0 insertions, 105 deletions
diff --git a/actions/config_test.go b/actions/config_test.go
deleted file mode 100644
index c0b2089..0000000
--- a/actions/config_test.go
+++ /dev/null
@@ -1,105 +0,0 @@
-/*
- * config_test.go - tests for setting up the config file
- *
- * Copyright 2017 Google Inc.
- * Author: Joe Richey (joerichey@google.com)
- *
- * Licensed under the Apache License, Version 2.0 (the "License"); you may not
- * use this file except in compliance with the License. You may obtain a copy of
- * the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
- * License for the specific language governing permissions and limitations under
- * the License.
- */
-
-package actions
-
-import (
- "io/ioutil"
- "log"
- "os"
- "testing"
- "time"
-)
-
-const testTime = 10 * time.Millisecond
-
-func init() {
- // All our testing uses an alternative config file location, so we don't
- // need root to run the tests
- ConfigFileLocation = "fscrypt_test.conf"
-}
-
-// Tests that we can make the config files with and without legacy settings
-func TestMakeConfig(t *testing.T) {
- defer os.RemoveAll(ConfigFileLocation)
-
- err := CreateConfigFile(testTime, true)
- if err != nil {
- t.Error(err)
- }
- os.RemoveAll(ConfigFileLocation)
-
- err = CreateConfigFile(testTime, false)
- if err != nil {
- t.Error(err)
- }
-}
-
-// Tests that we can find valid hashing costs for various time targets and the
-// estimations are somewhat close to the targets.
-func TestCostsSearch(t *testing.T) {
- for _, target := range []time.Duration{
- 100 * time.Microsecond,
- 1 * time.Millisecond,
- 10 * time.Millisecond,
- 100 * time.Millisecond,
- } {
- costs, err := getHashingCosts(target)
- if err != nil {
- t.Error(err)
- }
- actual, err := timeHashingCosts(costs)
- if err != nil {
- t.Error(err)
- }
-
- // Timing tests are only reliable for sufficiently long targets.
- if target > time.Millisecond {
- if actual*2 < target {
- t.Errorf("actual=%v is too small (target=%v)", actual, target)
- }
- if target*2 < actual {
- t.Errorf("actual=%v is too big (target=%v)", actual, target)
- }
- }
- }
-}
-
-func benchmarkCostsSearch(b *testing.B, target time.Duration) {
- // Disable logging for benchmarks
- log.SetOutput(ioutil.Discard)
- for i := 0; i < b.N; i++ {
- _, err := getHashingCosts(target)
- if err != nil {
- b.Fatal(err)
- }
- }
-}
-
-func BenchmarkCostsSearch10ms(b *testing.B) {
- benchmarkCostsSearch(b, 10*time.Millisecond)
-}
-
-func BenchmarkCostsSearch100ms(b *testing.B) {
- benchmarkCostsSearch(b, 100*time.Millisecond)
-}
-
-func BenchmarkCostsSearch1s(b *testing.B) {
- benchmarkCostsSearch(b, time.Second)
-}