From a4c8c7016ff601cadea111a7959142718b627b55 Mon Sep 17 00:00:00 2001 From: Rahul Gupta Date: Fri, 29 Sep 2023 02:08:01 +0530 Subject: [PATCH] Revert "perf: Zapi allocs improvements (#2380)" This reverts commit 1489cfc7da74dafd23c36030afce2846e7fa2e60. --- cmd/collectors/sensor_test.go | 2 +- pkg/api/ontapi/zapi/client.go | 22 +++++++++++----------- pkg/tree/tree.go | 12 ++++-------- pkg/tree/xml/xml.go | 18 +++++------------- 4 files changed, 21 insertions(+), 33 deletions(-) diff --git a/cmd/collectors/sensor_test.go b/cmd/collectors/sensor_test.go index 6424bcac1..6dd70c09d 100644 --- a/cmd/collectors/sensor_test.go +++ b/cmd/collectors/sensor_test.go @@ -27,7 +27,7 @@ func loadTestdata() { // setup matrix data var err error var fetch func(*matrix.Instance, *node.Node, []string) - dat, err := os.Open(testxml) + dat, err := os.ReadFile(testxml) if err != nil { abs, _ := filepath.Abs(testxml) fmt.Printf("failed to load %s\n", abs) diff --git a/pkg/api/ontapi/zapi/client.go b/pkg/api/ontapi/zapi/client.go index 3af08869a..5e6ab2166 100644 --- a/pkg/api/ontapi/zapi/client.go +++ b/pkg/api/ontapi/zapi/client.go @@ -16,7 +16,6 @@ import ( "github.com/netapp/harvest/v2/pkg/requests" "github.com/netapp/harvest/v2/pkg/tree" "github.com/netapp/harvest/v2/pkg/tree/node" - "github.com/netapp/harvest/v2/pkg/tree/xml" "io" "net/http" "strconv" @@ -497,22 +496,23 @@ func (c *Client) invoke(withTimers bool) (*node.Node, time.Duration, time.Durati return result, responseT, parseT, errs.New(errs.ErrAPIResponse, response.Status, errs.WithStatus(response.StatusCode)) } + // read response body + if body, err = io.ReadAll(response.Body); err != nil { + return result, responseT, parseT, err + } + defer c.printRequestAndResponse(zapiReq, body) + // parse xml if withTimers { start = time.Now() } - if root, body, err = xml.Load(response.Body, c.logZapi); err != nil { + if root, err = tree.LoadXML(body); err != nil { return result, responseT, parseT, err } if withTimers { parseT = time.Since(start) } - // read response body - if c.logZapi { - defer c.printRequestAndResponse(zapiReq, body) - } - // check if the request was successful if result = root.GetChildS("results"); result == nil { return result, responseT, parseT, errs.New(errs.ErrAPIResponse, "missing \"results\"") @@ -551,11 +551,11 @@ func (c *Client) TraceLogSet(collectorName string, config *node.Node) { } func (c *Client) printRequestAndResponse(req string, response []byte) { + res := "" + if response != nil { + res = string(response) + } if req != "" { - res := "" - if response != nil { - res = string(response) - } c.Logger.Info(). Str("Request", req). Str("Response", res). diff --git a/pkg/tree/tree.go b/pkg/tree/tree.go index 692a2eb91..ef6314852 100644 --- a/pkg/tree/tree.go +++ b/pkg/tree/tree.go @@ -9,7 +9,6 @@ import ( "github.com/netapp/harvest/v2/pkg/tree/node" "github.com/netapp/harvest/v2/pkg/tree/xml" y3 "gopkg.in/yaml.v3" - "io" "os" ) @@ -68,9 +67,8 @@ func consume(r *node.Node, key string, y *y3.Node, makeNewChild bool) { } } -func LoadXML(r io.Reader) (*node.Node, error) { - root, _, err := xml.Load(r, false) - return root, err +func LoadXML(data []byte) (*node.Node, error) { + return xml.Load(data) } func DumpXML(n *node.Node) ([]byte, error) { @@ -78,11 +76,9 @@ func DumpXML(n *node.Node) ([]byte, error) { } func ImportXML(filepath string) (*node.Node, error) { - file, err := os.Open(filepath) + data, err := os.ReadFile(filepath) if err != nil { return nil, err } - //goland:noinspection GoUnhandledErrorResult - defer file.Close() - return LoadXML(file) + return LoadXML(data) } diff --git a/pkg/tree/xml/xml.go b/pkg/tree/xml/xml.go index 0941bc67e..a213cd758 100644 --- a/pkg/tree/xml/xml.go +++ b/pkg/tree/xml/xml.go @@ -8,24 +8,16 @@ import ( "bytes" "encoding/xml" "github.com/netapp/harvest/v2/pkg/tree/node" - "io" ) -func Load(data io.Reader, log bool) (*node.Node, []byte, error) { - var buf bytes.Buffer - reader := data - - if log { - reader = io.TeeReader(data, &buf) - } - +func Load(data []byte) (*node.Node, error) { root := new(node.Node) - dec := xml.NewDecoder(reader) + buf := bytes.NewBuffer(data) + dec := xml.NewDecoder(buf) if err := dec.Decode(&root); err != nil { - return nil, nil, err + return nil, err } - - return root, buf.Bytes(), nil + return root, nil } func Dump(n *node.Node) ([]byte, error) {