Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
501c13f6
Commit
501c13f6
authored
Mar 14, 2018
by
BSBandme
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Rewrite go_benchmark
parent
6d2c6a00
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
61 additions
and
74 deletions
+61
-74
Makefile.am
benchmarks/Makefile.am
+1
-4
go_benchmark_test.go
benchmarks/go_benchmark_test.go
+60
-70
No files found.
benchmarks/Makefile.am
View file @
501c13f6
...
@@ -288,10 +288,7 @@ go-benchmark: go_protoc_middleman go_protoc_middleman2
...
@@ -288,10 +288,7 @@ go-benchmark: go_protoc_middleman go_protoc_middleman2
@
echo
"Writing shortcut script go-benchmark..."
@
echo
"Writing shortcut script go-benchmark..."
@
echo
'#! /bin/sh'
>
go-benchmark
@
echo
'#! /bin/sh'
>
go-benchmark
@
echo
'mkdir tmp_cc && mv *.cc tmp_cc'
>>
go-benchmark
@
echo
'mkdir tmp_cc && mv *.cc tmp_cc'
>>
go-benchmark
@
echo
'for file in $$@; do'
>>
go-benchmark
@
echo
'go test -bench=. -- $$@'
>>
go-benchmark
@
echo
' echo "Testing go benchmark for data file: $$file";'
>>
go-benchmark
@
echo
' go test -bench=. -- $$file;'
>>
go-benchmark
@
echo
'done'
>>
go-benchmark
@
echo
'mv tmp_cc/* . && rm -rf tmp_cc'
>>
go-benchmark
@
echo
'mv tmp_cc/* . && rm -rf tmp_cc'
>>
go-benchmark
@
chmod
+x go-benchmark
@
chmod
+x go-benchmark
...
...
benchmarks/go_benchmark_test.go
View file @
501c13f6
...
@@ -7,127 +7,117 @@ import (
...
@@ -7,127 +7,117 @@ import (
googleMessage2
"./tmp/datasets/google_message2"
googleMessage2
"./tmp/datasets/google_message2"
googleMessage3
"./tmp/datasets/google_message3"
googleMessage3
"./tmp/datasets/google_message3"
googleMessage4
"./tmp/datasets/google_message4"
googleMessage4
"./tmp/datasets/google_message4"
"errors"
"flag"
"flag"
"github.com/golang/protobuf/proto"
"github.com/golang/protobuf/proto"
"io/ioutil"
"io/ioutil"
"os"
"testing"
"testing"
)
)
// Data is returned by the Load function.
// Data is returned by the Load function.
type
Data
struct
{
type
Data
set
struct
{
// marshaled is a slice of marshaled protocol
name
string
// buffers. 1:1 with unmarshaled.
newMessage
func
()
proto
.
Message
marshaled
[][]
byte
marshaled
[][]
byte
// Unmarshaled is a slice of unmarshaled protocol
// buffers. 1:1 with marshaled.
unmarshaled
[]
proto
.
Message
unmarshaled
[]
proto
.
Message
count
int
}
}
var
data
*
Data
var
datasets
[]
Dataset
var
counter
int
type
GetDefaultInstanceFunction
func
()
proto
.
Message
var
getDefaultInstance
GetDefaultInstanceFunction
// This is used to getDefaultInstance for a message type.
// This is used to getDefaultInstance for a message type.
func
generate
GetDefaltInstanceFunction
(
dataset
benchmarkWrapper
.
BenchmarkDataset
)
error
{
func
generate
NewMessageFunction
(
dataset
benchmarkWrapper
.
BenchmarkDataset
)
func
()
proto
.
Message
{
switch
dataset
.
MessageName
{
switch
dataset
.
MessageName
{
case
"benchmarks.proto3.GoogleMessage1"
:
case
"benchmarks.proto3.GoogleMessage1"
:
getDefaultInstance
=
func
()
proto
.
Message
{
return
&
googleMessage1Proto3
.
GoogleMessage1
{}
}
return
func
()
proto
.
Message
{
return
new
(
googleMessage1Proto3
.
GoogleMessage1
)
}
return
nil
case
"benchmarks.proto2.GoogleMessage1"
:
case
"benchmarks.proto2.GoogleMessage1"
:
getDefaultInstance
=
func
()
proto
.
Message
{
return
&
googleMessage1Proto2
.
GoogleMessage1
{}
}
return
func
()
proto
.
Message
{
return
new
(
googleMessage1Proto2
.
GoogleMessage1
)
}
return
nil
case
"benchmarks.proto2.GoogleMessage2"
:
case
"benchmarks.proto2.GoogleMessage2"
:
getDefaultInstance
=
func
()
proto
.
Message
{
return
&
googleMessage2
.
GoogleMessage2
{}
}
return
func
()
proto
.
Message
{
return
new
(
googleMessage2
.
GoogleMessage2
)
}
return
nil
case
"benchmarks.google_message3.GoogleMessage3"
:
case
"benchmarks.google_message3.GoogleMessage3"
:
getDefaultInstance
=
func
()
proto
.
Message
{
return
&
googleMessage3
.
GoogleMessage3
{}
}
return
func
()
proto
.
Message
{
return
new
(
googleMessage3
.
GoogleMessage3
)
}
return
nil
case
"benchmarks.google_message4.GoogleMessage4"
:
case
"benchmarks.google_message4.GoogleMessage4"
:
getDefaultInstance
=
func
()
proto
.
Message
{
return
&
googleMessage4
.
GoogleMessage4
{}
}
return
func
()
proto
.
Message
{
return
new
(
googleMessage4
.
GoogleMessage4
)
}
return
nil
default
:
default
:
return
errors
.
New
(
"Unknown message type: "
+
dataset
.
MessageName
)
panic
(
"Unknown message type: "
+
dataset
.
MessageName
)
}
}
}
}
func
TestMain
(
m
*
testing
.
M
)
{
func
init
(
)
{
flag
.
Parse
()
flag
.
Parse
()
data
=
new
(
Data
)
for
_
,
f
:=
range
flag
.
Args
()
{
rawData
,
err
:=
ioutil
.
ReadFile
(
flag
.
Arg
(
0
))
// Load the benchmark.
b
,
err
:=
ioutil
.
ReadFile
(
f
)
if
err
!=
nil
{
if
err
!=
nil
{
panic
(
"Couldn't find file"
+
flag
.
Arg
(
0
)
)
panic
(
err
)
}
}
var
dataset
benchmarkWrapper
.
BenchmarkDataset
if
err
=
proto
.
Unmarshal
(
rawData
,
&
dataset
);
err
!=
nil
{
// Parse the benchmark.
panic
(
"The raw input data can't be parse into BenchmarkDataset message."
)
var
dm
benchmarkWrapper
.
BenchmarkDataset
if
err
:=
proto
.
Unmarshal
(
b
,
&
dm
);
err
!=
nil
{
panic
(
err
)
}
}
generateGetDefaltInstanceFunction
(
dataset
)
// Determine the concrete protobuf message type to use.
var
ds
Dataset
ds
.
newMessage
=
generateNewMessageFunction
(
dm
)
for
_
,
payload
:=
range
dataset
.
Payload
{
// Unmarshal each test message.
data
.
marshaled
=
append
(
data
.
marshaled
,
payload
)
for
_
,
payload
:=
range
dm
.
Payload
{
m
:=
getDefaultInstance
()
ds
.
marshaled
=
append
(
ds
.
marshaled
,
payload
)
proto
.
Unmarshal
(
payload
,
m
)
m
:=
ds
.
newMessage
()
data
.
unmarshaled
=
append
(
data
.
unmarshaled
,
m
)
if
err
:=
proto
.
Unmarshal
(
payload
,
m
);
err
!=
nil
{
panic
(
err
)
}
}
data
.
count
=
len
(
data
.
unmarshaled
)
ds
.
unmarshaled
=
append
(
ds
.
unmarshaled
,
m
)
}
ds
.
name
=
f
os
.
Exit
(
m
.
Run
())
datasets
=
append
(
datasets
,
ds
)
}
}
}
func
BenchmarkUnmarshal
(
b
*
testing
.
B
)
{
func
Benchmark
(
b
*
testing
.
B
)
{
b
.
ReportAllocs
()
for
_
,
ds
:=
range
datasets
{
b
.
Run
(
ds
.
name
,
func
(
b
*
testing
.
B
)
{
counter
:=
0
count
:=
len
(
ds
.
marshaled
)
b
.
Run
(
"Unmarshal"
,
func
(
b
*
testing
.
B
)
{
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
payload
:=
data
.
marshaled
[
counter
%
data
.
count
]
payload
:=
ds
.
marshaled
[
counter
%
count
]
out
:=
getDefaultInstanc
e
()
out
:=
ds
.
newMessag
e
()
if
err
:=
proto
.
Unmarshal
(
payload
,
out
);
err
!=
nil
{
if
err
:=
proto
.
Unmarshal
(
payload
,
out
);
err
!=
nil
{
b
.
Fatalf
(
"can't unmarshal message %d %v"
,
counter
%
data
.
count
,
err
)
b
.
Fatalf
(
"can't unmarshal message %d %v"
,
counter
%
count
,
err
)
}
}
counter
++
counter
++
}
}
}
})
b
.
Run
(
"Marshal"
,
func
(
b
*
testing
.
B
)
{
func
BenchmarkMarshal
(
b
*
testing
.
B
)
{
b
.
ReportAllocs
()
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
m
:=
data
.
unmarshaled
[
counter
%
data
.
count
]
m
:=
ds
.
unmarshaled
[
counter
%
count
]
if
_
,
err
:=
proto
.
Marshal
(
m
);
err
!=
nil
{
if
_
,
err
:=
proto
.
Marshal
(
m
);
err
!=
nil
{
b
.
Fatalf
(
"can't marshal message %d %+v: %v"
,
counter
%
data
.
count
,
m
,
err
)
b
.
Fatalf
(
"can't marshal message %d %+v: %v"
,
counter
%
count
,
m
,
err
)
}
}
counter
++
counter
++
}
}
}
})
b
.
Run
(
"Size"
,
func
(
b
*
testing
.
B
)
{
func
BenchmarkSize
(
b
*
testing
.
B
)
{
b
.
ReportAllocs
()
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
proto
.
Size
(
data
.
unmarshaled
[
counter
%
data
.
count
])
proto
.
Size
(
ds
.
unmarshaled
[
counter
%
count
])
counter
++
counter
++
}
}
}
})
b
.
Run
(
"Clone"
,
func
(
b
*
testing
.
B
)
{
func
BenchmarkClone
(
b
*
testing
.
B
)
{
b
.
ReportAllocs
()
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
proto
.
Clone
(
data
.
unmarshaled
[
counter
%
data
.
count
])
proto
.
Clone
(
ds
.
unmarshaled
[
counter
%
count
])
counter
++
counter
++
}
}
}
})
b
.
Run
(
"Merge"
,
func
(
b
*
testing
.
B
)
{
func
BenchmarkMerge
(
b
*
testing
.
B
)
{
b
.
ReportAllocs
()
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
out
:=
getDefaultInstanc
e
()
out
:=
ds
.
newMessag
e
()
proto
.
Merge
(
out
,
data
.
unmarshaled
[
counter
%
data
.
count
])
proto
.
Merge
(
out
,
ds
.
unmarshaled
[
counter
%
count
])
counter
++
counter
++
}
}
})
})
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment