diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-16 19:23:18 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-16 19:23:18 +0000 |
commit | 43a123c1ae6613b3efeed291fa552ecd909d3acf (patch) | |
tree | fd92518b7024bc74031f78a1cf9e454b65e73665 /test/bench/go1/json_test.go | |
parent | Initial commit. (diff) | |
download | golang-1.20-43a123c1ae6613b3efeed291fa552ecd909d3acf.tar.xz golang-1.20-43a123c1ae6613b3efeed291fa552ecd909d3acf.zip |
Adding upstream version 1.20.14.upstream/1.20.14upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | test/bench/go1/json_test.go | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/test/bench/go1/json_test.go b/test/bench/go1/json_test.go new file mode 100644 index 0000000..963127b --- /dev/null +++ b/test/bench/go1/json_test.go @@ -0,0 +1,86 @@ +// Copyright 2011 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// This benchmark tests JSON encoding and decoding performance. + +package go1 + +import ( + "bytes" + "compress/bzip2" + "encoding/base64" + "encoding/json" + "io" + "testing" +) + +func makeJsonBytes() []byte { + var r io.Reader + r = bytes.NewReader(bytes.Replace(jsonbz2_base64, []byte{'\n'}, nil, -1)) + r = base64.NewDecoder(base64.StdEncoding, r) + r = bzip2.NewReader(r) + b, err := io.ReadAll(r) + if err != nil { + panic(err) + } + return b +} + +func makeJsonData(jsonbytes []byte) *JSONResponse { + var v JSONResponse + if err := json.Unmarshal(jsonbytes, &v); err != nil { + panic(err) + } + return &v +} + +type JSONResponse struct { + Tree *JSONNode `json:"tree"` + Username string `json:"username"` +} + +type JSONNode struct { + Name string `json:"name"` + Kids []*JSONNode `json:"kids"` + CLWeight float64 `json:"cl_weight"` + Touches int `json:"touches"` + MinT int64 `json:"min_t"` + MaxT int64 `json:"max_t"` + MeanT int64 `json:"mean_t"` +} + +func jsondec(bytes []byte) { + var r JSONResponse + if err := json.Unmarshal(bytes, &r); err != nil { + panic(err) + } + _ = r +} + +func jsonenc(data *JSONResponse) { + buf, err := json.Marshal(data) + if err != nil { + panic(err) + } + _ = buf +} + +func BenchmarkJSONEncode(b *testing.B) { + jsonbytes := makeJsonBytes() + jsondata := makeJsonData(jsonbytes) + b.ResetTimer() + b.SetBytes(int64(len(jsonbytes))) + for i := 0; i < b.N; i++ { + jsonenc(jsondata) + } +} + +func BenchmarkJSONDecode(b *testing.B) { + jsonbytes := makeJsonBytes() + b.ResetTimer() + b.SetBytes(int64(len(jsonbytes))) + for i := 0; i < b.N; i++ { + jsondec(jsonbytes) + } +} |