From b8ddb5f13c8ba27470538954432e09617f0ae6a2 Mon Sep 17 00:00:00 2001 From: Alexander Demidenko Date: Thu, 14 Dec 2023 14:45:46 +0300 Subject: [PATCH] added a more complex test after removing the last element of the ring --- ring.go | 20 ++++++++++++++------ ring_test.go | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 48 insertions(+), 6 deletions(-) diff --git a/ring.go b/ring.go index 38dc2b5..6ccb586 100644 --- a/ring.go +++ b/ring.go @@ -329,19 +329,27 @@ func (r *Ring) deletePoint(tree avl.Tree, p *point) (_ avl.Tree, removed bool) { return tree, true } -func (r *Ring) magicFactor() int { +func (r *Ring) magicFactor() float64 { if m := r.MagicFactor; m > 0 { - return m + return float64(m) } return DefaultMagicFactor } // r.mu must be held. -func (r *Ring) rebuild() { - numPoints := line( - r.maxWeight, float64(r.magicFactor()), - r.minWeight, math.Ceil(float64(r.magicFactor())*(r.minWeight/r.maxWeight)), +func (r *Ring) numPoints() func(float64) int { + if r.maxWeight == 0 { + return func(float64) int { return 0 } + } + return line( + r.maxWeight, r.magicFactor(), + r.minWeight, math.Ceil(r.magicFactor())*(r.minWeight/r.maxWeight), ) +} + +// r.mu must be held. +func (r *Ring) rebuild() { + numPoints := r.numPoints() r.ringMu.RLock() root := r.ring diff --git a/ring_test.go b/ring_test.go index 7b88996..1bea495 100644 --- a/ring_test.go +++ b/ring_test.go @@ -321,6 +321,40 @@ func TestRingDeleteNotExisting(t *testing.T) { } } +func TestRingInsertDelete(t *testing.T) { + var r Ring + x := StringItem("foo") + if err := r.Insert(x, 1); err != nil { + t.Fatalf("unexpected error: %v", err) + } + if err := r.Delete(x); err != nil { + t.Fatalf("unexpected error: %v", err) + } +} + +func TestRingInsertDeleteGetSequence(t *testing.T) { + var r Ring + x := StringItem("foo") + if err := r.Insert(x, 1); err != nil { + t.Fatalf("unexpected error: %v", err) + } + if err := r.Delete(x); err != nil { + t.Fatalf("unexpected error: %v", err) + } + if item := r.Get(x); item != nil { + t.Fatalf("unexpected item from empty ring") + } + if err := r.Insert(x, 1); err != nil { + t.Fatalf("unexpected error: %v", err) + } + if item := r.Get(x); item == nil { + t.Fatalf("want item, but return empty") + } + if err := r.Delete(x); err != nil { + t.Fatalf("unexpected error: %v", err) + } +} + func TestRingUpdateNotExisting(t *testing.T) { var r Ring x := StringItem("foo")