239 lines
7.5 KiB
Go
239 lines
7.5 KiB
Go
|
package mathext
|
||
|
|
||
|
import (
|
||
|
"math"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
func TestSumIntsHappyPath(t *testing.T) {
|
||
|
values := []int{1, 2, 3, 4, 5}
|
||
|
expected := 15
|
||
|
result := Sum(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("Sum of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestSumFloatsHappyPath(t *testing.T) {
|
||
|
values := []float64{1.1, 2.2, 3.3}
|
||
|
expected := 6.6
|
||
|
result := Sum(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("Sum of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMeanOfInts(t *testing.T) {
|
||
|
values := []float64{1, 2, 3, 4, 5}
|
||
|
expected := 3.0
|
||
|
result := Mean(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("Mean of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMedianOddNumberOfElements(t *testing.T) {
|
||
|
values := []float64{1, 2, 3, 4, 5}
|
||
|
expected := 3.0
|
||
|
result := Median(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("Median of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestMedianEvenNumberOfElements(t *testing.T) {
|
||
|
values := []float64{1, 2, 3, 4, 5, 6}
|
||
|
expected := 3.5
|
||
|
result := Median(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("Median of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestArrMinInts(t *testing.T) {
|
||
|
values := []int{5, 3, 9, 1, 4}
|
||
|
expected := 1
|
||
|
result := ArrMin(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("ArrMin of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestArrMaxInts(t *testing.T) {
|
||
|
values := []int{5, 3, 9, 1, 4}
|
||
|
expected := 9
|
||
|
result := ArrMax(values)
|
||
|
if result != expected {
|
||
|
t.Errorf("ArrMax of %v; expected %v, got %v", values, expected, result)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileValidInput(t *testing.T) {
|
||
|
values := []int{1, 2, 3, 4, 5}
|
||
|
percentile := 50.0
|
||
|
expected := 3
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileOutOfRange(t *testing.T) {
|
||
|
values := []int{1, 2, 3, 4, 5}
|
||
|
percentile := 150.0
|
||
|
_, err := Percentile(values, percentile)
|
||
|
if err == nil {
|
||
|
t.Errorf("Expected error for percentile %v out of range, got nil", percentile)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileValueInArray(t *testing.T) {
|
||
|
values := []int{1, 3, 5, 7, 9}
|
||
|
percentile := 40.0
|
||
|
expected := 4
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestFloatPercentileValueInArray(t *testing.T) {
|
||
|
values := []int{1, 3, 5, 7, 9}
|
||
|
percentile := 40.0
|
||
|
expected := 4.2
|
||
|
result, err := FloatPercentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileInterpolation(t *testing.T) {
|
||
|
values := []float64{1.0, 2.0, 3.0, 4.0, 5.0}
|
||
|
percentile := 25.0
|
||
|
expected := 2.0
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileSingleValue(t *testing.T) {
|
||
|
values := []int{10}
|
||
|
percentile := 50.0
|
||
|
expected := 10
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileExactlyBetweenTwoValues(t *testing.T) {
|
||
|
values := []float64{1, 2, 3, 4, 5}
|
||
|
percentile := 62.5 // Exactly between 3 and 4
|
||
|
expected := 3.5
|
||
|
result, err := FloatPercentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileTwoThirdsBetweenTwoValues(t *testing.T) {
|
||
|
values := []float64{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
|
||
|
percentile := 66.666666666666
|
||
|
expected := 6.666666666666667 // Since 2/3 of the way between 6 and 7 is 6.666...
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || math.Abs(result-expected) > 1e-9 {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileBetweenTwoValues1(t *testing.T) {
|
||
|
values := []float64{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
|
||
|
percentile := 11.0
|
||
|
expected := 1.1
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || math.Abs(result-expected) > 1e-9 {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileBetweenTwoValues2(t *testing.T) {
|
||
|
values := []float64{0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
|
||
|
percentile := 9.0
|
||
|
expected := 0.9
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || math.Abs(result-expected) > 1e-9 {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileUnsortedInput(t *testing.T) {
|
||
|
values := []float64{5, 1, 4, 2, 3} // Unsorted input
|
||
|
percentile := 50.0
|
||
|
expected := 3.0
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileUnsortedInputLowPercentile(t *testing.T) {
|
||
|
values := []float64{10, 6, 7, 3, 2, 9, 8, 1, 4, 5} // Unsorted input
|
||
|
percentile := 10.0
|
||
|
expected := 1.9 // Expecting interpolation between 1 and 2
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestPercentileUnsortedInputHighPercentile(t *testing.T) {
|
||
|
values := []float64{10, 6, 7, 3, 2, 9, 8, 1, 4, 5} // Unsorted input
|
||
|
percentile := 90.0
|
||
|
expected := 9.1 // Expecting interpolation between 9 and 10
|
||
|
result, err := Percentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("Percentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestFloatPercentileExactValueFromInput(t *testing.T) {
|
||
|
values := []float64{1.5, 2.5, 3.5, 4.5, 5.5}
|
||
|
percentile := 50.0 // Exact value from input array should be 3.5
|
||
|
expected := 3.5
|
||
|
result, err := FloatPercentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("FloatPercentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestFloatPercentileInterpolatedValue(t *testing.T) {
|
||
|
values := []float64{1.0, 2.0, 3.0, 4.0, 5.0}
|
||
|
percentile := 87.5 // Interpolated value between 4.0 and 5.0
|
||
|
expected := 4.5
|
||
|
result, err := FloatPercentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("FloatPercentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestFloatPercentileUnsortedInputExactValue(t *testing.T) {
|
||
|
values := []float64{5.5, 1.5, 4.5, 2.5, 3.5} // Unsorted input
|
||
|
percentile := 50.0
|
||
|
expected := 3.5
|
||
|
result, err := FloatPercentile(values, percentile)
|
||
|
if err != nil || result != expected {
|
||
|
t.Errorf("FloatPercentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestFloatPercentileUnsortedInputInterpolatedValue(t *testing.T) {
|
||
|
values := []float64{10.5, 6.5, 7.5, 3.5, 2.5, 9.5, 8.5, 1.5, 4.5, 5.5}
|
||
|
percentile := 80.0 // Interpolated value between 4.0 and 5.0
|
||
|
expected := 8.7
|
||
|
result, err := FloatPercentile(values, percentile)
|
||
|
if err != nil || math.Abs(result-expected) > 1e-9 {
|
||
|
t.Errorf("FloatPercentile %v of %v; expected %v, got %v, err: %v", percentile, values, expected, result, err)
|
||
|
}
|
||
|
}
|