2022-01-04 22:41:45 +08:00
|
|
|
// Licensed to the LF AI & Data foundation under one
|
|
|
|
// or more contributor license agreements. See the NOTICE file
|
|
|
|
// distributed with this work for additional information
|
|
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
|
|
// to you under the Apache License, Version 2.0 (the
|
|
|
|
// "License"); you may not use this file except in compliance
|
2021-04-19 13:42:47 +08:00
|
|
|
// with the License. You may obtain a copy of the License at
|
|
|
|
//
|
2022-01-04 22:41:45 +08:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2021-04-19 13:42:47 +08:00
|
|
|
//
|
2022-01-04 22:41:45 +08:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2021-04-19 13:42:47 +08:00
|
|
|
|
2021-03-26 11:19:02 +08:00
|
|
|
package funcutil
|
|
|
|
|
|
|
|
import (
|
|
|
|
"math/rand"
|
|
|
|
"strconv"
|
2021-09-04 12:13:25 +08:00
|
|
|
"strings"
|
2021-03-26 11:19:02 +08:00
|
|
|
"testing"
|
|
|
|
|
2023-02-26 11:31:49 +08:00
|
|
|
"github.com/cockroachdb/errors"
|
2021-03-26 11:19:02 +08:00
|
|
|
"github.com/stretchr/testify/assert"
|
2023-11-06 06:02:16 +08:00
|
|
|
|
|
|
|
"github.com/milvus-io/milvus/pkg/util/hardware"
|
2021-03-26 11:19:02 +08:00
|
|
|
)
|
|
|
|
|
2021-09-04 12:13:25 +08:00
|
|
|
func dummyFunc() {
|
|
|
|
}
|
|
|
|
|
2021-09-08 16:53:30 +08:00
|
|
|
func Test_GetFunctionName(t *testing.T) {
|
2021-09-04 12:13:25 +08:00
|
|
|
name := GetFunctionName(dummyFunc)
|
|
|
|
assert.True(t, strings.Contains(name, "dummyFunc"))
|
|
|
|
}
|
|
|
|
|
2021-09-08 16:53:30 +08:00
|
|
|
func Test_ProcessFuncParallel(t *testing.T) {
|
2021-03-26 11:19:02 +08:00
|
|
|
total := 64
|
|
|
|
s := make([]int, total)
|
|
|
|
|
|
|
|
expectedS := make([]int, total)
|
|
|
|
for i := range expectedS {
|
|
|
|
expectedS[i] = i
|
|
|
|
}
|
|
|
|
|
|
|
|
naiveF := func(idx int) error {
|
|
|
|
s[idx] = idx
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var err error
|
|
|
|
|
2021-09-04 12:13:25 +08:00
|
|
|
err = ProcessFuncParallel(total, 0, naiveF, "naiveF") // maxParallel = 0
|
|
|
|
assert.Equal(t, err, nil)
|
|
|
|
|
|
|
|
err = ProcessFuncParallel(0, 1, naiveF, "naiveF") // total = 0
|
|
|
|
assert.Equal(t, err, nil)
|
|
|
|
|
2021-03-26 11:19:02 +08:00
|
|
|
err = ProcessFuncParallel(total, 1, naiveF, "naiveF") // serial
|
|
|
|
assert.Equal(t, err, nil, "process function serially must be right")
|
|
|
|
assert.Equal(t, s, expectedS, "process function serially must be right")
|
|
|
|
|
|
|
|
err = ProcessFuncParallel(total, total, naiveF, "naiveF") // Totally Parallel
|
|
|
|
assert.Equal(t, err, nil, "process function parallel must be right")
|
|
|
|
assert.Equal(t, s, expectedS, "process function parallel must be right")
|
|
|
|
|
2023-11-06 06:02:16 +08:00
|
|
|
err = ProcessFuncParallel(total, hardware.GetCPUNum(), naiveF, "naiveF") // Parallel by CPU
|
2021-03-26 11:19:02 +08:00
|
|
|
assert.Equal(t, err, nil, "process function parallel must be right")
|
|
|
|
assert.Equal(t, s, expectedS, "process function parallel must be right")
|
|
|
|
|
|
|
|
oddErrorF := func(idx int) error {
|
|
|
|
if idx%2 == 1 {
|
|
|
|
return errors.New("odd location: " + strconv.Itoa(idx))
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
err = ProcessFuncParallel(total, 1, oddErrorF, "oddErrorF") // serial
|
|
|
|
assert.NotEqual(t, err, nil, "process function serially must be right")
|
|
|
|
|
|
|
|
err = ProcessFuncParallel(total, total, oddErrorF, "oddErrorF") // Totally Parallel
|
|
|
|
assert.NotEqual(t, err, nil, "process function parallel must be right")
|
|
|
|
|
2023-11-06 06:02:16 +08:00
|
|
|
err = ProcessFuncParallel(total, hardware.GetCPUNum(), oddErrorF, "oddErrorF") // Parallel by CPU
|
2021-03-26 11:19:02 +08:00
|
|
|
assert.NotEqual(t, err, nil, "process function parallel must be right")
|
|
|
|
|
|
|
|
evenErrorF := func(idx int) error {
|
|
|
|
if idx%2 == 0 {
|
|
|
|
return errors.New("even location: " + strconv.Itoa(idx))
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
err = ProcessFuncParallel(total, 1, evenErrorF, "evenErrorF") // serial
|
|
|
|
assert.NotEqual(t, err, nil, "process function serially must be right")
|
|
|
|
|
|
|
|
err = ProcessFuncParallel(total, total, evenErrorF, "evenErrorF") // Totally Parallel
|
|
|
|
assert.NotEqual(t, err, nil, "process function parallel must be right")
|
|
|
|
|
2023-11-06 06:02:16 +08:00
|
|
|
err = ProcessFuncParallel(total, hardware.GetCPUNum(), evenErrorF, "evenErrorF") // Parallel by CPU
|
2021-03-26 11:19:02 +08:00
|
|
|
assert.NotEqual(t, err, nil, "process function parallel must be right")
|
|
|
|
|
2021-12-28 10:56:06 +08:00
|
|
|
// rand.Int() may be always an even number
|
2021-03-26 11:19:02 +08:00
|
|
|
randomErrorF := func(idx int) error {
|
|
|
|
if rand.Int()%2 == 0 {
|
|
|
|
return errors.New("random location: " + strconv.Itoa(idx))
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-10-04 17:18:56 +08:00
|
|
|
err = ProcessFuncParallel(total, 1, randomErrorF, "randomErrorF") // serial
|
2023-06-08 15:36:36 +08:00
|
|
|
assert.Error(t, err)
|
2021-03-26 11:19:02 +08:00
|
|
|
|
2021-10-04 17:18:56 +08:00
|
|
|
err = ProcessFuncParallel(total, total, randomErrorF, "randomErrorF") // Totally Parallel
|
2023-06-08 15:36:36 +08:00
|
|
|
assert.Error(t, err)
|
2021-03-26 11:19:02 +08:00
|
|
|
|
2023-11-06 06:02:16 +08:00
|
|
|
err = ProcessFuncParallel(total, hardware.GetCPUNum(), randomErrorF, "randomErrorF") // Parallel by CPU
|
2023-06-08 15:36:36 +08:00
|
|
|
assert.Error(t, err)
|
2021-03-26 11:19:02 +08:00
|
|
|
}
|