mirror of
https://github.com/ClusterCockpit/cc-backend
synced 2024-12-25 12:59:06 +01:00
308 lines
8.2 KiB
Go
308 lines
8.2 KiB
Go
package units
|
|
|
|
import (
|
|
"fmt"
|
|
"reflect"
|
|
"regexp"
|
|
"testing"
|
|
)
|
|
|
|
func TestUnitsExact(t *testing.T) {
|
|
testCases := []struct {
|
|
in string
|
|
want Unit
|
|
}{
|
|
{"b", NewUnit("Bytes")},
|
|
{"B", NewUnit("Bytes")},
|
|
{"byte", NewUnit("Bytes")},
|
|
{"bytes", NewUnit("Bytes")},
|
|
{"BYtes", NewUnit("Bytes")},
|
|
{"Mb", NewUnit("MBytes")},
|
|
{"MB", NewUnit("MBytes")},
|
|
{"Mbyte", NewUnit("MBytes")},
|
|
{"Mbytes", NewUnit("MBytes")},
|
|
{"MbYtes", NewUnit("MBytes")},
|
|
{"Gb", NewUnit("GBytes")},
|
|
{"GB", NewUnit("GBytes")},
|
|
{"Hz", NewUnit("Hertz")},
|
|
{"MHz", NewUnit("MHertz")},
|
|
{"GHz", NewUnit("GHertz")},
|
|
{"pkts", NewUnit("Packets")},
|
|
{"packets", NewUnit("Packets")},
|
|
{"packet", NewUnit("Packets")},
|
|
{"flop", NewUnit("Flops")},
|
|
{"flops", NewUnit("Flops")},
|
|
{"floPS", NewUnit("Flops")},
|
|
{"Mflop", NewUnit("MFlops")},
|
|
{"Gflop", NewUnit("GFlops")},
|
|
{"gflop", NewUnit("GFlops")},
|
|
{"%", NewUnit("Percent")},
|
|
{"percent", NewUnit("Percent")},
|
|
{"degc", NewUnit("degC")},
|
|
{"degC", NewUnit("degC")},
|
|
{"degf", NewUnit("degF")},
|
|
{"°f", NewUnit("degF")},
|
|
{"events", NewUnit("events")},
|
|
{"event", NewUnit("events")},
|
|
{"EveNts", NewUnit("events")},
|
|
{"reqs", NewUnit("requests")},
|
|
{"reQuEsTs", NewUnit("requests")},
|
|
{"Requests", NewUnit("requests")},
|
|
{"cyc", NewUnit("cycles")},
|
|
{"cy", NewUnit("cycles")},
|
|
{"Cycles", NewUnit("cycles")},
|
|
{"J", NewUnit("Joules")},
|
|
{"Joule", NewUnit("Joules")},
|
|
{"joule", NewUnit("Joules")},
|
|
{"W", NewUnit("Watt")},
|
|
{"Watts", NewUnit("Watt")},
|
|
{"watt", NewUnit("Watt")},
|
|
{"s", NewUnit("seconds")},
|
|
{"sec", NewUnit("seconds")},
|
|
{"secs", NewUnit("seconds")},
|
|
{"RPM", NewUnit("rpm")},
|
|
{"rPm", NewUnit("rpm")},
|
|
{"watt/byte", NewUnit("W/B")},
|
|
{"watts/bytes", NewUnit("W/B")},
|
|
{"flop/byte", NewUnit("flops/Bytes")},
|
|
{"F/B", NewUnit("flops/Bytes")},
|
|
}
|
|
compareUnitExact := func(in, out Unit) bool {
|
|
if in.getMeasure() == out.getMeasure() && in.getUnitDenominator() == out.getUnitDenominator() && in.getPrefix() == out.getPrefix() {
|
|
return true
|
|
}
|
|
return false
|
|
}
|
|
for _, c := range testCases {
|
|
u := NewUnit(c.in)
|
|
if (!u.Valid()) || (!compareUnitExact(u, c.want)) {
|
|
t.Errorf("func NewUnit(%q) == %q, want %q", c.in, u.String(), c.want.String())
|
|
} else {
|
|
t.Logf("NewUnit(%q) == %q", c.in, u.String())
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestUnitUnitConversion(t *testing.T) {
|
|
testCases := []struct {
|
|
in string
|
|
want Unit
|
|
prefixFactor float64
|
|
}{
|
|
{"kb", NewUnit("Bytes"), 1000},
|
|
{"Mb", NewUnit("Bytes"), 1000000},
|
|
{"Mb/s", NewUnit("Bytes/s"), 1000000},
|
|
{"Flops/s", NewUnit("MFlops/s"), 1e-6},
|
|
{"Flops/s", NewUnit("GFlops/s"), 1e-9},
|
|
{"MHz", NewUnit("Hertz"), 1e6},
|
|
{"kb", NewUnit("Kib"), 1000.0 / 1024},
|
|
{"Mib", NewUnit("MBytes"), (1024 * 1024.0) / (1e6)},
|
|
{"mb", NewUnit("MBytes"), 1.0},
|
|
}
|
|
compareUnitWithPrefix := func(in, out Unit, factor float64) bool {
|
|
if in.getMeasure() == out.getMeasure() && in.getUnitDenominator() == out.getUnitDenominator() {
|
|
if f := GetPrefixPrefixFactor(in.getPrefix(), out.getPrefix()); f(1.0) == factor {
|
|
return true
|
|
} else {
|
|
fmt.Println(f(1.0))
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
for _, c := range testCases {
|
|
u := NewUnit(c.in)
|
|
if (!u.Valid()) || (!compareUnitWithPrefix(u, c.want, c.prefixFactor)) {
|
|
t.Errorf("GetPrefixPrefixFactor(%q, %q) invalid, want %q with factor %g", c.in, u.String(), c.want.String(), c.prefixFactor)
|
|
} else {
|
|
t.Logf("GetPrefixPrefixFactor(%q, %q) = %g", c.in, c.want.String(), c.prefixFactor)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestUnitPrefixConversion(t *testing.T) {
|
|
testCases := []struct {
|
|
in string
|
|
want string
|
|
prefixFactor float64
|
|
wantUnit Unit
|
|
}{
|
|
{"KBytes", "", 1000, NewUnit("Bytes")},
|
|
{"MBytes", "", 1e6, NewUnit("Bytes")},
|
|
{"MBytes", "G", 1e-3, NewUnit("GBytes")},
|
|
{"mb", "M", 1, NewUnit("MBytes")},
|
|
}
|
|
compareUnitPrefix := func(in Unit, out Prefix, factor float64, outUnit Unit) bool {
|
|
if in.Valid() {
|
|
conv, unit := GetUnitPrefixFactor(in, out)
|
|
value := conv(1.0)
|
|
if value == factor && unit.String() == outUnit.String() {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
for _, c := range testCases {
|
|
u := NewUnit(c.in)
|
|
p := NewPrefix(c.want)
|
|
if (!u.Valid()) || (!compareUnitPrefix(u, p, c.prefixFactor, c.wantUnit)) {
|
|
t.Errorf("GetUnitPrefixFactor(%q, %q) invalid, want %q with factor %g", c.in, p.Prefix(), c.wantUnit.String(), c.prefixFactor)
|
|
} else {
|
|
t.Logf("GetUnitPrefixFactor(%q, %q) = %g", c.in, c.wantUnit.String(), c.prefixFactor)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestPrefixPrefixConversion(t *testing.T) {
|
|
testCases := []struct {
|
|
in string
|
|
want string
|
|
prefixFactor float64
|
|
}{
|
|
{"K", "", 1000},
|
|
{"M", "", 1e6},
|
|
{"M", "G", 1e-3},
|
|
{"", "M", 1e-6},
|
|
{"", "m", 1e3},
|
|
{"m", "n", 1e6},
|
|
//{"", "n", 1e9}, //does not work because of IEEE rounding problems
|
|
}
|
|
for _, c := range testCases {
|
|
i := NewPrefix(c.in)
|
|
o := NewPrefix(c.want)
|
|
if i != InvalidPrefix && o != InvalidPrefix {
|
|
conv := GetPrefixPrefixFactor(i, o)
|
|
value := conv(1.0)
|
|
if value != c.prefixFactor {
|
|
t.Errorf("GetPrefixPrefixFactor(%q, %q) invalid, want %q with factor %g but got %g", c.in, c.want, o.Prefix(), c.prefixFactor, value)
|
|
} else {
|
|
t.Logf("GetPrefixPrefixFactor(%q, %q) = %g", c.in, c.want, c.prefixFactor)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestMeasureRegex(t *testing.T) {
|
|
for _, data := range MeasuresMap {
|
|
_, err := regexp.Compile(data.Regex)
|
|
if err != nil {
|
|
t.Errorf("failed to compile regex '%s': %s", data.Regex, err.Error())
|
|
}
|
|
t.Logf("succussfully compiled regex '%s' for measure %s", data.Regex, data.Long)
|
|
}
|
|
}
|
|
|
|
func TestPrefixRegex(t *testing.T) {
|
|
for _, data := range PrefixDataMap {
|
|
_, err := regexp.Compile(data.Regex)
|
|
if err != nil {
|
|
t.Errorf("failed to compile regex '%s': %s", data.Regex, err.Error())
|
|
}
|
|
t.Logf("succussfully compiled regex '%s' for prefix %s", data.Regex, data.Long)
|
|
}
|
|
}
|
|
|
|
func TestConvertValue(t *testing.T) {
|
|
v := float64(103456)
|
|
ConvertValue(&v, "MB/s", "GB/s")
|
|
|
|
if v != 104.00 {
|
|
t.Errorf("Failed ConvertValue: Want 103.456, Got %f", v)
|
|
}
|
|
}
|
|
|
|
func TestConvertValueUp(t *testing.T) {
|
|
v := float64(10.3456)
|
|
ConvertValue(&v, "GB/s", "MB/s")
|
|
|
|
if v != 10346.00 {
|
|
t.Errorf("Failed ConvertValue: Want 10346.00, Got %f", v)
|
|
}
|
|
}
|
|
func TestConvertSeries(t *testing.T) {
|
|
s := []float64{2890031237, 23998994567, 389734042344, 390349424345}
|
|
r := []float64{3, 24, 390, 391}
|
|
ConvertSeries(s, "F/s", "GF/s")
|
|
|
|
if !reflect.DeepEqual(s, r) {
|
|
t.Errorf("Failed ConvertValue: Want 3, 24, 390, 391, Got %v", s)
|
|
}
|
|
}
|
|
|
|
// func TestNormalizeValue(t *testing.T) {
|
|
// var s string
|
|
// v := float64(103456)
|
|
//
|
|
// NormalizeValue(&v, "MB/s", &s)
|
|
//
|
|
// if v != 104.00 {
|
|
// t.Errorf("Failed ConvertValue: Want 104.00, Got %f", v)
|
|
// }
|
|
// if s != "GB/s" {
|
|
// t.Errorf("Failed Prefix or unit: Want GB/s, Got %s", s)
|
|
// }
|
|
// }
|
|
//
|
|
// func TestNormalizeValueNoPrefix(t *testing.T) {
|
|
// var s string
|
|
// v := float64(103458596)
|
|
//
|
|
// NormalizeValue(&v, "F/s", &s)
|
|
//
|
|
// if v != 104.00 {
|
|
// t.Errorf("Failed ConvertValue: Want 104.00, Got %f", v)
|
|
// }
|
|
// if s != "MF/s" {
|
|
// t.Errorf("Failed Prefix or unit: Want MF/s, Got %s", s)
|
|
// }
|
|
// }
|
|
//
|
|
// func TestNormalizeValueKeep(t *testing.T) {
|
|
// var s string
|
|
// v := float64(345)
|
|
//
|
|
// NormalizeValue(&v, "MB/s", &s)
|
|
//
|
|
// if v != 345.00 {
|
|
// t.Errorf("Failed ConvertValue: Want 104.00, Got %f", v)
|
|
// }
|
|
// if s != "MB/s" {
|
|
// t.Errorf("Failed Prefix or unit: Want GB/s, Got %s", s)
|
|
// }
|
|
// }
|
|
//
|
|
// func TestNormalizeValueDown(t *testing.T) {
|
|
// var s string
|
|
// v := float64(0.0004578)
|
|
//
|
|
// NormalizeValue(&v, "GB/s", &s)
|
|
//
|
|
// if v != 458.00 {
|
|
// t.Errorf("Failed ConvertValue: Want 458.00, Got %f", v)
|
|
// }
|
|
// if s != "KB/s" {
|
|
// t.Errorf("Failed Prefix or unit: Want KB/s, Got %s", s)
|
|
// }
|
|
// }
|
|
//
|
|
// func TestNormalizeSeries(t *testing.T) {
|
|
// var us string
|
|
// s := []float64{2890031237, 23998994567, 389734042344, 390349424345}
|
|
// r := []float64{3, 24, 390, 391}
|
|
//
|
|
// total := 0.0
|
|
// for _, number := range s {
|
|
// total += number
|
|
// }
|
|
// avg := total / float64(len(s))
|
|
//
|
|
// fmt.Printf("AVG: %e\n", avg)
|
|
// NormalizeSeries(s, avg, "KB/s", &us)
|
|
//
|
|
// if !reflect.DeepEqual(s, r) {
|
|
// t.Errorf("Failed ConvertValue: Want 3, 24, 390, 391, Got %v", s)
|
|
// }
|
|
// if us != "TB/s" {
|
|
// t.Errorf("Failed Prefix or unit: Want TB/s, Got %s", us)
|
|
// }
|
|
// }
|