From 6ac9deabb85f691e93a28a4c165cd323be181cc1 Mon Sep 17 00:00:00 2001 From: Pavel Karpy Date: Tue, 7 Jun 2022 20:34:46 +0300 Subject: [PATCH] [#264] storagegroup: Fix `out of range` It panicked when the previous members slice had capacity more than a new one because of incorrect slicing that led to `out of range`. Signed-off-by: Pavel Karpy --- storagegroup/storagegroup.go | 4 ++-- storagegroup/storagegroup_test.go | 12 ++++++++++++ 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/storagegroup/storagegroup.go b/storagegroup/storagegroup.go index a14bd0a9..df64a5da 100644 --- a/storagegroup/storagegroup.go +++ b/storagegroup/storagegroup.go @@ -138,14 +138,14 @@ func (sg *StorageGroup) SetMembers(members []oid.ID) { if cap(mV2) >= ln { mV2 = mV2[:0] } else { - mV2 = make([]refs.ObjectID, ln) + mV2 = make([]refs.ObjectID, 0, ln) } var oidV2 refs.ObjectID for i := 0; i < ln; i++ { members[i].WriteToV2(&oidV2) - mV2[i] = oidV2 + mV2 = append(mV2, oidV2) } } diff --git a/storagegroup/storagegroup_test.go b/storagegroup/storagegroup_test.go index ef74c186..f25959d0 100644 --- a/storagegroup/storagegroup_test.go +++ b/storagegroup/storagegroup_test.go @@ -181,3 +181,15 @@ func generateOIDList() []refs.ObjectID { return mmV2 } + +func TestStorageGroup_SetMembers_DoubleSetting(t *testing.T) { + var sg storagegroup.StorageGroup + + mm := []oid.ID{oidtest.ID(), oidtest.ID(), oidtest.ID()} // cap is 3 at least + sg.SetMembers(mm) + + // the previous cap is more that a new length; + // slicing should not lead to `out of range` + // and apply update correctly + sg.SetMembers(mm[:1]) +}