mirror of
https://github.com/octoleo/syncthing.git
synced 2024-12-22 10:58:57 +00:00
lib/events: Fix unmarshaling of EventType
skip-check: authors GitHub-Pull-Request: https://github.com/syncthing/syncthing/pull/4540
This commit is contained in:
parent
67c39b2512
commit
b2af8f135b
@ -8,6 +8,7 @@
|
||||
package events
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"runtime"
|
||||
"time"
|
||||
@ -118,6 +119,18 @@ func (t EventType) MarshalText() ([]byte, error) {
|
||||
return []byte(t.String()), nil
|
||||
}
|
||||
|
||||
func (t *EventType) UnmarshalJSON(b []byte) error {
|
||||
var s string
|
||||
|
||||
if err := json.Unmarshal(b, &s); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
*t = UnmarshalEventType(s)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func UnmarshalEventType(s string) EventType {
|
||||
switch s {
|
||||
case "Starting":
|
||||
|
@ -7,6 +7,7 @@
|
||||
package events
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"testing"
|
||||
"time"
|
||||
@ -321,3 +322,20 @@ func TestSinceUsesSubscriptionId(t *testing.T) {
|
||||
t.Fatal("Incorrect number of events:", len(events))
|
||||
}
|
||||
}
|
||||
|
||||
func TestUnmarshalEvent(t *testing.T) {
|
||||
var event Event
|
||||
|
||||
s := `
|
||||
{
|
||||
"id": 1,
|
||||
"globalID": 1,
|
||||
"time": "2006-01-02T15:04:05.999999999Z",
|
||||
"type": "Starting",
|
||||
"data": {}
|
||||
}`
|
||||
|
||||
if err := json.Unmarshal([]byte(s), &event); err != nil {
|
||||
t.Fatal("Failed to unmarshal event:", err)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user