From 6199b95b6176a383a30a08fa2bfe41b3c66d7db0 Mon Sep 17 00:00:00 2001 From: Martin Polden Date: Sun, 12 Aug 2018 13:39:56 +0200 Subject: [PATCH] jottacloud: Handle empty time values --- backend/jottacloud/api/types.go | 32 +++++++++++----------------- backend/jottacloud/api/types_test.go | 29 +++++++++++++++++++++++++ 2 files changed, 42 insertions(+), 19 deletions(-) create mode 100644 backend/jottacloud/api/types_test.go diff --git a/backend/jottacloud/api/types.go b/backend/jottacloud/api/types.go index 567e5e1f3..2f2ae0dfb 100644 --- a/backend/jottacloud/api/types.go +++ b/backend/jottacloud/api/types.go @@ -12,41 +12,35 @@ const ( timeFormat = "2006-01-02-T15:04:05Z0700" ) -// Time represents represents date and time information for the -// Jottacloud API, by using a custom RFC3339 like format +// Time represents time values in the Jottacloud API. It uses a custom RFC3339 like format. type Time time.Time // UnmarshalXML turns XML into a Time func (t *Time) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error { var v string - err := d.DecodeElement(&v, &start) - if err != nil { + if err := d.DecodeElement(&v, &start); err != nil { return err } - var newT time.Time - newT, err = time.Parse(timeFormat, v) - if err == nil { - *t = Time(newT) + if v == "" { + *t = Time(time.Time{}) + return nil + } + newTime, err := time.Parse(timeFormat, v) + if err == nil { + *t = Time(newTime) } - //fmt.Printf("UnmarshalTime (in: %s, out: %s)\n", v, newT.String()) return err } // MarshalXML turns a Time into XML func (t *Time) MarshalXML(e *xml.Encoder, start xml.StartElement) error { - timeString := (*time.Time)(t).Format(timeFormat) - return e.EncodeElement(timeString, start) + return e.EncodeElement(t.String(), start) } // Return Time string in Jottacloud format -func (t Time) String() string { - t1 := (time.Time)(t) - s := t1.Format(timeFormat) - //fmt.Printf("FormatTime: (in %s, out: %s)\n", t1.String(), s) - return s -} +func (t Time) String() string { return time.Time(t).Format(timeFormat) } -// Flag is a Hacky type for checking if an attribute is present +// Flag is a hacky type for checking if an attribute is present type Flag bool // UnmarshalXMLAttr sets Flag to true if the attribute is present @@ -260,7 +254,7 @@ type Error struct { // Error returns a string for the error and statistifes the error interface func (e *Error) Error() string { - out := fmt.Sprintf("Error %d", e.StatusCode) + out := fmt.Sprintf("error %d", e.StatusCode) if e.Message != "" { out += ": " + e.Message } diff --git a/backend/jottacloud/api/types_test.go b/backend/jottacloud/api/types_test.go new file mode 100644 index 000000000..84515048e --- /dev/null +++ b/backend/jottacloud/api/types_test.go @@ -0,0 +1,29 @@ +package api + +import ( + "encoding/xml" + "testing" + "time" +) + +func TestMountpointEmptyModificationTime(t *testing.T) { + mountpoint := ` + + Sync + /foo/Jotta + /foo/Jotta + 0 + + Jotta + foo + + +` + var jf JottaFolder + if err := xml.Unmarshal([]byte(mountpoint), &jf); err != nil { + t.Fatal(err) + } + if !time.Time(jf.ModifiedAt).IsZero() { + t.Errorf("got non-zero time, want zero") + } +}