From 9272f55c86c70fa8a1079d49f92e85b2821c2146 Mon Sep 17 00:00:00 2001 From: hlts2 Date: Wed, 12 Jul 2023 10:46:59 +0900 Subject: [PATCH 1/4] fix index path for test Signed-off-by: hlts2 --- internal/core/algorithm/ngt/ngt_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/internal/core/algorithm/ngt/ngt_test.go b/internal/core/algorithm/ngt/ngt_test.go index 70156d88ff..ca3a4b3b00 100644 --- a/internal/core/algorithm/ngt/ngt_test.go +++ b/internal/core/algorithm/ngt/ngt_test.go @@ -1829,7 +1829,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-813", + idxPath: "/tmp/ngt-814", bulkInsertChunkSize: 100, dimension: 9, objectType: Float, From e25266a01519e75d23d4ee8ef92a396c22a9ae52 Mon Sep 17 00:00:00 2001 From: hlts2 Date: Wed, 12 Jul 2023 11:40:52 +0900 Subject: [PATCH 2/4] use t.TempDir for index path Signed-off-by: hlts2 --- internal/core/algorithm/ngt/ngt_test.go | 28 ++++++++++++------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/internal/core/algorithm/ngt/ngt_test.go b/internal/core/algorithm/ngt/ngt_test.go index ca3a4b3b00..2fb612c6d7 100644 --- a/internal/core/algorithm/ngt/ngt_test.go +++ b/internal/core/algorithm/ngt/ngt_test.go @@ -1397,7 +1397,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-81", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1425,7 +1425,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-82", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1453,7 +1453,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-83", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1487,7 +1487,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-84", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1528,7 +1528,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-85", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1574,7 +1574,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-86", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1602,7 +1602,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-87", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1630,7 +1630,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-88", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1663,7 +1663,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-89", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1704,7 +1704,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-810", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1750,7 +1750,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-811", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1778,7 +1778,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-812", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1804,7 +1804,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-813", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1829,7 +1829,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: "/tmp/ngt-814", + idxPath: t.TempDir(), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, From 2a7927b3c1c44f3611ecdaff63fa71dfabb4f00e Mon Sep 17 00:00:00 2001 From: hlts2 Date: Wed, 12 Jul 2023 14:34:18 +0900 Subject: [PATCH 3/4] create inde temp directory and fix fails test Signed-off-by: hlts2 --- internal/core/algorithm/ngt/ngt_test.go | 377 ++++++++++++++---------- 1 file changed, 214 insertions(+), 163 deletions(-) diff --git a/internal/core/algorithm/ngt/ngt_test.go b/internal/core/algorithm/ngt/ngt_test.go index 2fb612c6d7..7039631ee3 100644 --- a/internal/core/algorithm/ngt/ngt_test.go +++ b/internal/core/algorithm/ngt/ngt_test.go @@ -22,7 +22,9 @@ import ( "io/fs" "math" "os" + "path/filepath" "reflect" + "strings" "sync" "testing" @@ -32,7 +34,6 @@ import ( "github.com/vdaas/vald/internal/file" "github.com/vdaas/vald/internal/log" "github.com/vdaas/vald/internal/log/logger" - "github.com/vdaas/vald/internal/strings" "github.com/vdaas/vald/internal/test/comparator" "github.com/vdaas/vald/internal/test/goleak" ) @@ -75,6 +76,11 @@ var ( } ) +func idxTempDir(t *testing.T) string { + t.Helper() + return filepath.Join(t.TempDir(), "index") +} + func TestMain(m *testing.M) { log.Init(log.WithLoggerType(logger.NOP.String())) os.Exit(m.Run()) @@ -103,7 +109,7 @@ func TestNew(t *testing.T) { // comparator for idxPath comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + return s1 == s2 }))) if diff := comparator.Diff(got, w.want, comparators...); diff != "" { @@ -120,74 +126,101 @@ func TestNew(t *testing.T) { return nil } tests := []test{ - { - name: "return NGT when no option is set", - args: args{ - opts: nil, - }, - want: want{ - want: &ngt{ - idxPath: "/tmp/ngt-", - radius: DefaultRadius, - epsilon: DefaultEpsilon, - poolSize: DefaultPoolSize, - bulkInsertChunkSize: 100, - objectType: Float, - mu: &sync.RWMutex{}, + func() test { + return test{ + name: "return NGT when no option is set", + args: args{ + opts: nil, }, - }, - }, - { - name: "return NGT when 1 option is set", - args: args{ - opts: []Option{ - WithIndexPath("/tmp/ngt-01"), + want: want{ + want: &ngt{ + idxPath: "/tmp/ngt-", + radius: DefaultRadius, + epsilon: DefaultEpsilon, + poolSize: DefaultPoolSize, + bulkInsertChunkSize: 100, + objectType: Float, + mu: &sync.RWMutex{}, + }, }, - }, - want: want{ - want: &ngt{ - idxPath: "/tmp/ngt-01", - radius: DefaultRadius, - epsilon: DefaultEpsilon, - poolSize: DefaultPoolSize, - bulkInsertChunkSize: 100, - objectType: Float, - mu: &sync.RWMutex{}, + checkFunc: func(w want, got NGT, err error) error { + if !errors.Is(err, w.err) { + return errors.Errorf("got_error: \"%#v\",\n\t\t\t\twant: \"%#v\"", err, w.err) + } + comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { + return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + }))) + if diff := comparator.Diff(got, w.want, comparators...); diff != "" { + return errors.Errorf("diff: %s", diff) + } + if ngt, ok := got.(*ngt); ok { + if _, err := os.Stat(ngt.idxPath); errors.Is(err, fs.ErrNotExist) { + return errors.Errorf("index file not exists, path: %s", ngt.idxPath) + } + } + return nil }, - }, - }, - { - name: "return NGT when multiple options are set", - args: args{ - opts: []Option{ - WithObjectType(Uint8), - WithDefaultPoolSize(100), - WithIndexPath("/tmp/ngt-02"), + } + }(), + func() test { + idxPath := idxTempDir(t) + return test{ + name: "return NGT when 1 option is set", + args: args{ + opts: []Option{ + WithIndexPath(idxPath), + }, }, - }, - want: want{ - want: &ngt{ - idxPath: "/tmp/ngt-02", - radius: DefaultRadius, - epsilon: DefaultEpsilon, - poolSize: 100, - bulkInsertChunkSize: 100, - objectType: Uint8, - mu: &sync.RWMutex{}, + want: want{ + want: &ngt{ + idxPath: idxPath, + radius: DefaultRadius, + epsilon: DefaultEpsilon, + poolSize: DefaultPoolSize, + bulkInsertChunkSize: 100, + objectType: Float, + mu: &sync.RWMutex{}, + }, }, - }, - }, - { - name: "return error when option return error", - args: args{ - opts: []Option{ - WithDimension(1), + } + }(), + func() test { + idxPath := idxTempDir(t) + return test{ + name: "return NGT when multiple options are set", + args: args{ + opts: []Option{ + WithObjectType(Uint8), + WithDefaultPoolSize(100), + WithIndexPath(idxPath), + }, }, - }, - want: want{ - err: errors.NewErrCriticalOption("dimension", 1, errors.ErrInvalidDimensionSize(1, algorithm.MaximumVectorDimensionSize)), - }, - }, + want: want{ + want: &ngt{ + idxPath: idxPath, + radius: DefaultRadius, + epsilon: DefaultEpsilon, + poolSize: 100, + bulkInsertChunkSize: 100, + objectType: Uint8, + mu: &sync.RWMutex{}, + }, + }, + } + }(), + func() test { + return test{ + name: "return error when option return error", + args: args{ + opts: []Option{ + WithDimension(1), + }, + }, + want: want{ + err: errors.NewErrCriticalOption("dimension", 1, errors.ErrInvalidDimensionSize(1, algorithm.MaximumVectorDimensionSize)), + }, + } + }(), } for _, tc := range tests { @@ -242,7 +275,7 @@ func TestLoad(t *testing.T) { // comparator for idxPath comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + return s1 == s2 }))) if diff := comparator.Diff(got, w.want, comparators...); diff != "" { @@ -261,7 +294,7 @@ func TestLoad(t *testing.T) { tests := []test{ // uint func() test { - idxPath := "/tmp/ngt-11" + idxPath := idxTempDir(t) opts := []Option{ WithDimension(9), WithIndexPath(idxPath), @@ -322,7 +355,7 @@ func TestLoad(t *testing.T) { } }(), func() test { - idxPath := "/tmp/ngt-12" + idxPath := idxTempDir(t) vec := []float32{0, 1, 2, 3, 4, 5, 6, 7, 8} opts := []Option{ WithDimension(9), @@ -391,7 +424,7 @@ func TestLoad(t *testing.T) { }(), // float func() test { - idxPath := "/tmp/ngt-13" + idxPath := idxTempDir(t) opts := []Option{ WithDimension(9), WithIndexPath(idxPath), @@ -452,7 +485,7 @@ func TestLoad(t *testing.T) { } }(), func() test { - idxPath := "/tmp/ngt-14" + idxPath := idxTempDir(t) vec := []float32{0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8} opts := []Option{ WithDimension(9), @@ -521,7 +554,7 @@ func TestLoad(t *testing.T) { }(), // other func() test { - idxPath := "/tmp/ngt-15" + idxPath := idxTempDir(t) vec := []float32{0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8} opts := []Option{ WithDimension(9), @@ -566,7 +599,7 @@ func TestLoad(t *testing.T) { } }(), func() test { - idxPath := "/tmp/ngt-16" + idxPath := idxTempDir(t) opts := []Option{ WithDimension(9), WithIndexPath(idxPath), @@ -655,7 +688,7 @@ func Test_gen(t *testing.T) { // comparator for idxPath comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + return s1 == s2 }))) if diff := comparator.Diff(got, w.want, comparators...); diff != "" { @@ -688,9 +721,27 @@ func Test_gen(t *testing.T) { mu: &sync.RWMutex{}, }, }, + checkFunc: func(ctx context.Context, w want, got NGT, err error) error { + if !errors.Is(err, w.err) { + return errors.Errorf("got_error: \"%#v\",\n\t\t\t\twant: \"%#v\"", err, w.err) + } + comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { + return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + }))) + if diff := comparator.Diff(got, w.want, comparators...); diff != "" { + return errors.Errorf("diff: %s", diff) + } + if ngt, ok := got.(*ngt); ok { + if _, err := os.Stat(ngt.idxPath); errors.Is(err, fs.ErrNotExist) { + return errors.Errorf("index file not exists, path: %s", ngt.idxPath) + } + } + + return nil + }, }, func() test { - idxPath := "/tmp/ngt-21" + idxPath := idxTempDir(t) vec := []float32{0, 1, 2, 3, 4, 5, 6, 7, 8} opts := []Option{ WithDimension(9), @@ -1074,10 +1125,10 @@ func Test_ngt_open(t *testing.T) { type test struct { name string fields fields - createFunc func(t *testing.T, fields fields) (NGT, error) + createFunc func(*testing.T, fields) (NGT, error) want want checkFunc func(want, error) error - beforeFunc func(*testing.T) + beforeFunc func(*testing.T, fields) afterFunc func(*testing.T, NGT) error } defaultCreateFunc := func(t *testing.T, fields fields) (NGT, error) { @@ -1109,17 +1160,17 @@ func Test_ngt_open(t *testing.T) { { name: "return nil when index exists", fields: fields{ - idxPath: "/tmp/ngt-61", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, mu: &sync.RWMutex{}, }, - beforeFunc: func(t *testing.T) { + beforeFunc: func(t *testing.T, fields fields) { t.Helper() n, err := New( - WithIndexPath("/tmp/ngt-61"), + WithIndexPath(fields.idxPath), WithDimension(9), WithObjectType(Float), ) @@ -1143,7 +1194,7 @@ func Test_ngt_open(t *testing.T) { { name: "return error when index path is not exists", fields: fields{ - idxPath: "/tmp/ngt-62", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -1156,15 +1207,15 @@ func Test_ngt_open(t *testing.T) { { name: "return error when index path contains no file", fields: fields{ - idxPath: "/tmp/ngt-63", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, mu: &sync.RWMutex{}, }, - beforeFunc: func(*testing.T) { + beforeFunc: func(t *testing.T, fields fields) { t.Helper() - _ = file.MkdirAll("/tmp/ngt-63", fs.ModePerm) + _ = file.MkdirAll(fields.idxPath, fs.ModePerm) }, checkFunc: func(w want, e error) error { if e == nil { @@ -1181,7 +1232,7 @@ func Test_ngt_open(t *testing.T) { tt.Parallel() defer goleak.VerifyNone(tt, goleak.IgnoreCurrent()) if test.beforeFunc != nil { - test.beforeFunc(tt) + test.beforeFunc(tt, test.fields) } if test.afterFunc == nil { test.afterFunc = defaultAfterFunc @@ -1264,7 +1315,7 @@ func Test_ngt_loadObjectSpace(t *testing.T) { { name: "return nil when load object space success", fields: fields{ - idxPath: "/tmp/ngt-71", + idxPath: idxTempDir(t), dimension: 9, objectType: Float, }, @@ -1397,7 +1448,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1425,7 +1476,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1453,7 +1504,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1487,7 +1538,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1528,7 +1579,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1574,7 +1625,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1602,7 +1653,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1630,7 +1681,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1663,7 +1714,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1704,7 +1755,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1750,7 +1801,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1778,7 +1829,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Uint8, @@ -1804,7 +1855,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1829,7 +1880,7 @@ func Test_ngt_Search(t *testing.T) { }, fields: fields{ inMemory: false, - idxPath: t.TempDir(), + idxPath: idxTempDir(t), bulkInsertChunkSize: 100, dimension: 9, objectType: Float, @@ -1969,7 +2020,7 @@ func Test_ngt_Insert(t *testing.T) { vec: []float32{0, 1, 2, 3, 4, 5, 6, 7, 8}, }, fields: fields{ - idxPath: "/tmp/ngt-91", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -1984,7 +2035,7 @@ func Test_ngt_Insert(t *testing.T) { vec: []float32{0, 0, 0, 0, 0, 0, 0, 0, 0}, }, fields: fields{ - idxPath: "/tmp/ngt-92", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2002,7 +2053,7 @@ func Test_ngt_Insert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-93", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2020,7 +2071,7 @@ func Test_ngt_Insert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-94", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2035,7 +2086,7 @@ func Test_ngt_Insert(t *testing.T) { vec: []float32{0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8}, }, fields: fields{ - idxPath: "/tmp/ngt-95", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2050,7 +2101,7 @@ func Test_ngt_Insert(t *testing.T) { vec: []float32{0, 0, 0, 0, 0, 0, 0, 0, 0}, }, fields: fields{ - idxPath: "/tmp/ngt-96", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2068,7 +2119,7 @@ func Test_ngt_Insert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-97", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2086,7 +2137,7 @@ func Test_ngt_Insert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-98", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2101,7 +2152,7 @@ func Test_ngt_Insert(t *testing.T) { vec: []float32{0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8}, }, fields: fields{ - idxPath: "/tmp/ngt-99", + idxPath: idxTempDir(t), inMemory: false, dimension: 5, objectType: Float, @@ -2225,7 +2276,7 @@ func Test_ngt_InsertCommit(t *testing.T) { vec: []float32{0, 1, 2, 3, 4, 5, 6, 7, 8}, }, fields: fields{ - idxPath: "/tmp/ngt-101", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2240,7 +2291,7 @@ func Test_ngt_InsertCommit(t *testing.T) { vec: []float32{0, 0, 0, 0, 0, 0, 0, 0, 0}, }, fields: fields{ - idxPath: "/tmp/ngt-102", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2258,7 +2309,7 @@ func Test_ngt_InsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-103", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2276,7 +2327,7 @@ func Test_ngt_InsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-104", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Uint8, @@ -2291,7 +2342,7 @@ func Test_ngt_InsertCommit(t *testing.T) { vec: []float32{0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8}, }, fields: fields{ - idxPath: "/tmp/ngt-105", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2306,7 +2357,7 @@ func Test_ngt_InsertCommit(t *testing.T) { vec: []float32{0, 0, 0, 0, 0, 0, 0, 0, 0}, }, fields: fields{ - idxPath: "/tmp/ngt-106", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2324,7 +2375,7 @@ func Test_ngt_InsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-107", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2342,7 +2393,7 @@ func Test_ngt_InsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-108", + idxPath: idxTempDir(t), inMemory: false, dimension: 9, objectType: Float, @@ -2357,7 +2408,7 @@ func Test_ngt_InsertCommit(t *testing.T) { vec: []float32{0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8}, }, fields: fields{ - idxPath: "/tmp/ngt-109", + idxPath: idxTempDir(t), inMemory: false, dimension: 5, objectType: Float, @@ -2512,7 +2563,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-111", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2535,7 +2586,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-112", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2555,7 +2606,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-113", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2577,7 +2628,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-114", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2600,7 +2651,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-115", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2623,7 +2674,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-116", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2643,7 +2694,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-117", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2665,7 +2716,7 @@ func Test_ngt_BulkInsert(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-118", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2808,7 +2859,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-121", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2831,7 +2882,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-122", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2851,7 +2902,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-123", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2873,7 +2924,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-124", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2896,7 +2947,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-125", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2919,7 +2970,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-126", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2939,7 +2990,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-127", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -2961,7 +3012,7 @@ func Test_ngt_BulkInsertCommit(t *testing.T) { }, }, fields: fields{ - idxPath: "/tmp/ngt-128", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3083,7 +3134,7 @@ func Test_ngt_CreateAndSaveIndex(t *testing.T) { poolSize: 0, }, fields: fields{ - idxPath: "/tmp/ngt-131", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3096,7 +3147,7 @@ func Test_ngt_CreateAndSaveIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-132", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3123,7 +3174,7 @@ func Test_ngt_CreateAndSaveIndex(t *testing.T) { poolSize: 0, }, fields: fields{ - idxPath: "/tmp/ngt-133", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -3182,7 +3233,7 @@ func Test_ngt_CreateAndSaveIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-134", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3227,7 +3278,7 @@ func Test_ngt_CreateAndSaveIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-135", + idxPath: idxTempDir(t), inMemory: true, bulkInsertChunkSize: 5, dimension: 9, @@ -3342,7 +3393,7 @@ func Test_ngt_CreateIndex(t *testing.T) { poolSize: 0, }, fields: fields{ - idxPath: "/tmp/ngt-141", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3355,7 +3406,7 @@ func Test_ngt_CreateIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-142", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3382,7 +3433,7 @@ func Test_ngt_CreateIndex(t *testing.T) { poolSize: 0, }, fields: fields{ - idxPath: "/tmp/ngt-143", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -3441,7 +3492,7 @@ func Test_ngt_CreateIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-144", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3486,7 +3537,7 @@ func Test_ngt_CreateIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-145", + idxPath: idxTempDir(t), inMemory: true, bulkInsertChunkSize: 5, dimension: 9, @@ -3598,7 +3649,7 @@ func Test_ngt_SaveIndex(t *testing.T) { poolSize: 0, }, fields: fields{ - idxPath: "/tmp/ngt-151", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3611,7 +3662,7 @@ func Test_ngt_SaveIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-152", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3638,7 +3689,7 @@ func Test_ngt_SaveIndex(t *testing.T) { poolSize: 0, }, fields: fields{ - idxPath: "/tmp/ngt-153", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -3697,7 +3748,7 @@ func Test_ngt_SaveIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-154", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 5, dimension: 9, @@ -3742,7 +3793,7 @@ func Test_ngt_SaveIndex(t *testing.T) { poolSize: 100, }, fields: fields{ - idxPath: "/tmp/ngt-155", + idxPath: idxTempDir(t), inMemory: true, bulkInsertChunkSize: 5, dimension: 9, @@ -3861,7 +3912,7 @@ func Test_ngt_Remove(t *testing.T) { id: 1, }, fields: fields{ - idxPath: "/tmp/ngt-161", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -3893,7 +3944,7 @@ func Test_ngt_Remove(t *testing.T) { id: 999, }, fields: fields{ - idxPath: "/tmp/ngt-162", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -3927,7 +3978,7 @@ func Test_ngt_Remove(t *testing.T) { id: 1, }, fields: fields{ - idxPath: "/tmp/ngt-163", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -3959,7 +4010,7 @@ func Test_ngt_Remove(t *testing.T) { id: 999, }, fields: fields{ - idxPath: "/tmp/ngt-164", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4095,7 +4146,7 @@ func Test_ngt_BulkRemove(t *testing.T) { ids: []uint{1}, }, fields: fields{ - idxPath: "/tmp/ngt-171", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4127,7 +4178,7 @@ func Test_ngt_BulkRemove(t *testing.T) { ids: []uint{999}, }, fields: fields{ - idxPath: "/tmp/ngt-172", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4160,7 +4211,7 @@ func Test_ngt_BulkRemove(t *testing.T) { ids: []uint{1, 999}, }, fields: fields{ - idxPath: "/tmp/ngt-173", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4206,7 +4257,7 @@ func Test_ngt_BulkRemove(t *testing.T) { ids: []uint{1}, }, fields: fields{ - idxPath: "/tmp/ngt-174", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4238,7 +4289,7 @@ func Test_ngt_BulkRemove(t *testing.T) { ids: []uint{999}, }, fields: fields{ - idxPath: "/tmp/ngt-175", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4271,7 +4322,7 @@ func Test_ngt_BulkRemove(t *testing.T) { ids: []uint{1, 999}, }, fields: fields{ - idxPath: "/tmp/ngt-176", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4422,7 +4473,7 @@ func Test_ngt_GetVector(t *testing.T) { id: 1, }, fields: fields{ - idxPath: "/tmp/ngt-181", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4452,7 +4503,7 @@ func Test_ngt_GetVector(t *testing.T) { id: 10, }, fields: fields{ - idxPath: "/tmp/ngt-182", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4483,7 +4534,7 @@ func Test_ngt_GetVector(t *testing.T) { id: 1, }, fields: fields{ - idxPath: "/tmp/ngt-183", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4513,7 +4564,7 @@ func Test_ngt_GetVector(t *testing.T) { id: 10, }, fields: fields{ - idxPath: "/tmp/ngt-184", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4544,7 +4595,7 @@ func Test_ngt_GetVector(t *testing.T) { id: 10, }, fields: fields{ - idxPath: "/tmp/ngt-185", + idxPath: idxTempDir(t), inMemory: false, bulkInsertChunkSize: 100, dimension: 9, @@ -4658,8 +4709,8 @@ func Test_ngt_Close(t *testing.T) { { name: "close success", fields: fields{ + idxPath: idxTempDir(t), inMemory: false, - idxPath: "/tmp/ngt-191", bulkInsertChunkSize: 100, dimension: 9, objectType: Float, From 428219b463619c4d8039546ce0f599ef772c2af3 Mon Sep 17 00:00:00 2001 From: hlts2 Date: Wed, 12 Jul 2023 15:13:12 +0900 Subject: [PATCH 4/4] refactoring comprator Signed-off-by: hlts2 --- internal/core/algorithm/ngt/ngt_test.go | 107 ++++++++++-------------- 1 file changed, 42 insertions(+), 65 deletions(-) diff --git a/internal/core/algorithm/ngt/ngt_test.go b/internal/core/algorithm/ngt/ngt_test.go index 7039631ee3..e0dbb195d6 100644 --- a/internal/core/algorithm/ngt/ngt_test.go +++ b/internal/core/algorithm/ngt/ngt_test.go @@ -95,23 +95,22 @@ func TestNew(t *testing.T) { err error } type test struct { - name string - args args - want want - checkFunc func(want, NGT, error) error - beforeFunc func(args) - afterFunc func(*testing.T, NGT) error - } - defaultCheckFunc := func(w want, got NGT, err error) error { + name string + args args + want want + comparators []comparator.Option + checkFunc func(want, NGT, error, ...comparator.Option) error + beforeFunc func(args) + afterFunc func(*testing.T, NGT) error + } + defaultComprators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { + return s1 == s2 + }))) + defaultCheckFunc := func(w want, got NGT, err error, comparators ...comparator.Option) error { if !errors.Is(err, w.err) { return errors.Errorf("got_error: \"%#v\",\n\t\t\t\twant: \"%#v\"", err, w.err) } - // comparator for idxPath - comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return s1 == s2 - }))) - if diff := comparator.Diff(got, w.want, comparators...); diff != "" { return errors.Errorf("diff: %s", diff) } @@ -143,23 +142,9 @@ func TestNew(t *testing.T) { mu: &sync.RWMutex{}, }, }, - checkFunc: func(w want, got NGT, err error) error { - if !errors.Is(err, w.err) { - return errors.Errorf("got_error: \"%#v\",\n\t\t\t\twant: \"%#v\"", err, w.err) - } - comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") - }))) - if diff := comparator.Diff(got, w.want, comparators...); diff != "" { - return errors.Errorf("diff: %s", diff) - } - if ngt, ok := got.(*ngt); ok { - if _, err := os.Stat(ngt.idxPath); errors.Is(err, fs.ErrNotExist) { - return errors.Errorf("index file not exists, path: %s", ngt.idxPath) - } - } - return nil - }, + comparators: append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { + return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + }))), } }(), func() test { @@ -238,6 +223,10 @@ func TestNew(t *testing.T) { if test.checkFunc == nil { checkFunc = defaultCheckFunc } + comparators := test.comparators + if test.comparators == nil || len(test.comparators) == 0 { + comparators = defaultComprators + } got, err := New(test.args.opts...) defer func() { @@ -245,7 +234,7 @@ func TestNew(t *testing.T) { tt.Error(err) } }() - if err := checkFunc(test.want, got, err); err != nil { + if err := checkFunc(test.want, got, err, comparators...); err != nil { tt.Errorf("error = %v", err) } }) @@ -674,23 +663,22 @@ func Test_gen(t *testing.T) { err error } type test struct { - name string - args args - want want - checkFunc func(context.Context, want, NGT, error) error - beforeFunc func(*testing.T, args) - afterFunc func(*testing.T, NGT) error - } - defaultCheckFunc := func(_ context.Context, w want, got NGT, err error) error { + name string + args args + want want + comparators []comparator.Option + checkFunc func(context.Context, want, NGT, error, ...comparator.Option) error + beforeFunc func(*testing.T, args) + afterFunc func(*testing.T, NGT) error + } + defaultComprators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { + return s1 == s2 + }))) + defaultCheckFunc := func(_ context.Context, w want, got NGT, err error, comparators ...comparator.Option) error { if !errors.Is(err, w.err) { return errors.Errorf("got_error: \"%#v\",\n\t\t\t\twant: \"%#v\"", err, w.err) } - // comparator for idxPath - comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return s1 == s2 - }))) - if diff := comparator.Diff(got, w.want, comparators...); diff != "" { return errors.Errorf("diff: %s", diff) } @@ -721,24 +709,9 @@ func Test_gen(t *testing.T) { mu: &sync.RWMutex{}, }, }, - checkFunc: func(ctx context.Context, w want, got NGT, err error) error { - if !errors.Is(err, w.err) { - return errors.Errorf("got_error: \"%#v\",\n\t\t\t\twant: \"%#v\"", err, w.err) - } - comparators := append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { - return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") - }))) - if diff := comparator.Diff(got, w.want, comparators...); diff != "" { - return errors.Errorf("diff: %s", diff) - } - if ngt, ok := got.(*ngt); ok { - if _, err := os.Stat(ngt.idxPath); errors.Is(err, fs.ErrNotExist) { - return errors.Errorf("index file not exists, path: %s", ngt.idxPath) - } - } - - return nil - }, + comparators: append(ngtComparator, comparator.CompareField("idxPath", cmp.Comparer(func(s1, s2 string) bool { + return strings.HasPrefix(s1, "/tmp/ngt-") || strings.HasPrefix(s2, "/tmp/ngt-") + }))), }, func() test { idxPath := idxTempDir(t) @@ -782,8 +755,8 @@ func Test_gen(t *testing.T) { mu: &sync.RWMutex{}, }, }, - checkFunc: func(ctx context.Context, w want, n NGT, e error) error { - if err := defaultCheckFunc(ctx, w, n, e); err != nil { + checkFunc: func(ctx context.Context, w want, n NGT, e error, comparators ...comparator.Option) error { + if err := defaultCheckFunc(ctx, w, n, e, comparators...); err != nil { return err } @@ -837,6 +810,10 @@ func Test_gen(t *testing.T) { if test.checkFunc == nil { checkFunc = defaultCheckFunc } + comparators := test.comparators + if test.comparators == nil || len(test.comparators) == 0 { + comparators = defaultComprators + } got, err := gen(test.args.isLoad, test.args.opts...) defer func() { @@ -847,7 +824,7 @@ func Test_gen(t *testing.T) { ctx, cancel := context.WithCancel(context.Background()) defer cancel() - if err := checkFunc(ctx, test.want, got, err); err != nil { + if err := checkFunc(ctx, test.want, got, err, comparators...); err != nil { tt.Errorf("error = %v", err) } })