package tsdb_test import ( "testing" "time" "github.com/BurntSushi/toml" "github.com/influxdata/influxdb/v2/tsdb" ) func TestConfig_Parse(t *testing.T) { // Parse configuration. c := tsdb.NewConfig() if _, err := toml.Decode(` dir = "/var/lib/influxdb/data" wal-dir = "/var/lib/influxdb/wal" wal-fsync-delay = "10s" tsm-use-madv-willneed = true `, &c); err != nil { t.Fatal(err) } if err := c.Validate(); err != nil { t.Errorf("unexpected validate error: %s", err) } if got, exp := c.Dir, "/var/lib/influxdb/data"; got != exp { t.Errorf("unexpected dir:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.WALDir, "/var/lib/influxdb/wal"; got != exp { t.Errorf("unexpected wal-dir:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.WALFsyncDelay, time.Duration(10*time.Second); time.Duration(got).Nanoseconds() != exp.Nanoseconds() { t.Errorf("unexpected wal-fsync-delay:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.TSMWillNeed, true; got != exp { t.Errorf("unexpected tsm-madv-willneed:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } } func TestConfig_Validate_Error(t *testing.T) { c := tsdb.NewConfig() if err := c.Validate(); err == nil || err.Error() != "Data.Dir must be specified" { t.Errorf("unexpected error: %s", err) } c.Dir = "/var/lib/influxdb/data" if err := c.Validate(); err == nil || err.Error() != "Data.WALDir must be specified" { t.Errorf("unexpected error: %s", err) } c.WALDir = "/var/lib/influxdb/wal" c.Engine = "fake1" if err := c.Validate(); err == nil || err.Error() != "unrecognized engine fake1" { t.Errorf("unexpected error: %s", err) } c.Engine = "tsm1" c.Index = "foo" if err := c.Validate(); err == nil || err.Error() != "unrecognized index foo" { t.Errorf("unexpected error: %s", err) } c.Index = tsdb.InmemIndexName if err := c.Validate(); err != nil { t.Error(err) } c.Index = tsdb.TSI1IndexName if err := c.Validate(); err != nil { t.Error(err) } c.SeriesIDSetCacheSize = -1 if err := c.Validate(); err == nil || err.Error() != "series-id-set-cache-size must be non-negative" { t.Errorf("unexpected error: %s", err) } } func TestConfig_ByteSizes(t *testing.T) { // Parse configuration. c := tsdb.NewConfig() if _, err := toml.Decode(` dir = "/var/lib/influxdb/data" wal-dir = "/var/lib/influxdb/wal" wal-fsync-delay = "10s" cache-max-memory-size = 5368709120 cache-snapshot-memory-size = 104857600 `, &c); err != nil { t.Fatal(err) } if err := c.Validate(); err != nil { t.Errorf("unexpected validate error: %s", err) } if got, exp := c.Dir, "/var/lib/influxdb/data"; got != exp { t.Errorf("unexpected dir:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.WALDir, "/var/lib/influxdb/wal"; got != exp { t.Errorf("unexpected wal-dir:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.WALFsyncDelay, time.Duration(10*time.Second); time.Duration(got).Nanoseconds() != exp.Nanoseconds() { t.Errorf("unexpected wal-fsync-delay:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.CacheMaxMemorySize, uint64(5<<30); uint64(got) != exp { t.Errorf("unexpected cache-max-memory-size:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.CacheSnapshotMemorySize, uint64(100<<20); uint64(got) != exp { t.Errorf("unexpected cache-snapshot-memory-size:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } } func TestConfig_HumanReadableSizes(t *testing.T) { // Parse configuration. c := tsdb.NewConfig() if _, err := toml.Decode(` dir = "/var/lib/influxdb/data" wal-dir = "/var/lib/influxdb/wal" wal-fsync-delay = "10s" cache-max-memory-size = "5g" cache-snapshot-memory-size = "100m" `, &c); err != nil { t.Fatal(err) } if err := c.Validate(); err != nil { t.Errorf("unexpected validate error: %s", err) } if got, exp := c.Dir, "/var/lib/influxdb/data"; got != exp { t.Errorf("unexpected dir:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.WALDir, "/var/lib/influxdb/wal"; got != exp { t.Errorf("unexpected wal-dir:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.WALFsyncDelay, time.Duration(10*time.Second); time.Duration(got).Nanoseconds() != exp.Nanoseconds() { t.Errorf("unexpected wal-fsync-delay:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.CacheMaxMemorySize, uint64(5<<30); uint64(got) != exp { t.Errorf("unexpected cache-max-memory-size:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } if got, exp := c.CacheSnapshotMemorySize, uint64(100<<20); uint64(got) != exp { t.Errorf("unexpected cache-snapshot-memory-size:\n\nexp=%v\n\ngot=%v\n\n", exp, got) } }