2014-01-15 22:17:40 +00:00
|
|
|
package agent
|
|
|
|
|
|
|
|
import (
|
2015-01-20 22:13:36 +00:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
2015-05-29 19:03:55 +00:00
|
|
|
"runtime"
|
2014-01-15 22:17:40 +00:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAEScale(t *testing.T) {
|
|
|
|
intv := time.Minute
|
|
|
|
if v := aeScale(intv, 100); v != intv {
|
|
|
|
t.Fatalf("Bad: %v", v)
|
|
|
|
}
|
|
|
|
if v := aeScale(intv, 200); v != 2*intv {
|
|
|
|
t.Fatalf("Bad: %v", v)
|
|
|
|
}
|
|
|
|
if v := aeScale(intv, 1000); v != 4*intv {
|
|
|
|
t.Fatalf("Bad: %v", v)
|
|
|
|
}
|
|
|
|
if v := aeScale(intv, 10000); v != 8*intv {
|
|
|
|
t.Fatalf("Bad: %v", v)
|
|
|
|
}
|
|
|
|
}
|
2014-01-15 22:34:17 +00:00
|
|
|
|
2015-01-08 03:11:21 +00:00
|
|
|
func TestStringHash(t *testing.T) {
|
|
|
|
in := "hello world"
|
|
|
|
expected := "5eb63bbbe01eeed093cb22bb8f5acdc3"
|
|
|
|
|
|
|
|
if out := stringHash(in); out != expected {
|
|
|
|
t.Fatalf("bad: %s", out)
|
|
|
|
}
|
|
|
|
}
|
2015-01-20 22:13:36 +00:00
|
|
|
|
|
|
|
func TestSetFilePermissions(t *testing.T) {
|
2015-05-29 19:03:55 +00:00
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
t.SkipNow()
|
|
|
|
}
|
2017-05-12 08:34:50 +00:00
|
|
|
tempFile, err := ioutil.TempFile("", t.Name()+"-consul")
|
2015-01-20 22:13:36 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
path := tempFile.Name()
|
|
|
|
defer os.Remove(path)
|
|
|
|
|
|
|
|
// Bad UID fails
|
2015-01-21 04:30:59 +00:00
|
|
|
if err := setFilePermissions(path, UnixSocketPermissions{Usr: "%"}); err == nil {
|
2015-01-20 22:13:36 +00:00
|
|
|
t.Fatalf("should fail")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bad GID fails
|
2015-01-21 04:30:59 +00:00
|
|
|
if err := setFilePermissions(path, UnixSocketPermissions{Grp: "%"}); err == nil {
|
2015-01-20 22:13:36 +00:00
|
|
|
t.Fatalf("should fail")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bad mode fails
|
2015-01-21 04:30:59 +00:00
|
|
|
if err := setFilePermissions(path, UnixSocketPermissions{Perms: "%"}); err == nil {
|
2015-01-20 22:13:36 +00:00
|
|
|
t.Fatalf("should fail")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Allows omitting user/group/mode
|
2015-01-21 04:30:59 +00:00
|
|
|
if err := setFilePermissions(path, UnixSocketPermissions{}); err != nil {
|
2015-01-20 22:13:36 +00: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)
|
|
|
|
}
|
2015-01-21 04:30:59 +00:00
|
|
|
if err := setFilePermissions(path, UnixSocketPermissions{}); err != nil {
|
2015-01-20 22:13:36 +00: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
|
2015-01-21 04:30:59 +00:00
|
|
|
if err := setFilePermissions(path, UnixSocketPermissions{Perms: "0777"}); err != nil {
|
2015-01-20 22:13:36 +00: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())
|
|
|
|
}
|
|
|
|
}
|