diff options
| author | Mark Pulford <mark@kyne.com.au> | 2011-05-16 19:21:06 +0930 |
|---|---|---|
| committer | Mark Pulford <mark@kyne.com.au> | 2011-05-16 19:21:06 +0930 |
| commit | a966d2fd2aaff7651d7928fb8381a17bf1f5f517 (patch) | |
| tree | f40aab098067d55f0a21cb1f2b2fa3271f218250 | |
| parent | c88eb62e287fa99f78c942ba551f35b13916acdc (diff) | |
| download | lua-cjson-a966d2fd2aaff7651d7928fb8381a17bf1f5f517.tar.gz lua-cjson-a966d2fd2aaff7651d7928fb8381a17bf1f5f517.tar.bz2 lua-cjson-a966d2fd2aaff7651d7928fb8381a17bf1f5f517.zip | |
Move all benchmark code into bench.lua
Move benchmark() into bench.lua since it not used elsewhere.
Replace posix.gettimeofday() with socket.gettime() to improve portability.
| -rwxr-xr-x | tests/bench.lua | 34 | ||||
| -rw-r--r-- | tests/common.lua | 39 |
2 files changed, 34 insertions, 39 deletions
diff --git a/tests/bench.lua b/tests/bench.lua index 847365b..c1808cf 100755 --- a/tests/bench.lua +++ b/tests/bench.lua | |||
| @@ -7,8 +7,40 @@ | |||
| 7 | -- Mark Pulford <mark@kyne.com.au> | 7 | -- Mark Pulford <mark@kyne.com.au> |
| 8 | 8 | ||
| 9 | require "common" | 9 | require "common" |
| 10 | require "socket" | ||
| 10 | local json = require "cjson" | 11 | local json = require "cjson" |
| 11 | 12 | ||
| 13 | function benchmark(tests, iter, rep) | ||
| 14 | local function bench(func, iter) | ||
| 15 | collectgarbage("collect") | ||
| 16 | local t = socket.gettime() | ||
| 17 | for i = 1, iter do | ||
| 18 | func(i) | ||
| 19 | end | ||
| 20 | t = socket.gettime() - t | ||
| 21 | return (iter / t) | ||
| 22 | end | ||
| 23 | |||
| 24 | local test_results = {} | ||
| 25 | for name, func in pairs(tests) do | ||
| 26 | -- k(number), v(string) | ||
| 27 | -- k(string), v(function) | ||
| 28 | -- k(number), v(function) | ||
| 29 | if type(func) == "string" then | ||
| 30 | name = func | ||
| 31 | func = _G[name] | ||
| 32 | end | ||
| 33 | local result = {} | ||
| 34 | for i = 1, rep do | ||
| 35 | result[i] = bench(func, iter) | ||
| 36 | end | ||
| 37 | table.sort(result) | ||
| 38 | test_results[name] = result[rep] | ||
| 39 | end | ||
| 40 | |||
| 41 | return test_results | ||
| 42 | end | ||
| 43 | |||
| 12 | function bench_file(filename) | 44 | function bench_file(filename) |
| 13 | local data_json = file_load(filename) | 45 | local data_json = file_load(filename) |
| 14 | local data_obj = json.decode(data_json) | 46 | local data_obj = json.decode(data_json) |
| @@ -28,6 +60,8 @@ function bench_file(filename) | |||
| 28 | return benchmark(tests, 5000, 5) | 60 | return benchmark(tests, 5000, 5) |
| 29 | end | 61 | end |
| 30 | 62 | ||
| 63 | cjson.encode_keep_buffer(true) | ||
| 64 | |||
| 31 | for i = 1, #arg do | 65 | for i = 1, #arg do |
| 32 | local results = bench_file(arg[i]) | 66 | local results = bench_file(arg[i]) |
| 33 | for k, v in pairs(results) do | 67 | for k, v in pairs(results) do |
diff --git a/tests/common.lua b/tests/common.lua index 47e3f56..e08b6c2 100644 --- a/tests/common.lua +++ b/tests/common.lua | |||
| @@ -1,5 +1,4 @@ | |||
| 1 | require "cjson" | 1 | require "cjson" |
| 2 | require "posix" | ||
| 3 | 2 | ||
| 4 | -- Misc routines to assist with CJSON testing | 3 | -- Misc routines to assist with CJSON testing |
| 5 | -- | 4 | -- |
| @@ -120,44 +119,6 @@ function file_save(filename, data) | |||
| 120 | file:close() | 119 | file:close() |
| 121 | end | 120 | end |
| 122 | 121 | ||
| 123 | function gettimeofday() | ||
| 124 | local tv_sec, tv_usec = posix.gettimeofday() | ||
| 125 | |||
| 126 | return tv_sec + tv_usec / 1000000 | ||
| 127 | end | ||
| 128 | |||
| 129 | function benchmark(tests, iter, rep) | ||
| 130 | local function bench(func, iter) | ||
| 131 | collectgarbage("stop") | ||
| 132 | local t = gettimeofday() | ||
| 133 | for i = 1, iter do | ||
| 134 | func(i) | ||
| 135 | end | ||
| 136 | t = gettimeofday() - t | ||
| 137 | collectgarbage("restart") | ||
| 138 | return (iter / t) | ||
| 139 | end | ||
| 140 | |||
| 141 | local test_results = {} | ||
| 142 | for name, func in pairs(tests) do | ||
| 143 | -- k(number), v(string) | ||
| 144 | -- k(string), v(function) | ||
| 145 | -- k(number), v(function) | ||
| 146 | if type(func) == "string" then | ||
| 147 | name = func | ||
| 148 | func = _G[name] | ||
| 149 | end | ||
| 150 | local result = {} | ||
| 151 | for i = 1, rep do | ||
| 152 | result[i] = bench(func, iter) | ||
| 153 | end | ||
| 154 | table.sort(result) | ||
| 155 | test_results[name] = result[rep] | ||
| 156 | end | ||
| 157 | |||
| 158 | return test_results | ||
| 159 | end | ||
| 160 | |||
| 161 | function compare_values(val1, val2) | 122 | function compare_values(val1, val2) |
| 162 | local type1 = type(val1) | 123 | local type1 = type(val1) |
| 163 | local type2 = type(val2) | 124 | local type2 = type(val2) |
