#!/usr/bin/env lua -- Simple JSON benchmark. -- -- Your Mileage May Vary. -- -- Mark Pulford local json_module = os.getenv("JSON_MODULE") or "cjson" require "socket" local json = require(json_module) local util = require "cjson.util" local function find_func(mod, funcnames) for _, v in ipairs(funcnames) do if mod[v] then return mod[v] end end return nil end local json_encode = find_func(json, { "encode", "Encode", "to_string", "stringify", "json" }) local json_decode = find_func(json, { "decode", "Decode", "to_value", "parse" }) function benchmark(tests, seconds, rep) local function bench(func, iter) -- collectgarbage("stop") collectgarbage("collect") local t = socket.gettime() for i = 1, iter do func(i) end t = socket.gettime() - t -- collectgarbage("restart") return (iter / t) end -- Roughly calculate the number of interations required -- to obtain a particular time period. local function calc_iter(func, seconds) local base_iter = 10 local rate = (bench(func, base_iter) + bench(func, base_iter)) / 2 return math.ceil(seconds * rate) end local test_results = {} for name, func in pairs(tests) do -- k(number), v(string) -- k(string), v(function) -- k(number), v(function) if type(func) == "string" then name = func func = _G[name] end local iter = calc_iter(func, seconds) local result = {} for i = 1, rep do result[i] = bench(func, iter) end table.sort(result) test_results[name] = result[rep] end return test_results end function bench_file(filename) local data_json = util.file_load(filename) local data_obj = json_decode(data_json) local function test_encode() json_encode(data_obj) end local function test_decode() json_decode(data_json) end local tests = {} if json_encode then tests.encode = test_encode end if json_decode then tests.decode = test_decode end return benchmark(tests, 0.1, 5) end -- Optionally load any custom configuration required for this module local success, data = pcall(util.file_load, string.format("bench-%s.lua", json_module)) if success then util.run_script(data, _G) configure(json) end for i = 1, #arg do local results = bench_file(arg[i]) for k, v in pairs(results) do print(string.format("%s\t%s\t%d", arg[i], k, v)) end end -- vi:ai et sw=4 ts=4: