172 lines
4.4 KiB
Go
172 lines
4.4 KiB
Go
// MIT License
|
|
|
|
// Copyright (c) 2021 Tree Xie
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
// in the Software without restriction, including without limitation the rights
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
// furnished to do so, subject to the following conditions:
|
|
|
|
// The above copyright notice and this permission notice shall be included in all
|
|
// copies or substantial portions of the Software.
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
// SOFTWARE.
|
|
|
|
package charts
|
|
|
|
import (
|
|
"strconv"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/wcharczuk/go-chart/v2"
|
|
)
|
|
|
|
func TestGetXAxisAndValues(t *testing.T) {
|
|
assert := assert.New(t)
|
|
|
|
genLabels := func(count int) []string {
|
|
arr := make([]string, count)
|
|
for i := 0; i < count; i++ {
|
|
arr[i] = strconv.Itoa(i)
|
|
}
|
|
return arr
|
|
}
|
|
genValues := func(count int, betweenTicks bool) []float64 {
|
|
if betweenTicks {
|
|
count++
|
|
}
|
|
arr := make([]float64, count)
|
|
for i := 0; i < count; i++ {
|
|
arr[i] = float64(i)
|
|
}
|
|
return arr
|
|
}
|
|
genTicks := func(count int, betweenTicks bool) []chart.Tick {
|
|
arr := make([]chart.Tick, 0)
|
|
offset := 0
|
|
if betweenTicks {
|
|
offset = 1
|
|
arr = append(arr, chart.Tick{})
|
|
}
|
|
for i := 0; i < count; i++ {
|
|
arr = append(arr, chart.Tick{
|
|
Value: float64(i + offset),
|
|
Label: strconv.Itoa(i),
|
|
})
|
|
}
|
|
return arr
|
|
}
|
|
|
|
tests := []struct {
|
|
xAxis XAxis
|
|
tickPosition chart.TickPosition
|
|
theme string
|
|
result chart.XAxis
|
|
values []float64
|
|
}{
|
|
{
|
|
xAxis: XAxis{
|
|
Data: genLabels(5),
|
|
},
|
|
values: genValues(5, false),
|
|
result: chart.XAxis{
|
|
Ticks: genTicks(5, false),
|
|
},
|
|
},
|
|
// 居中
|
|
{
|
|
xAxis: XAxis{
|
|
Data: genLabels(5),
|
|
},
|
|
tickPosition: chart.TickPositionBetweenTicks,
|
|
// 居中因此value多一个
|
|
values: genValues(5, true),
|
|
result: chart.XAxis{
|
|
Ticks: genTicks(5, true),
|
|
},
|
|
},
|
|
{
|
|
xAxis: XAxis{
|
|
Data: genLabels(20),
|
|
},
|
|
// 居中因此value多一个
|
|
values: genValues(20, false),
|
|
result: chart.XAxis{
|
|
Ticks: []chart.Tick{
|
|
{Value: 0, Label: "0"}, {Value: 2, Label: "2"}, {Value: 4, Label: "4"}, {Value: 6, Label: "6"}, {Value: 8, Label: "8"}, {Value: 10, Label: "10"}, {Value: 12, Label: "12"}, {Value: 14, Label: "14"}, {Value: 16, Label: "16"}, {Value: 18, Label: "18"}, {Value: 19, Label: "19"}},
|
|
},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
xAxis, values := GetXAxisAndValues(tt.xAxis, tt.tickPosition, tt.theme)
|
|
|
|
assert.Equal(tt.result.Ticks, xAxis.Ticks)
|
|
assert.Equal(tt.tickPosition, xAxis.TickPosition)
|
|
assert.Equal(tt.values, values)
|
|
}
|
|
}
|
|
|
|
func TestDefaultFloatFormater(t *testing.T) {
|
|
assert := assert.New(t)
|
|
|
|
assert.Equal("", defaultFloatFormater(1))
|
|
|
|
assert.Equal("0.1", defaultFloatFormater(0.1))
|
|
assert.Equal("0.12", defaultFloatFormater(0.123))
|
|
assert.Equal("10", defaultFloatFormater(10.1))
|
|
}
|
|
|
|
func TestSetYAxisOption(t *testing.T) {
|
|
assert := assert.New(t)
|
|
min := 10.0
|
|
max := 20.0
|
|
opt := &YAxisOption{
|
|
Formater: func(v interface{}) string {
|
|
return ""
|
|
},
|
|
Min: &min,
|
|
Max: &max,
|
|
}
|
|
yAxis := &chart.YAxis{
|
|
Range: &chart.ContinuousRange{},
|
|
}
|
|
setYAxisOption(yAxis, opt)
|
|
|
|
assert.NotEmpty(yAxis.ValueFormatter)
|
|
assert.Equal(max, yAxis.Range.GetMax())
|
|
assert.Equal(min, yAxis.Range.GetMin())
|
|
}
|
|
|
|
func TestGetYAxis(t *testing.T) {
|
|
assert := assert.New(t)
|
|
|
|
yAxis := GetYAxis(ThemeDark, nil)
|
|
|
|
assert.True(yAxis.GridMajorStyle.Hidden)
|
|
assert.True(yAxis.GridMajorStyle.Hidden)
|
|
assert.False(yAxis.Style.Hidden)
|
|
|
|
yAxis = GetYAxis(ThemeDark, &YAxisOption{
|
|
Disabled: true,
|
|
})
|
|
|
|
assert.True(yAxis.GridMajorStyle.Hidden)
|
|
assert.True(yAxis.GridMajorStyle.Hidden)
|
|
assert.True(yAxis.Style.Hidden)
|
|
|
|
// secondary yAxis
|
|
yAxis = GetSecondaryYAxis(ThemeDark, nil)
|
|
assert.False(yAxis.GridMajorStyle.Hidden)
|
|
assert.False(yAxis.GridMajorStyle.Hidden)
|
|
assert.True(yAxis.Style.StrokeColor.IsZero())
|
|
}
|