19563: Log memory usage of arv-mount, crunch-run, and keepstore.
[arvados.git] / lib / crunchstat / crunchstat_test.go
index c27e39241df08af2c925a791e6fd849afc496b90..f5e2f8662fb21c67e0d2883b58e9cf18beb52463 100644 (file)
@@ -6,20 +6,33 @@ package crunchstat
 
 import (
        "bufio"
+       "bytes"
        "io"
        "log"
        "os"
        "regexp"
        "testing"
+       "time"
+
+       "github.com/sirupsen/logrus"
+       . "gopkg.in/check.v1"
 )
 
+func Test(t *testing.T) {
+       TestingT(t)
+}
+
+var _ = Suite(&suite{})
+
+type suite struct{}
+
 func bufLogger() (*log.Logger, *bufio.Reader) {
        r, w := io.Pipe()
        logger := log.New(w, "", 0)
        return logger, bufio.NewReader(r)
 }
 
-func TestReadAllOrWarnFail(t *testing.T) {
+func (s *suite) TestReadAllOrWarnFail(c *C) {
        logger, rcv := bufLogger()
        rep := Reporter{Logger: logger}
 
@@ -35,32 +48,57 @@ func TestReadAllOrWarnFail(t *testing.T) {
                // reading, but reading from byte 0 returns an error.
                f, err := os.Open("/proc/self/mem")
                if err != nil {
-                       t.Fatalf("Opening /proc/self/mem: %s", err)
+                       c.Fatalf("Opening /proc/self/mem: %s", err)
                }
                if x, err := rep.readAllOrWarn(f); err == nil {
-                       t.Fatalf("Expected error, got %v", x)
+                       c.Fatalf("Expected error, got %v", x)
                }
        }
        <-done
        if err != nil {
-               t.Fatal(err)
+               c.Fatal(err)
        } else if matched, err := regexp.MatchString("^warning: read /proc/self/mem: .*", string(msg)); err != nil || !matched {
-               t.Fatalf("Expected error message about unreadable file, got \"%s\"", msg)
+               c.Fatalf("Expected error message about unreadable file, got \"%s\"", msg)
        }
 }
 
-func TestReadAllOrWarnSuccess(t *testing.T) {
+func (s *suite) TestReadAllOrWarnSuccess(c *C) {
        rep := Reporter{Logger: log.New(os.Stderr, "", 0)}
 
        f, err := os.Open("./crunchstat_test.go")
        if err != nil {
-               t.Fatalf("Opening ./crunchstat_test.go: %s", err)
+               c.Fatalf("Opening ./crunchstat_test.go: %s", err)
        }
        data, err := rep.readAllOrWarn(f)
        if err != nil {
-               t.Fatalf("got error %s", err)
+               c.Fatalf("got error %s", err)
        }
        if matched, err := regexp.MatchString("\npackage crunchstat\n", string(data)); err != nil || !matched {
-               t.Fatalf("data failed regexp: err %v, matched %v", err, matched)
+               c.Fatalf("data failed regexp: err %v, matched %v", err, matched)
+       }
+}
+
+func (s *suite) TestReportPIDs(c *C) {
+       var logbuf bytes.Buffer
+       logger := logrus.New()
+       logger.Out = &logbuf
+       r := Reporter{
+               Logger:     logger,
+               CgroupRoot: "/sys/fs/cgroup",
+               PollPeriod: time.Second,
+       }
+       r.Start()
+       r.ReportPID("init", 1)
+       r.ReportPID("test_process", os.Getpid())
+       r.ReportPID("nonexistent", 12345) // should be silently ignored/omitted
+       for deadline := time.Now().Add(10 * time.Second); ; time.Sleep(time.Millisecond) {
+               if time.Now().After(deadline) {
+                       c.Error("timed out")
+                       break
+               }
+               if regexp.MustCompile(`(!?ms).*procmem \d+ init \d+ test_process.*`).MatchString(logbuf.String()) {
+                       break
+               }
        }
+       c.Logf("%s", logbuf.String())
 }