mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-11-21 14:44:00 +00:00
lib/storage: fix TestUpdateCurrHourMetricIDs test when it runs on the first hour of the day by UTC
This commit is contained in:
parent
d8d4d21d7a
commit
d8303845ef
2 changed files with 79 additions and 6 deletions
|
@ -2435,7 +2435,7 @@ func (s *Storage) updateNextDayMetricIDs(date uint64) {
|
||||||
if e.date == date {
|
if e.date == date {
|
||||||
pendingMetricIDs.Union(&e.v)
|
pendingMetricIDs.Union(&e.v)
|
||||||
} else {
|
} else {
|
||||||
// Do not add pendingMetricIDs from the previous day to the cyrrent day,
|
// Do not add pendingMetricIDs from the previous day to the current day,
|
||||||
// since this may result in missing registration of the metricIDs in the per-day inverted index.
|
// since this may result in missing registration of the metricIDs in the per-day inverted index.
|
||||||
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/3309
|
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/3309
|
||||||
pendingMetricIDs = &uint64set.Set{}
|
pendingMetricIDs = &uint64set.Set{}
|
||||||
|
@ -2484,9 +2484,8 @@ func (s *Storage) updateCurrHourMetricIDs(hour uint64) {
|
||||||
m = &uint64set.Set{}
|
m = &uint64set.Set{}
|
||||||
byTenant = make(map[accountProjectKey]*uint64set.Set)
|
byTenant = make(map[accountProjectKey]*uint64set.Set)
|
||||||
}
|
}
|
||||||
|
if hm.hour == hour || hour%24 != 0 {
|
||||||
if hour%24 != 0 {
|
// Do not add pending metricIDs from the previous hour on the previous day to the current hour,
|
||||||
// Do not add pending metricIDs from the previous hour to the current hour on the next day,
|
|
||||||
// since this may result in missing registration of the metricIDs in the per-day inverted index.
|
// since this may result in missing registration of the metricIDs in the per-day inverted index.
|
||||||
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/3309
|
// See https://github.com/VictoriaMetrics/VictoriaMetrics/issues/3309
|
||||||
for _, x := range newEntries {
|
for _, x := range newEntries {
|
||||||
|
|
|
@ -156,9 +156,12 @@ func TestUpdateCurrHourMetricIDs(t *testing.T) {
|
||||||
t.Run("empty_pending_metric_ids_stale_curr_hour", func(t *testing.T) {
|
t.Run("empty_pending_metric_ids_stale_curr_hour", func(t *testing.T) {
|
||||||
s := newStorage()
|
s := newStorage()
|
||||||
hour := fasttime.UnixHour()
|
hour := fasttime.UnixHour()
|
||||||
|
if hour%24 == 0 {
|
||||||
|
hour++
|
||||||
|
}
|
||||||
hmOrig := &hourMetricIDs{
|
hmOrig := &hourMetricIDs{
|
||||||
m: &uint64set.Set{},
|
m: &uint64set.Set{},
|
||||||
hour: 123,
|
hour: hour - 1,
|
||||||
}
|
}
|
||||||
hmOrig.m.Add(12)
|
hmOrig.m.Add(12)
|
||||||
hmOrig.m.Add(34)
|
hmOrig.m.Add(34)
|
||||||
|
@ -245,9 +248,12 @@ func TestUpdateCurrHourMetricIDs(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
hour := fasttime.UnixHour()
|
hour := fasttime.UnixHour()
|
||||||
|
if hour%24 == 0 {
|
||||||
|
hour++
|
||||||
|
}
|
||||||
hmOrig := &hourMetricIDs{
|
hmOrig := &hourMetricIDs{
|
||||||
m: &uint64set.Set{},
|
m: &uint64set.Set{},
|
||||||
hour: 123,
|
hour: hour - 1,
|
||||||
}
|
}
|
||||||
hmOrig.m.Add(12)
|
hmOrig.m.Add(12)
|
||||||
hmOrig.m.Add(34)
|
hmOrig.m.Add(34)
|
||||||
|
@ -343,6 +349,74 @@ func TestUpdateCurrHourMetricIDs(t *testing.T) {
|
||||||
t.Fatalf("unexpected s.pendingHourEntries.Len(); got %d; want %d", len(s.pendingHourEntries), 0)
|
t.Fatalf("unexpected s.pendingHourEntries.Len(); got %d; want %d", len(s.pendingHourEntries), 0)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
t.Run("nonempty_pending_metric_ids_valid_curr_hour_start_of_day", func(t *testing.T) {
|
||||||
|
s := newStorage()
|
||||||
|
s.pendingHourEntries = []pendingHourMetricIDEntry{
|
||||||
|
{AccountID: 123, ProjectID: 431, MetricID: 343},
|
||||||
|
{AccountID: 123, ProjectID: 431, MetricID: 32424},
|
||||||
|
{AccountID: 1, ProjectID: 2, MetricID: 8293432},
|
||||||
|
}
|
||||||
|
mExpected := &uint64set.Set{}
|
||||||
|
for _, e := range s.pendingHourEntries {
|
||||||
|
mExpected.Add(e.MetricID)
|
||||||
|
}
|
||||||
|
byTenantExpected := make(map[accountProjectKey]*uint64set.Set)
|
||||||
|
for _, e := range s.pendingHourEntries {
|
||||||
|
k := accountProjectKey{
|
||||||
|
AccountID: e.AccountID,
|
||||||
|
ProjectID: e.ProjectID,
|
||||||
|
}
|
||||||
|
x := byTenantExpected[k]
|
||||||
|
if x == nil {
|
||||||
|
x = &uint64set.Set{}
|
||||||
|
byTenantExpected[k] = x
|
||||||
|
}
|
||||||
|
x.Add(e.MetricID)
|
||||||
|
}
|
||||||
|
|
||||||
|
hour := fasttime.UnixHour()
|
||||||
|
hour -= hour % 24
|
||||||
|
hmOrig := &hourMetricIDs{
|
||||||
|
m: &uint64set.Set{},
|
||||||
|
hour: hour,
|
||||||
|
}
|
||||||
|
hmOrig.m.Add(12)
|
||||||
|
hmOrig.m.Add(34)
|
||||||
|
s.currHourMetricIDs.Store(hmOrig)
|
||||||
|
s.updateCurrHourMetricIDs(hour)
|
||||||
|
hmCurr := s.currHourMetricIDs.Load().(*hourMetricIDs)
|
||||||
|
if hmCurr.hour != hour {
|
||||||
|
// It is possible new hour occurred. Update the hour and verify it again.
|
||||||
|
hour = uint64(timestampFromTime(time.Now())) / msecPerHour
|
||||||
|
if hmCurr.hour != hour {
|
||||||
|
t.Fatalf("unexpected hmCurr.hour; got %d; want %d", hmCurr.hour, hour)
|
||||||
|
}
|
||||||
|
// Do not run other checks, since they may fail.
|
||||||
|
return
|
||||||
|
}
|
||||||
|
m := mExpected.Clone()
|
||||||
|
hmOrig.m.ForEach(func(part []uint64) bool {
|
||||||
|
for _, metricID := range part {
|
||||||
|
m.Add(metricID)
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
if !hmCurr.m.Equal(m) {
|
||||||
|
t.Fatalf("unexpected hm.m; got %v; want %v", hmCurr.m, m)
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(hmCurr.byTenant, byTenantExpected) {
|
||||||
|
t.Fatalf("unexpected hmPrev.byTenant; got %v; want %v", hmCurr.byTenant, byTenantExpected)
|
||||||
|
}
|
||||||
|
|
||||||
|
hmPrev := s.prevHourMetricIDs.Load().(*hourMetricIDs)
|
||||||
|
hmEmpty := &hourMetricIDs{}
|
||||||
|
if !reflect.DeepEqual(hmPrev, hmEmpty) {
|
||||||
|
t.Fatalf("unexpected hmPrev; got %v; want %v", hmPrev, hmEmpty)
|
||||||
|
}
|
||||||
|
if len(s.pendingHourEntries) != 0 {
|
||||||
|
t.Fatalf("unexpected s.pendingHourEntries.Len(); got %d; want %d", len(s.pendingHourEntries), 0)
|
||||||
|
}
|
||||||
|
})
|
||||||
t.Run("nonempty_pending_metric_ids_from_previous_hour_new_day", func(t *testing.T) {
|
t.Run("nonempty_pending_metric_ids_from_previous_hour_new_day", func(t *testing.T) {
|
||||||
s := newStorage()
|
s := newStorage()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue