Skip to content

Commit

Permalink
patch: ParseLocator, sanitize locator components
Browse files Browse the repository at this point in the history
- currently, parsing the following string "event:     /xmidt-test/2/config" yields an authority with the value `     `
 - sanitize each locator component, removing trailing and leading whitespaces

#210
  • Loading branch information
denopink committed Oct 18, 2024
1 parent ab8273f commit c6482be
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 4 deletions.
8 changes: 4 additions & 4 deletions id.go
Original file line number Diff line number Diff line change
Expand Up @@ -141,13 +141,13 @@ func ParseLocator(locator string) (Locator, error) {

var l Locator

l.Scheme = strings.ToLower(match[1])
l.Authority = match[2]
l.Scheme = strings.TrimSpace(strings.ToLower(match[1]))
l.Authority = strings.TrimSpace(match[2])
if len(match) > 3 {
l.Service = strings.TrimPrefix(match[3], "/")
l.Service = strings.TrimSpace(strings.TrimPrefix(match[3], "/"))
}
if len(match) > 4 {
l.Ignored = match[4]
l.Ignored = strings.TrimSpace(match[4])
}

// If the locator is a device identifier, then we need to parse it.
Expand Down
16 changes: 16 additions & 0 deletions id_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,14 @@ func TestParseLocator(t *testing.T) {
Scheme: SchemeDNS,
Authority: "foo.bar.com",
},
}, {
description: "event scheme (with spaces)",
locator: "event: targetedEvent ",
str: "event:targetedEvent",
want: Locator{
Scheme: SchemeEvent,
Authority: "targetedEvent",
},
}, {
description: "event scheme",
locator: "event:targetedEvent",
Expand Down Expand Up @@ -251,6 +259,14 @@ func TestParseLocator(t *testing.T) {
description: "invalid self scheme",
locator: "self:anything",
expectedErr: ErrorInvalidDeviceName,
}, {
description: "invalid event scheme (no authority)",
locator: "event:/anything",
expectedErr: ErrorInvalidLocator,
}, {
description: "invalid event scheme (no authority and with spaces)",
locator: "event: /anything",
expectedErr: ErrorInvalidLocator,
},
}
for _, tc := range tests {
Expand Down

0 comments on commit c6482be

Please sign in to comment.