Create v2/soap/types, refactored from v1.
This commit is contained in:
parent
29c1eac5a2
commit
688314d831
File diff suppressed because it is too large
Load Diff
@ -3,21 +3,10 @@ package types
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
var dummyLoc = time.FixedZone("DummyTZ", 6*3600)
|
|
||||||
|
|
||||||
func newFixed14_4Parts(intPart int64, fracPart int16) *Fixed14_4 {
|
|
||||||
v, err := Fixed14_4FromParts(intPart, fracPart)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
return &v
|
|
||||||
}
|
|
||||||
|
|
||||||
type isEqual func(got, want SOAPValue) bool
|
type isEqual func(got, want SOAPValue) bool
|
||||||
|
|
||||||
type typeTestCase struct {
|
type typeTestCase struct {
|
||||||
@ -40,6 +29,12 @@ type unmarshalCase struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func Test(t *testing.T) {
|
func Test(t *testing.T) {
|
||||||
|
// Fake out the local time for the implementation.
|
||||||
|
localLoc = time.FixedZone("Fake/Local", 6*3600)
|
||||||
|
defer func() {
|
||||||
|
localLoc = time.Local
|
||||||
|
}()
|
||||||
|
|
||||||
badNumbers := []string{"", " ", "abc"}
|
badNumbers := []string{"", " ", "abc"}
|
||||||
|
|
||||||
typeTestCases := []typeTestCase{
|
typeTestCases := []typeTestCase{
|
||||||
@ -140,37 +135,20 @@ func Test(t *testing.T) {
|
|||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
makeValue: func() SOAPValue { return &Fixed14_4{} },
|
makeValue: func() SOAPValue { return new(FloatFixed14_4) },
|
||||||
isEqual: func(got, want SOAPValue) bool {
|
isEqual: func(got, want SOAPValue) bool { return *got.(*FloatFixed14_4) == *want.(*FloatFixed14_4) },
|
||||||
return got.(*Fixed14_4).Fractional == want.(*Fixed14_4).Fractional
|
|
||||||
},
|
|
||||||
marshalTests: []marshalCase{
|
marshalTests: []marshalCase{
|
||||||
{newFixed14_4Parts(0, 0), "0.0000"},
|
{NewFloatFixed14_4(0), "0.0000"},
|
||||||
{newFixed14_4Parts(1, 2), "1.0002"},
|
{NewFloatFixed14_4(1), "1.0000"},
|
||||||
{newFixed14_4Parts(1, 20), "1.0020"},
|
{NewFloatFixed14_4(1.2346), "1.2346"},
|
||||||
{newFixed14_4Parts(1, 200), "1.0200"},
|
{NewFloatFixed14_4(-1), "-1.0000"},
|
||||||
{newFixed14_4Parts(1, 2000), "1.2000"},
|
{NewFloatFixed14_4(-1.2346), "-1.2346"},
|
||||||
{newFixed14_4Parts(-1, -2), "-1.0002"},
|
{NewFloatFixed14_4(1e13), "10000000000000.0000"},
|
||||||
{newFixed14_4Parts(1234, 5678), "1234.5678"},
|
{NewFloatFixed14_4(-1e13), "-10000000000000.0000"},
|
||||||
{newFixed14_4Parts(-1234, -5678), "-1234.5678"},
|
|
||||||
{newFixed14_4Parts(9999_99999_99999, 9999), "99999999999999.9999"},
|
|
||||||
{newFixed14_4Parts(-9999_99999_99999, -9999), "-99999999999999.9999"},
|
|
||||||
},
|
},
|
||||||
unmarshalErrs: append([]string{
|
marshalErrs: []SOAPValue{
|
||||||
"", ".", "0.00000000abc", "0.-5",
|
NewFloatFixed14_4(1e14),
|
||||||
}, badNumbers...),
|
NewFloatFixed14_4(-1e14),
|
||||||
unmarshalTests: []unmarshalCase{
|
|
||||||
{"010", newFixed14_4Parts(10, 0)},
|
|
||||||
{"0", newFixed14_4Parts(0, 0)},
|
|
||||||
{"0.", newFixed14_4Parts(0, 0)},
|
|
||||||
{"0.000005", newFixed14_4Parts(0, 0)},
|
|
||||||
{"1.2", newFixed14_4Parts(1, 2000)},
|
|
||||||
{"1.20", newFixed14_4Parts(1, 2000)},
|
|
||||||
{"1.200", newFixed14_4Parts(1, 2000)},
|
|
||||||
{"1.02", newFixed14_4Parts(1, 200)},
|
|
||||||
{"1.020", newFixed14_4Parts(1, 200)},
|
|
||||||
{"1.002", newFixed14_4Parts(1, 20)},
|
|
||||||
{"1.00200005", newFixed14_4Parts(1, 20)},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -186,10 +164,24 @@ func Test(t *testing.T) {
|
|||||||
unmarshalErrs: []string{"aa", ""},
|
unmarshalErrs: []string{"aa", ""},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
makeValue: func() SOAPValue { return new(DateLocal) },
|
||||||
|
isEqual: func(got, want SOAPValue) bool {
|
||||||
|
return got.(*DateLocal).ToTime().Equal(want.(*DateLocal).ToTime())
|
||||||
|
},
|
||||||
|
marshalTests: []marshalCase{
|
||||||
|
{NewDateLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc)), "2013-10-08"},
|
||||||
|
},
|
||||||
|
unmarshalTests: []unmarshalCase{
|
||||||
|
{"20131008", NewDateLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc))},
|
||||||
|
},
|
||||||
|
unmarshalErrs: []string{"", "-1"},
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
makeValue: func() SOAPValue { return new(TimeOfDay) },
|
makeValue: func() SOAPValue { return new(TimeOfDay) },
|
||||||
isEqual: func(got, want SOAPValue) bool {
|
isEqual: func(got, want SOAPValue) bool {
|
||||||
return got.(*TimeOfDay).equal(*want.(*TimeOfDay))
|
return got.(*TimeOfDay).Equal(want.(*TimeOfDay))
|
||||||
},
|
},
|
||||||
marshalTests: []marshalCase{
|
marshalTests: []marshalCase{
|
||||||
{&TimeOfDay{}, "00:00:00"},
|
{&TimeOfDay{}, "00:00:00"},
|
||||||
@ -212,29 +204,36 @@ func Test(t *testing.T) {
|
|||||||
"00:00:60",
|
"00:00:60",
|
||||||
// Unexpected timezone component:
|
// Unexpected timezone component:
|
||||||
"01:02:03Z",
|
"01:02:03Z",
|
||||||
|
"01:02:03+01",
|
||||||
"01:02:03+01:23",
|
"01:02:03+01:23",
|
||||||
"01:02:03+01:23",
|
"01:02:03+0123",
|
||||||
"01:02:03-01:23",
|
"01:02:03-01",
|
||||||
"01:02:03-01:23",
|
"01:02:03-01:23",
|
||||||
|
"01:02:03-0123",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
makeValue: func() SOAPValue { return new(TimeOfDayTZ) },
|
makeValue: func() SOAPValue { return new(TimeOfDayTZ) },
|
||||||
isEqual: func(got, want SOAPValue) bool {
|
isEqual: func(got, want SOAPValue) bool {
|
||||||
return got.(*TimeOfDayTZ).equal(*want.(*TimeOfDayTZ))
|
return got.(*TimeOfDayTZ).Equal(want.(*TimeOfDayTZ))
|
||||||
},
|
},
|
||||||
marshalTests: []marshalCase{
|
marshalTests: []marshalCase{
|
||||||
{&TimeOfDayTZ{}, "00:00:00"},
|
{&TimeOfDayTZ{}, "00:00:00"},
|
||||||
// ISO8601 special case
|
// ISO8601 special case
|
||||||
{&TimeOfDayTZ{TimeOfDay{24, 0, 0}, TZD{}}, "24:00:00"},
|
{&TimeOfDayTZ{TimeOfDay{24, 0, 0}, false, 0}, "24:00:00"},
|
||||||
{&TimeOfDayTZ{TimeOfDay{1, 2, 3}, TZDOffset(0)}, "01:02:03Z"},
|
{&TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, 0}, "01:02:03Z"},
|
||||||
{&TimeOfDayTZ{TimeOfDay{1, 2, 3}, TZDOffset(3600 + 23*60)}, "01:02:03+01:23"},
|
{&TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, 3600 + 23*60}, "01:02:03+01:23"},
|
||||||
{&TimeOfDayTZ{TimeOfDay{1, 2, 3}, TZDOffset(-(3600 + 23*60))}, "01:02:03-01:23"},
|
{&TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, -(3600 + 23*60)}, "01:02:03-01:23"},
|
||||||
},
|
},
|
||||||
unmarshalTests: []unmarshalCase{
|
unmarshalTests: []unmarshalCase{
|
||||||
{"010203+01:23", &TimeOfDayTZ{TimeOfDay{1, 2, 3}, TZDOffset(3600 + 23*60)}},
|
{"000000", &TimeOfDayTZ{}},
|
||||||
{"010203-01:23", &TimeOfDayTZ{TimeOfDay{1, 2, 3}, TZDOffset(-(3600 + 23*60))}},
|
{"01Z", &TimeOfDayTZ{TimeOfDay{1, 0, 0}, true, 0}},
|
||||||
|
{"01+01", &TimeOfDayTZ{TimeOfDay{1, 0, 0}, true, 3600}},
|
||||||
|
{"01:02:03+01", &TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, 3600}},
|
||||||
|
{"01:02:03+0123", &TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, 3600 + 23*60}},
|
||||||
|
{"01:02:03-01", &TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, -3600}},
|
||||||
|
{"01:02:03-0123", &TimeOfDayTZ{TimeOfDay{1, 2, 3}, true, -(3600 + 23*60)}},
|
||||||
},
|
},
|
||||||
unmarshalErrs: []string{
|
unmarshalErrs: []string{
|
||||||
// Misformatted values:
|
// Misformatted values:
|
||||||
@ -249,54 +248,63 @@ func Test(t *testing.T) {
|
|||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
makeValue: func() SOAPValue { return new(Date) },
|
makeValue: func() SOAPValue { return new(DateLocal) },
|
||||||
isEqual: func(got, want SOAPValue) bool {
|
isEqual: func(got, want SOAPValue) bool {
|
||||||
a, b := got.(*Date), want.(*Date)
|
return got.(*DateLocal).ToTime().Equal(want.(*DateLocal).ToTime())
|
||||||
return a.Year == b.Year && a.Month == b.Month && a.Day == b.Day
|
|
||||||
},
|
},
|
||||||
marshalTests: []marshalCase{
|
marshalTests: []marshalCase{
|
||||||
{&Date{2013, 10, 8}, "2013-10-08"},
|
{NewDateLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc)), "2013-10-08"},
|
||||||
},
|
},
|
||||||
unmarshalTests: []unmarshalCase{
|
unmarshalTests: []unmarshalCase{
|
||||||
{"20131008", &Date{2013, 10, 8}},
|
{"20131008", NewDateLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc))},
|
||||||
|
},
|
||||||
|
unmarshalErrs: []string{
|
||||||
|
// Unexpected time component.
|
||||||
|
"2013-10-08T10:30:50",
|
||||||
|
// Unexpected timezone component.
|
||||||
|
"2013-10-08+01",
|
||||||
},
|
},
|
||||||
unmarshalErrs: []string{"", "-1"},
|
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
makeValue: func() SOAPValue { return new(DateTime) },
|
makeValue: func() SOAPValue { return new(DateTimeLocal) },
|
||||||
isEqual: func(got, want SOAPValue) bool {
|
isEqual: func(got, want SOAPValue) bool {
|
||||||
return got.(*DateTime).equal(*want.(*DateTime))
|
return got.(*DateTimeLocal).ToTime().Equal(want.(*DateTimeLocal).ToTime())
|
||||||
},
|
},
|
||||||
marshalTests: []marshalCase{
|
marshalTests: []marshalCase{
|
||||||
{DateTimeFromTime(time.Date(2013, 10, 8, 0, 0, 0, 0, dummyLoc)).ptr(), "2013-10-08T00:00:00"},
|
{NewDateTimeLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc)), "2013-10-08T00:00:00"},
|
||||||
{DateTimeFromTime(time.Date(2013, 10, 8, 10, 30, 50, 0, dummyLoc)).ptr(), "2013-10-08T10:30:50"},
|
{NewDateTimeLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, localLoc)), "2013-10-08T10:30:50"},
|
||||||
},
|
},
|
||||||
unmarshalTests: []unmarshalCase{
|
unmarshalTests: []unmarshalCase{
|
||||||
{"20131008", DateTimeFromTime(time.Date(2013, 10, 8, 0, 0, 0, 0, dummyLoc)).ptr()},
|
{"20131008", NewDateTimeLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc))},
|
||||||
},
|
},
|
||||||
unmarshalErrs: []string{
|
unmarshalErrs: []string{
|
||||||
// Unexpected timezone component.
|
// Unexpected timezone component.
|
||||||
"2013-10-08T10:30:50+01:00",
|
"2013-10-08T10:30:50+01",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
makeValue: func() SOAPValue { return new(DateTimeTZ) },
|
makeValue: func() SOAPValue { return new(DateTimeTZLocal) },
|
||||||
isEqual: func(got, want SOAPValue) bool {
|
isEqual: func(got, want SOAPValue) bool {
|
||||||
return got.(*DateTimeTZ).equal(*want.(*DateTimeTZ))
|
return got.(*DateTimeTZLocal).ToTime().Equal(want.(*DateTimeTZLocal).ToTime())
|
||||||
},
|
},
|
||||||
marshalTests: []marshalCase{
|
marshalTests: []marshalCase{
|
||||||
{DateTimeTZFromTime(time.Date(2013, 10, 8, 0, 0, 0, 0, dummyLoc)).ptr(), "2013-10-08T00:00:00+06:00"},
|
{NewDateTimeTZLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc)), "2013-10-08T00:00:00+06:00"},
|
||||||
{DateTimeTZFromTime(time.Date(2013, 10, 8, 10, 30, 50, 0, dummyLoc)).ptr(), "2013-10-08T10:30:50+06:00"},
|
{NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, localLoc)), "2013-10-08T10:30:50+06:00"},
|
||||||
{DateTimeTZFromTime(time.Date(2013, 10, 8, 0, 0, 0, 0, time.UTC)).ptr(), "2013-10-08T00:00:00Z"},
|
{NewDateTimeTZLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, time.UTC)), "2013-10-08T00:00:00+00:00"},
|
||||||
{DateTimeTZFromTime(time.Date(2013, 10, 8, 10, 30, 50, 0, time.UTC)).ptr(), "2013-10-08T10:30:50Z"},
|
{NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.UTC)), "2013-10-08T10:30:50+00:00"},
|
||||||
{DateTimeTZFromTime(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("+01:23", 3600+23*60))).ptr(), "2013-10-08T10:30:50+01:23"},
|
{NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("+01:23", 3600+23*60))), "2013-10-08T10:30:50+01:23"},
|
||||||
{DateTimeTZFromTime(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("-01:23", -(3600+23*60)))).ptr(), "2013-10-08T10:30:50-01:23"},
|
{NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("-01:23", -(3600+23*60)))), "2013-10-08T10:30:50-01:23"},
|
||||||
},
|
},
|
||||||
unmarshalTests: []unmarshalCase{
|
unmarshalTests: []unmarshalCase{
|
||||||
{"2013-10-08T10:30:50", &DateTimeTZ{Date{2013, 10, 8}, TimeOfDay{10, 30, 50}, TZD{}}},
|
{"20131008", NewDateTimeTZLocal(time.Date(2013, 10, 8, 0, 0, 0, 0, localLoc))},
|
||||||
{"2013-10-08T10:30:50+00:00", DateTimeTZFromTime(time.Date(2013, 10, 8, 10, 30, 50, 0, time.UTC)).ptr()},
|
{"2013-10-08T10:30:50", NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, localLoc))},
|
||||||
|
{"2013-10-08T10:30:50Z", NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.UTC))},
|
||||||
|
{"2013-10-08T10:30:50+01", NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("+01:00", 3600)))},
|
||||||
|
{"2013-10-08T10:30:50+0123", NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("+01:23", 3600+23*60)))},
|
||||||
|
{"2013-10-08T10:30:50-01", NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("-01:00", -3600)))},
|
||||||
|
{"2013-10-08T10:30:50-0123", NewDateTimeTZLocal(time.Date(2013, 10, 8, 10, 30, 50, 0, time.FixedZone("-01:23", -(3600+23*60))))},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -372,11 +380,10 @@ func Test(t *testing.T) {
|
|||||||
for i, mt := range tt.marshalTests {
|
for i, mt := range tt.marshalTests {
|
||||||
mt := mt
|
mt := mt
|
||||||
t.Run(fmt.Sprintf("marshalTest#%d_%v", i, mt.input), func(t *testing.T) {
|
t.Run(fmt.Sprintf("marshalTest#%d_%v", i, mt.input), func(t *testing.T) {
|
||||||
gotBytes, err := mt.input.MarshalText()
|
got, err := mt.input.Marshal()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Errorf("got unexpected error: %v", err)
|
t.Errorf("got unexpected error: %v", err)
|
||||||
}
|
}
|
||||||
got := string(gotBytes)
|
|
||||||
if got != mt.want {
|
if got != mt.want {
|
||||||
t.Errorf("got %q, want: %q", got, mt.want)
|
t.Errorf("got %q, want: %q", got, mt.want)
|
||||||
}
|
}
|
||||||
@ -385,7 +392,7 @@ func Test(t *testing.T) {
|
|||||||
for i, input := range tt.marshalErrs {
|
for i, input := range tt.marshalErrs {
|
||||||
input := input
|
input := input
|
||||||
t.Run(fmt.Sprintf("marshalErr#%d_%v", i, input), func(t *testing.T) {
|
t.Run(fmt.Sprintf("marshalErr#%d_%v", i, input), func(t *testing.T) {
|
||||||
got, err := input.MarshalText()
|
got, err := input.Marshal()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
t.Errorf("got %q, want error", got)
|
t.Errorf("got %q, want error", got)
|
||||||
}
|
}
|
||||||
@ -395,8 +402,8 @@ func Test(t *testing.T) {
|
|||||||
ut := ut
|
ut := ut
|
||||||
t.Run(fmt.Sprintf("unmarshalTest#%d_%q", i, ut.input), func(t *testing.T) {
|
t.Run(fmt.Sprintf("unmarshalTest#%d_%q", i, ut.input), func(t *testing.T) {
|
||||||
got := tt.makeValue()
|
got := tt.makeValue()
|
||||||
if err := got.UnmarshalText([]byte(ut.input)); err != nil {
|
if err := got.Unmarshal(ut.input); err != nil {
|
||||||
t.Errorf("got unexpected error: %v", err)
|
t.Errorf("got error, want success")
|
||||||
}
|
}
|
||||||
if !tt.isEqual(got, ut.want) {
|
if !tt.isEqual(got, ut.want) {
|
||||||
t.Errorf("got %v, want %v", got, ut.want)
|
t.Errorf("got %v, want %v", got, ut.want)
|
||||||
@ -407,7 +414,7 @@ func Test(t *testing.T) {
|
|||||||
input := input
|
input := input
|
||||||
t.Run(fmt.Sprintf("unmarshalErrs#%d_%q", i, input), func(t *testing.T) {
|
t.Run(fmt.Sprintf("unmarshalErrs#%d_%q", i, input), func(t *testing.T) {
|
||||||
got := tt.makeValue()
|
got := tt.makeValue()
|
||||||
if err := got.UnmarshalText([]byte(input)); err == nil {
|
if err := got.Unmarshal(input); err == nil {
|
||||||
t.Errorf("got %v, want error", got)
|
t.Errorf("got %v, want error", got)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -415,123 +422,3 @@ func Test(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFixed14_4(t *testing.T) {
|
|
||||||
t.Run("Parts", func(t *testing.T) {
|
|
||||||
tests := []struct {
|
|
||||||
intPart int64
|
|
||||||
fracPart int16
|
|
||||||
fractional int64
|
|
||||||
}{
|
|
||||||
{0, 0, 0},
|
|
||||||
{1, 2, 1_0002},
|
|
||||||
{-1, -2, -1_0002},
|
|
||||||
{1234, 5678, 1234_5678},
|
|
||||||
{-1234, -5678, -1234_5678},
|
|
||||||
{9999_99999_99999, 9999, 9999_99999_99999_9999},
|
|
||||||
{-9999_99999_99999, -9999, -9999_99999_99999_9999},
|
|
||||||
}
|
|
||||||
for _, test := range tests {
|
|
||||||
test := test
|
|
||||||
t.Run(fmt.Sprintf("FromParts(%d,%d)", test.intPart, test.fracPart), func(t *testing.T) {
|
|
||||||
got, err := Fixed14_4FromParts(test.intPart, test.fracPart)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("got error %v, want success", err)
|
|
||||||
}
|
|
||||||
if got.Fractional != test.fractional {
|
|
||||||
t.Errorf("got %d, want %d", got.Fractional, test.fractional)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
t.Run(fmt.Sprintf("%d.Parts()", test.fractional), func(t *testing.T) {
|
|
||||||
v, err := Fixed14_4FromFractional(test.fractional)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("got error %v, want success", err)
|
|
||||||
}
|
|
||||||
gotIntPart, gotFracPart := v.Parts()
|
|
||||||
if gotIntPart != test.intPart {
|
|
||||||
t.Errorf("got %d, want %d", gotIntPart, test.intPart)
|
|
||||||
}
|
|
||||||
if gotFracPart != test.fracPart {
|
|
||||||
t.Errorf("got %d, want %d", gotFracPart, test.fracPart)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
t.Run("Float", func(t *testing.T) {
|
|
||||||
tests := []struct {
|
|
||||||
flt float64
|
|
||||||
fix *Fixed14_4
|
|
||||||
}{
|
|
||||||
{0, newFixed14_4Parts(0, 0)},
|
|
||||||
{1234.5678, newFixed14_4Parts(1234, 5678)},
|
|
||||||
{-1234.5678, newFixed14_4Parts(-1234, -5678)},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, test := range tests {
|
|
||||||
t.Run(fmt.Sprintf("To/FromFloat(%v)", test.fix), func(t *testing.T) {
|
|
||||||
gotFix, err := Fixed14_4FromFloat(test.flt)
|
|
||||||
if err != nil {
|
|
||||||
t.Errorf("got error %v, want success", err)
|
|
||||||
}
|
|
||||||
if gotFix.Fractional != test.fix.Fractional {
|
|
||||||
t.Errorf("got %v, want %v", gotFix, test.fix)
|
|
||||||
}
|
|
||||||
|
|
||||||
gotFlt := test.fix.Float64()
|
|
||||||
if math.Abs(gotFlt-test.flt) > 1e-6 {
|
|
||||||
t.Errorf("got %f, want %f", gotFlt, test.flt)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
errTests := []float64{
|
|
||||||
1e50,
|
|
||||||
-1e50,
|
|
||||||
1e14,
|
|
||||||
-1e14,
|
|
||||||
math.NaN(),
|
|
||||||
math.Inf(1),
|
|
||||||
math.Inf(-1),
|
|
||||||
}
|
|
||||||
for _, test := range errTests {
|
|
||||||
t.Run(fmt.Sprintf("ErrorFromFloat(%f)", test), func(t *testing.T) {
|
|
||||||
got, err := Fixed14_4FromFloat(test)
|
|
||||||
if err == nil {
|
|
||||||
t.Errorf("got success and %v, want error", got)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// methods only used in testing:
|
|
||||||
|
|
||||||
func (v TimeOfDay) equal(o TimeOfDay) bool {
|
|
||||||
return v.Hour == o.Hour && v.Minute == o.Minute && v.Second == o.Second
|
|
||||||
}
|
|
||||||
|
|
||||||
func (v TimeOfDayTZ) equal(o TimeOfDayTZ) bool {
|
|
||||||
return v.TimeOfDay.equal(o.TimeOfDay) && v.TZ.equal(o.TZ)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d Date) equal(o Date) bool {
|
|
||||||
return d.Year == o.Year && d.Month == o.Month && d.Day == o.Day
|
|
||||||
}
|
|
||||||
|
|
||||||
func (dtz DateTime) ptr() *DateTime { return &dtz }
|
|
||||||
|
|
||||||
func (dt DateTime) equal(o DateTime) bool {
|
|
||||||
return dt.Date.equal(o.Date) && dt.TimeOfDay.equal(o.TimeOfDay)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (dtz DateTimeTZ) ptr() *DateTimeTZ { return &dtz }
|
|
||||||
|
|
||||||
func (dtz DateTimeTZ) equal(o DateTimeTZ) bool {
|
|
||||||
return dtz.Date.equal(o.Date) &&
|
|
||||||
dtz.TimeOfDay.equal(o.TimeOfDay) &&
|
|
||||||
dtz.TZ.equal(o.TZ)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (tzd TZD) equal(o TZD) bool {
|
|
||||||
return tzd.Offset == o.Offset && tzd.HasTZ == o.HasTZ
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user