initial commits
parent
fa844fd34c
commit
0c8c3456a5
|
@ -0,0 +1,30 @@
|
||||||
|
package tmp
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
|
||||||
|
"sourcecode.social/reiver/go-erorr"
|
||||||
|
)
|
||||||
|
|
||||||
|
var _ json.Marshaler = Nothing[bool]()
|
||||||
|
var _ json.Marshaler = Nothing[string]()
|
||||||
|
|
||||||
|
// MarshalJSON makes it so json.Marshaler is implemented.
|
||||||
|
func (receiver Temporal[T]) MarshalJSON() ([]byte, error) {
|
||||||
|
switch interface{}(receiver.value).(type) {
|
||||||
|
case bool, string,json.Marshaler:
|
||||||
|
// these are OK.
|
||||||
|
default:
|
||||||
|
return nil, erorr.Errorf("tmp: cannot marshal something of type %T into JSON because parameterized type is ‘%T’ rather than ‘bool’, ‘string’, or ‘json.Marshaler’", receiver, receiver.value)
|
||||||
|
}
|
||||||
|
|
||||||
|
if receiver.isnothing() {
|
||||||
|
return nil, erorr.Errorf("tmp: cannot marshal opt.Nothing[%T]() into JSON", receiver.value)
|
||||||
|
}
|
||||||
|
|
||||||
|
if receiver.IsDefunct() {
|
||||||
|
return nil, erorr.Errorf("tmp: cannot marshal defunct %#v into JSON", receiver.value)
|
||||||
|
}
|
||||||
|
|
||||||
|
return json.Marshal(receiver.value)
|
||||||
|
}
|
|
@ -0,0 +1,96 @@
|
||||||
|
package tmp_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"sourcecode.social/reiver/go-tmp"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestTemporal_MarshalJSON_bool(t *testing.T) {
|
||||||
|
|
||||||
|
tests := []struct{
|
||||||
|
Value tmp.Temporal[bool]
|
||||||
|
Expected string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
Value: tmp.Permanent(false),
|
||||||
|
Expected: "false",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Value: tmp.Permanent(true),
|
||||||
|
Expected: "true",
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
Value: tmp.Temporary(false, 9_223_372_036_854_775_807), // supposed to be a time far in the future
|
||||||
|
Expected: "false",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Value: tmp.Temporary(true, 9_223_372_036_854_775_806), // supposed to be a time far in the future
|
||||||
|
Expected: "true",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for testNumber, test := range tests {
|
||||||
|
|
||||||
|
actualBytes, err := test.Value.MarshalJSON()
|
||||||
|
if nil != err {
|
||||||
|
t.Errorf("For test #%d, did not expect an error but actually got one." , testNumber)
|
||||||
|
t.Logf("ERROR: (%T) %s", err, err)
|
||||||
|
t.Logf("VALUE: %#v", test.Value)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
actual := string(actualBytes)
|
||||||
|
expected := test.Expected
|
||||||
|
|
||||||
|
if expected != actual {
|
||||||
|
t.Errorf("For test #%d, the actual value for the JSON marshaling is not what was expected.", testNumber)
|
||||||
|
t.Logf("EXPECTED: %q", expected)
|
||||||
|
t.Logf("ACTUAL: %q", actual)
|
||||||
|
t.Logf("VALUE: %#v", test.Value)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestTemporal_MarshalJSON_bool_fail(t *testing.T) {
|
||||||
|
|
||||||
|
tests := []struct{
|
||||||
|
Value tmp.Temporal[bool]
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
Value: tmp.Nothing[bool](),
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
{
|
||||||
|
Value: tmp.Temporary(false, 1234), // supposed to be a time that is already expired
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Value: tmp.Temporary(true, 5678), // supposed to be a time that is already expired
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
for testNumber, test := range tests {
|
||||||
|
|
||||||
|
actualBytes, err := test.Value.MarshalJSON()
|
||||||
|
if nil == err {
|
||||||
|
t.Errorf("For test #%d, expected an error but did not actually get one.", testNumber)
|
||||||
|
t.Logf("ACTUAL: %q", actualBytes)
|
||||||
|
t.Logf("ERROR: (%T) %s", err, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if nil != actualBytes {
|
||||||
|
t.Errorf("For test #%d, expected not bytes but actually get some.", testNumber)
|
||||||
|
t.Logf("ACTUAL: %q", actualBytes)
|
||||||
|
t.Logf("ERROR: (%T) %s", err, err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue