From 768681bf3bc970f039ec9585e6e389ed2f08008b Mon Sep 17 00:00:00 2001 From: Tom Wieczorek Date: Fri, 15 Nov 2024 10:21:10 +0100 Subject: [PATCH] :seedling: More tests for encoding.TextMarshaler Test that json.Marshaler has precedence over encoding.TextMarshaler. Signed-off-by: Tom Wieczorek --- pkg/crd/testdata/cronjob_types.go | 33 +++++++++++++++++-- .../testdata.kubebuilder.io_cronjobs.yaml | 5 +++ 2 files changed, 35 insertions(+), 3 deletions(-) diff --git a/pkg/crd/testdata/cronjob_types.go b/pkg/crd/testdata/cronjob_types.go index 3429e8239..4569d2f7d 100644 --- a/pkg/crd/testdata/cronjob_types.go +++ b/pkg/crd/testdata/cronjob_types.go @@ -27,6 +27,7 @@ import ( "encoding/json" "fmt" "net/url" + "strconv" "time" batchv1beta1 "k8s.io/api/batch/v1beta1" @@ -605,9 +606,9 @@ func (u *URL3) MarshalText() (text []byte, err error) { return u.MarshalBinary() } -// URL4 is an alias of [net/url.URL]. It implements [encoding.TextMarshaler] so -// that it can be used in K8s CRDs such that the CRD resource will have the URL -// but operator code can can work with the URL struct. +// URL4 is newtype around [net/url.URL]. It implements [encoding.TextMarshaler] +// so that it can be used in K8s CRDs such that the CRD resource will have the +// URL but operator code can can work with the URL struct. type URL4 url.URL var _ encoding.TextMarshaler = (*URL4)(nil) @@ -617,6 +618,28 @@ func (u *URL4) MarshalText() (text []byte, err error) { return (*url.URL)(u).MarshalBinary() } +// +kubebuilder:validation:Type=integer +// +kubebuilder:validation:Format=int64 +// Time2 is a newtype around [metav1.Time]. +// It implements both [encoding.TextMarshaler] and [json.Marshaler]. +// The latter is authoritative for the CRD generation. +type Time2 time.Time + +var _ interface { + encoding.TextMarshaler + json.Marshaler +} = (*Time2)(nil) + +// MarshalText implements [encoding.TextMarshaler]. +func (t *Time2) MarshalText() (text []byte, err error) { + return []byte((*time.Time)(t).String()), nil +} + +// MarshalJSON implements [json.Marshaler]. +func (t *Time2) MarshalJSON() ([]byte, error) { + return strconv.AppendInt(nil, (*time.Time)(t).UnixMilli(), 10), nil +} + // Duration has a custom Marshaler but no markers. // We want the CRD generation to infer type information // from the go types and ignore the presense of the Marshaler. @@ -667,6 +690,10 @@ type CronJobStatus struct { // +optional LastScheduleTime *metav1.Time `json:"lastScheduleTime,omitempty"` + // Information when was the last time the job was successfully scheduled. + // +optional + LastScheduleTime2 Time2 `json:"lastScheduleTime2,omitempty"` + // Information about the last time the job was successfully scheduled, // with microsecond precision. // +optional diff --git a/pkg/crd/testdata/testdata.kubebuilder.io_cronjobs.yaml b/pkg/crd/testdata/testdata.kubebuilder.io_cronjobs.yaml index f7c032e05..e99637a39 100644 --- a/pkg/crd/testdata/testdata.kubebuilder.io_cronjobs.yaml +++ b/pkg/crd/testdata/testdata.kubebuilder.io_cronjobs.yaml @@ -9240,6 +9240,11 @@ spec: scheduled. format: date-time type: string + lastScheduleTime2: + description: Information when was the last time the job was successfully + scheduled. + format: int64 + type: integer type: object type: object selectableFields: