jottacloud: Handle empty time values

This commit is contained in:
Martin Polden 2018-08-12 13:39:56 +02:00 committed by Nick Craig-Wood
parent 040768383b
commit 6199b95b61
2 changed files with 42 additions and 19 deletions

View file

@ -12,41 +12,35 @@ const (
timeFormat = "2006-01-02-T15:04:05Z0700" timeFormat = "2006-01-02-T15:04:05Z0700"
) )
// Time represents represents date and time information for the // Time represents time values in the Jottacloud API. It uses a custom RFC3339 like format.
// Jottacloud API, by using a custom RFC3339 like format
type Time time.Time type Time time.Time
// UnmarshalXML turns XML into a Time // UnmarshalXML turns XML into a Time
func (t *Time) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error { func (t *Time) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error {
var v string var v string
err := d.DecodeElement(&v, &start) if err := d.DecodeElement(&v, &start); err != nil {
if err != nil {
return err return err
} }
var newT time.Time if v == "" {
newT, err = time.Parse(timeFormat, v) *t = Time(time.Time{})
if err == nil { return nil
*t = Time(newT) }
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 return err
} }
// MarshalXML turns a Time into XML // MarshalXML turns a Time into XML
func (t *Time) MarshalXML(e *xml.Encoder, start xml.StartElement) error { func (t *Time) MarshalXML(e *xml.Encoder, start xml.StartElement) error {
timeString := (*time.Time)(t).Format(timeFormat) return e.EncodeElement(t.String(), start)
return e.EncodeElement(timeString, start)
} }
// Return Time string in Jottacloud format // Return Time string in Jottacloud format
func (t Time) String() string { func (t Time) String() string { return time.Time(t).Format(timeFormat) }
t1 := (time.Time)(t)
s := t1.Format(timeFormat)
//fmt.Printf("FormatTime: (in %s, out: %s)\n", t1.String(), s)
return s
}
// 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 type Flag bool
// UnmarshalXMLAttr sets Flag to true if the attribute is present // 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 // Error returns a string for the error and statistifes the error interface
func (e *Error) Error() string { func (e *Error) Error() string {
out := fmt.Sprintf("Error %d", e.StatusCode) out := fmt.Sprintf("error %d", e.StatusCode)
if e.Message != "" { if e.Message != "" {
out += ": " + e.Message out += ": " + e.Message
} }

View file

@ -0,0 +1,29 @@
package api
import (
"encoding/xml"
"testing"
"time"
)
func TestMountpointEmptyModificationTime(t *testing.T) {
mountpoint := `
<mountPoint time="2018-08-12-T09:58:24Z" host="dn-157">
<name xml:space="preserve">Sync</name>
<path xml:space="preserve">/foo/Jotta</path>
<abspath xml:space="preserve">/foo/Jotta</abspath>
<size>0</size>
<modified></modified>
<device>Jotta</device>
<user>foo</user>
<metadata first="" max="" total="0" num_folders="0" num_files="0"/>
</mountPoint>
`
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")
}
}