Refactor random functions

This commit is contained in:
Deluan 2024-05-11 20:04:21 -04:00
parent 30ae468dc1
commit 0ae2944073
10 changed files with 53 additions and 19 deletions

View file

@ -5,12 +5,18 @@ import (
"io/fs"
"os"
"path/filepath"
"testing"
"github.com/navidrome/navidrome/utils/merge"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
)
func TestMergeFS(t *testing.T) {
RegisterFailHandler(Fail)
RunSpecs(t, "MergeFS Suite")
}
var _ = Describe("FS", func() {
var baseName, overlayName string
var mergedDir fs.FS

View file

@ -1,18 +1,11 @@
package number
import (
"crypto/rand"
"math/big"
"strconv"
"golang.org/x/exp/constraints"
)
func RandomInt64(max int64) int64 {
rnd, _ := rand.Int(rand.Reader, big.NewInt(max))
return rnd.Int64()
}
func ParseInt[T constraints.Integer](s string) T {
r, _ := strconv.ParseInt(s, 10, 64)
return T(r)

View file

@ -4,6 +4,7 @@ import (
"testing"
"github.com/navidrome/navidrome/utils/number"
"github.com/navidrome/navidrome/utils/random"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
)
@ -17,7 +18,7 @@ var _ = Describe("number package", func() {
Describe("RandomInt64", func() {
It("should return a random int64", func() {
for i := 0; i < 10000; i++ {
Expect(number.RandomInt64(100)).To(BeNumerically("<", 100))
Expect(random.Int64(100)).To(BeNumerically("<", 100))
}
})
})

11
utils/random/number.go Normal file
View file

@ -0,0 +1,11 @@
package random
import (
"crypto/rand"
"math/big"
)
func Int64(max int64) int64 {
rnd, _ := rand.Int(rand.Reader, big.NewInt(max))
return rnd.Int64()
}

View file

@ -0,0 +1,24 @@
package random_test
import (
"testing"
"github.com/navidrome/navidrome/utils/random"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
)
func TestRandom(t *testing.T) {
RegisterFailHandler(Fail)
RunSpecs(t, "Random Suite")
}
var _ = Describe("number package", func() {
Describe("Int64", func() {
It("should return a random int64", func() {
for i := 0; i < 10000; i++ {
Expect(random.Int64(100)).To(BeNumerically("<", 100))
}
})
})
})

View file

@ -1,9 +1,7 @@
package utils
package random
import (
"errors"
"github.com/navidrome/navidrome/utils/number"
)
type WeightedChooser struct {
@ -41,7 +39,7 @@ func (w *WeightedChooser) weightedChoice() (int, error) {
if w.totalWeight == 0 {
return 0, errors.New("no choices available")
}
rnd := number.RandomInt64(int64(w.totalWeight))
rnd := Int64(int64(w.totalWeight))
for i, weight := range w.weights {
rnd -= int64(weight)
if rnd < 0 {

View file

@ -1,4 +1,4 @@
package utils
package random
import (
. "github.com/onsi/ginkgo/v2"