Fix expanding item name with unicode params, fixes #1269
This commit is contained in:
@@ -14,8 +14,7 @@ func (item *Item) ExpandItemName() string {
|
||||
return name
|
||||
}
|
||||
|
||||
keyRunes := []rune(item.Key)
|
||||
keyParamsStr := string(keyRunes[strings.Index(key, "[")+1 : strings.LastIndex(key, "]")])
|
||||
keyParamsStr := key[strings.Index(key, "[")+1 : strings.LastIndex(key, "]")]
|
||||
keyParams := splitKeyParams(keyParamsStr)
|
||||
|
||||
for i := len(keyParams); i >= 1; i-- {
|
||||
|
||||
57
pkg/zabbix/utils_test.go
Normal file
57
pkg/zabbix/utils_test.go
Normal file
@@ -0,0 +1,57 @@
|
||||
package zabbix
|
||||
|
||||
import (
|
||||
"github.com/stretchr/testify/assert"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestExpandItemName(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
itemName string
|
||||
key string
|
||||
expected string
|
||||
}{
|
||||
{
|
||||
name: "UNQUOTED_PARAMS",
|
||||
itemName: "CPU $2 time",
|
||||
key: "system.cpu.util[,user,avg1]",
|
||||
expected: "CPU user time",
|
||||
},
|
||||
{
|
||||
name: "QUOTED_PARAMS_WITH_COMMAS",
|
||||
itemName: "CPU $1 $2 $3",
|
||||
key: "system.cpu.util[\"type=user,value=avg\",time,\"user\"]",
|
||||
expected: "CPU type=user,value=avg time user",
|
||||
},
|
||||
{
|
||||
name: "MULTIPLE_ARRAY_PARAMS",
|
||||
itemName: "CPU $2 - $3 time",
|
||||
key: "system.cpu.util[,[user,system],avg1]",
|
||||
expected: "CPU user,system - avg1 time",
|
||||
},
|
||||
{
|
||||
name: "MULTIPLE_ARRAY_PARAMS",
|
||||
itemName: "CPU - $2 - $3 - $4",
|
||||
key: "system.cpu.util[,[],[\"user,system\",iowait],avg1]",
|
||||
expected: "CPU - - \"user,system\",iowait - avg1",
|
||||
},
|
||||
{
|
||||
name: "UNICODE_PARAMS",
|
||||
itemName: "CPU $1 $2 $3",
|
||||
key: "system.cpu.util[\"type=\b5Ὂg̀9! ℃ᾭG,value=avg\",time,\"user\"]",
|
||||
expected: "CPU type=\b5Ὂg̀9! ℃ᾭG,value=avg time user",
|
||||
},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
item := &Item{
|
||||
Name: tt.itemName,
|
||||
Key: tt.key,
|
||||
}
|
||||
expandedName := item.ExpandItemName()
|
||||
assert.Equal(t, tt.expected, expandedName)
|
||||
})
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user