Fix unit tests for graphite

pull/3125/head
Can ZHANG 2015-06-12 15:03:01 +08:00 committed by Jason Wilder
parent c130efb5e2
commit 2a383e6858
2 changed files with 68 additions and 71 deletions

View File

@ -16,7 +16,8 @@ bind-address = ":8080"
database = "mydb" database = "mydb"
enabled = true enabled = true
protocol = "tcp" protocol = "tcp"
name-position = "first" name-schema= "measurement"
ignore-unnamed = true
name-separator = "." name-separator = "."
batch-size=100 batch-size=100
batch-timeout="1s" batch-timeout="1s"
@ -34,8 +35,10 @@ consistency-level="one"
t.Fatalf("unexpected graphite enabled: %v", c.Enabled) t.Fatalf("unexpected graphite enabled: %v", c.Enabled)
} else if c.Protocol != "tcp" { } else if c.Protocol != "tcp" {
t.Fatalf("unexpected graphite protocol: %s", c.Protocol) t.Fatalf("unexpected graphite protocol: %s", c.Protocol)
} else if c.NamePosition != "first" { } else if c.NameSchema != "measurement" {
t.Fatalf("unexpected graphite name position: %s", c.NamePosition) t.Fatalf("unexpected graphite name schema: %s", c.NameSchema)
} else if c.IgnoreUnnamed != true {
t.Fatalf("unexpected ignore-unnamed: %v", c.IgnoreUnnamed)
} else if c.NameSeparator != "." { } else if c.NameSeparator != "." {
t.Fatalf("unexpected graphite name separator: %s", c.NameSeparator) t.Fatalf("unexpected graphite name separator: %s", c.NameSeparator)
} else if c.BatchSize != 100 { } else if c.BatchSize != 100 {

View File

@ -23,29 +23,42 @@ func Test_DecodeNameAndTags(t *testing.T) {
str string str string
name string name string
tags map[string]string tags map[string]string
position string schema string
separator string separator string
ignore bool
err string err string
}{ }{
{test: "metric only", str: "cpu", name: "cpu"}, {test: "metric only", str: "cpu", name: "cpu", schema:"measurement", ignore: true},
{test: "metric with single series", str: "cpu.hostname.server01", name: "cpu", tags: map[string]string{"hostname": "server01"}}, {test: "metric with single series", str: "cpu.server01", name: "cpu", ignore: true,
{test: "metric with multiple series", str: "cpu.region.us-west.hostname.server01", name: "cpu", tags: map[string]string{"hostname": "server01", "region": "us-west"}}, schema:"measurement.hostname", tags: map[string]string{"hostname": "server01"}},
{test: "no metric", tags: make(map[string]string), err: `no name specified for metric. ""`}, {test: "metric with multiple series", str: "cpu.us-west.server01", name: "cpu", ignore: true,
{test: "wrong metric format", str: "foo.cpu", tags: make(map[string]string), err: `received "foo.cpu" which doesn't conform to format of key.value.key.value.name or name`}, schema:"measurement.region.hostname", tags: map[string]string{"hostname": "server01", "region": "us-west"}},
{test: "no metric", tags: make(map[string]string), ignore: true,
err: `no measurement specified for metric. ""`},
{test: "ignore unnamed", str: "foo.cpu", ignore: true, schema: "measurement",
tags: make(map[string]string), name: "foo"},
{test: "not ignore unnamed", str: "foo.cpu", ignore: false, schema: "measurement",
tags: make(map[string]string), err: `received "foo.cpu" which contains unnamed field`},
{test: "name shorter than schema", str: "foo", schema: "measurement.A.B.C", ignore: true,
tags: make(map[string]string), name: "foo"},
} }
for _, test := range tests { for _, test := range tests {
t.Logf("testing %q...", test.test) t.Logf("testing %q...", test.test)
p := graphite.NewParser() if test.separator == "" {
if test.separator != "" { test.separator = "."
p.Separator = test.separator
} }
p := graphite.NewParser(test.schema, test.separator, test.ignore)
name, tags, err := p.DecodeNameAndTags(test.str) name, tags, err := p.DecodeNameAndTags(test.str)
if errstr(err) != test.err { if errstr(err) != test.err {
t.Fatalf("err does not match. expected %v, got %v", test.err, err) t.Fatalf("err does not match. expected %v, got %v", test.err, err)
} }
if err != nil {
// If we erred out,it was intended and the following tests won't work
continue
}
if name != test.name { if name != test.name {
t.Fatalf("name parse failer. expected %v, got %v", test.name, name) t.Fatalf("name parse failer. expected %v, got %v", test.name, name)
} }
@ -72,58 +85,38 @@ func Test_DecodeMetric(t *testing.T) {
tags map[string]string tags map[string]string
value float64 value float64
time time.Time time time.Time
position, separator string separator string
schema string
ignore bool
err string err string
}{ }{
{ {
test: "position first by default", test: "normal case",
line: `cpu.foo.bar 50 ` + strTime, line: `cpu.foo.bar 50 ` + strTime,
schema: "measurement.foo.bar",
name: "cpu", name: "cpu",
tags: map[string]string{"foo": "bar"}, tags: map[string]string{
"foo": "foo",
"bar": "bar",
},
value: 50, value: 50,
time: testTime, time: testTime,
}, },
{ {
test: "position first if unable to determine", test: "DecodeNameAndTags returns error",
position: "foo",
line: `cpu.foo.bar 50 ` + strTime, line: `cpu.foo.bar 50 ` + strTime,
name: "cpu", schema: "a.b.c",
tags: map[string]string{"foo": "bar"}, err: `no measurement specified for metric. "cpu.foo.bar"`,
value: 50,
time: testTime,
},
{
test: "position last if specified",
position: "last",
line: `foo.bar.cpu 50 ` + strTime,
name: "cpu",
tags: map[string]string{"foo": "bar"},
value: 50,
time: testTime,
},
{
test: "position first if specified with no series",
position: "first",
line: `cpu 50 ` + strTime,
name: "cpu",
tags: map[string]string{},
value: 50,
time: testTime,
},
{
test: "position last if specified with no series",
position: "last",
line: `cpu 50 ` + strTime,
name: "cpu",
tags: map[string]string{},
value: 50,
time: testTime,
}, },
{ {
test: "separator is . by default", test: "separator is . by default",
line: `cpu.foo.bar 50 ` + strTime, line: `cpu.foo.bar 50 ` + strTime,
name: "cpu", name: "cpu",
tags: map[string]string{"foo": "bar"}, schema: "measurement.foo.bar",
tags: map[string]string{
"foo": "foo",
"bar": "bar",
},
value: 50, value: 50,
time: testTime, time: testTime,
}, },
@ -132,7 +125,11 @@ func Test_DecodeMetric(t *testing.T) {
separator: ".", separator: ".",
line: `cpu.foo.bar 50 ` + strTime, line: `cpu.foo.bar 50 ` + strTime,
name: "cpu", name: "cpu",
tags: map[string]string{"foo": "bar"}, schema: "measurement.foo.bar",
tags: map[string]string{
"foo": "foo",
"bar": "bar",
},
value: 50, value: 50,
time: testTime, time: testTime,
}, },
@ -141,7 +138,11 @@ func Test_DecodeMetric(t *testing.T) {
separator: "-", separator: "-",
line: `cpu-foo-bar 50 ` + strTime, line: `cpu-foo-bar 50 ` + strTime,
name: "cpu", name: "cpu",
tags: map[string]string{"foo": "bar"}, schema: "measurement-foo-bar",
tags: map[string]string{
"foo": "foo",
"bar": "bar",
},
value: 50, value: 50,
time: testTime, time: testTime,
}, },
@ -150,16 +151,11 @@ func Test_DecodeMetric(t *testing.T) {
separator: "boo", separator: "boo",
line: `cpuboofooboobar 50 ` + strTime, line: `cpuboofooboobar 50 ` + strTime,
name: "cpu", name: "cpu",
tags: map[string]string{"foo": "bar"}, schema: "measurementboofooboobar",
value: 50, tags: map[string]string{
time: testTime, "foo": "foo",
"bar": "bar",
}, },
{
test: "series + metric + integer value",
line: `cpu.foo.bar 50 ` + strTime,
name: "cpu",
tags: map[string]string{"foo": "bar"},
value: 50, value: 50,
time: testTime, time: testTime,
}, },
@ -167,6 +163,7 @@ func Test_DecodeMetric(t *testing.T) {
test: "metric only with float value", test: "metric only with float value",
line: `cpu 50.554 ` + strTime, line: `cpu 50.554 ` + strTime,
name: "cpu", name: "cpu",
schema: "measurement",
value: 50.554, value: 50.554,
time: testTime, time: testTime,
}, },
@ -175,24 +172,22 @@ func Test_DecodeMetric(t *testing.T) {
line: `50.554 1419972457825`, line: `50.554 1419972457825`,
err: `received "50.554 1419972457825" which doesn't have three fields`, err: `received "50.554 1419972457825" which doesn't have three fields`,
}, },
{
test: "should error on invalid key",
line: `foo.cpu 50.554 1419972457825`,
err: `received "foo.cpu" which doesn't conform to format of key.value.key.value.name or name`,
},
{ {
test: "should error parsing invalid float", test: "should error parsing invalid float",
line: `cpu 50.554z 1419972457825`, line: `cpu 50.554z 1419972457825`,
schema: "measurement",
err: `field "cpu" value: strconv.ParseFloat: parsing "50.554z": invalid syntax`, err: `field "cpu" value: strconv.ParseFloat: parsing "50.554z": invalid syntax`,
}, },
{ {
test: "should error parsing invalid int", test: "should error parsing invalid int",
line: `cpu 50z 1419972457825`, line: `cpu 50z 1419972457825`,
schema: "measurement",
err: `field "cpu" value: strconv.ParseFloat: parsing "50z": invalid syntax`, err: `field "cpu" value: strconv.ParseFloat: parsing "50z": invalid syntax`,
}, },
{ {
test: "should error parsing invalid time", test: "should error parsing invalid time",
line: `cpu 50.554 14199724z57825`, line: `cpu 50.554 14199724z57825`,
schema: "measurement",
err: `field "cpu" time: strconv.ParseFloat: parsing "14199724z57825": invalid syntax`, err: `field "cpu" time: strconv.ParseFloat: parsing "14199724z57825": invalid syntax`,
}, },
} }
@ -200,11 +195,10 @@ func Test_DecodeMetric(t *testing.T) {
for _, test := range tests { for _, test := range tests {
t.Logf("testing %q...", test.test) t.Logf("testing %q...", test.test)
p := graphite.NewParser() if test.separator == "" {
if test.separator != "" { test.separator = "."
p.Separator = test.separator
} }
p.LastEnabled = (test.position == "last") p := graphite.NewParser(test.schema, test.separator, test.ignore)
point, err := p.Parse(test.line) point, err := p.Parse(test.line)
if errstr(err) != test.err { if errstr(err) != test.err {