2014-01-15 12:17:40 -10:00
|
|
|
package agent
|
|
|
|
|
|
|
|
import (
|
2015-01-20 14:13:36 -08:00
|
|
|
"os"
|
2015-05-29 21:03:55 +02:00
|
|
|
"runtime"
|
2014-01-15 12:17:40 -10:00
|
|
|
"testing"
|
2017-11-01 14:25:46 -07:00
|
|
|
"time"
|
2017-05-12 15:41:13 +02:00
|
|
|
|
|
|
|
"github.com/hashicorp/consul/testutil"
|
2017-11-01 14:25:46 -07:00
|
|
|
"github.com/pascaldekloe/goe/verify"
|
2014-01-15 12:17:40 -10:00
|
|
|
)
|
|
|
|
|
2015-01-07 19:11:21 -08:00
|
|
|
func TestStringHash(t *testing.T) {
|
2017-05-21 09:54:40 +02:00
|
|
|
t.Parallel()
|
2015-01-07 19:11:21 -08:00
|
|
|
in := "hello world"
|
|
|
|
expected := "5eb63bbbe01eeed093cb22bb8f5acdc3"
|
|
|
|
|
|
|
|
if out := stringHash(in); out != expected {
|
|
|
|
t.Fatalf("bad: %s", out)
|
|
|
|
}
|
|
|
|
}
|
2015-01-20 14:13:36 -08:00
|
|
|
|
|
|
|
func TestSetFilePermissions(t *testing.T) {
|
2017-05-21 09:54:40 +02:00
|
|
|
t.Parallel()
|
2015-05-29 21:03:55 +02:00
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
t.SkipNow()
|
|
|
|
}
|
2017-05-12 15:41:13 +02:00
|
|
|
tempFile := testutil.TempFile(t, "consul")
|
2015-01-20 14:13:36 -08:00
|
|
|
path := tempFile.Name()
|
|
|
|
defer os.Remove(path)
|
|
|
|
|
|
|
|
// Bad UID fails
|
2017-09-25 20:40:42 +02:00
|
|
|
if err := setFilePermissions(path, "%", "", ""); err == nil {
|
2015-01-20 14:13:36 -08:00
|
|
|
t.Fatalf("should fail")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bad GID fails
|
2017-09-25 20:40:42 +02:00
|
|
|
if err := setFilePermissions(path, "", "%", ""); err == nil {
|
2015-01-20 14:13:36 -08:00
|
|
|
t.Fatalf("should fail")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bad mode fails
|
2017-09-25 20:40:42 +02:00
|
|
|
if err := setFilePermissions(path, "", "", "%"); err == nil {
|
2015-01-20 14:13:36 -08:00
|
|
|
t.Fatalf("should fail")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Allows omitting user/group/mode
|
2017-09-25 20:40:42 +02:00
|
|
|
if err := setFilePermissions(path, "", "", ""); err != nil {
|
2015-01-20 14:13:36 -08:00
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Doesn't change mode if not given
|
|
|
|
if err := os.Chmod(path, 0700); err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
2017-09-25 20:40:42 +02:00
|
|
|
if err := setFilePermissions(path, "", "", ""); err != nil {
|
2015-01-20 14:13:36 -08:00
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
fi, err := os.Stat(path)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if fi.Mode().String() != "-rwx------" {
|
|
|
|
t.Fatalf("bad: %s", fi.Mode())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Changes mode if given
|
2017-09-25 20:40:42 +02:00
|
|
|
if err := setFilePermissions(path, "", "", "0777"); err != nil {
|
2015-01-20 14:13:36 -08:00
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
fi, err = os.Stat(path)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
if fi.Mode().String() != "-rwxrwxrwx" {
|
|
|
|
t.Fatalf("bad: %s", fi.Mode())
|
|
|
|
}
|
|
|
|
}
|
2017-11-01 14:25:46 -07:00
|
|
|
|
|
|
|
func TestDurationFixer(t *testing.T) {
|
|
|
|
obj := map[string]interface{}{
|
|
|
|
"key1": []map[string]interface{}{
|
|
|
|
{
|
|
|
|
"subkey1": "10s",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"subkey2": "5d",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"key2": map[string]interface{}{
|
|
|
|
"subkey3": "30s",
|
|
|
|
"subkey4": "20m",
|
|
|
|
},
|
|
|
|
"key3": "11s",
|
|
|
|
"key4": "49h",
|
|
|
|
}
|
|
|
|
expected := map[string]interface{}{
|
|
|
|
"key1": []map[string]interface{}{
|
|
|
|
{
|
|
|
|
"subkey1": 10 * time.Second,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"subkey2": "5d",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
"key2": map[string]interface{}{
|
|
|
|
"subkey3": "30s",
|
|
|
|
"subkey4": 20 * time.Minute,
|
|
|
|
},
|
|
|
|
"key3": "11s",
|
|
|
|
"key4": 49 * time.Hour,
|
|
|
|
}
|
|
|
|
|
|
|
|
fixer := NewDurationFixer("key4", "subkey1", "subkey4")
|
|
|
|
if err := fixer.FixupDurations(obj); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ensure we only processed the intended fieldnames
|
|
|
|
verify.Values(t, "", obj, expected)
|
|
|
|
}
|