From 75a319a5e7d251bc18994fad56749017f8fac993 Mon Sep 17 00:00:00 2001 From: Alexey Melnichuk Date: Fri, 3 Apr 2015 16:50:42 +0400 Subject: Add. Test for multiple prelude. --- test/test_threads_ex_opt_2.lua | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 test/test_threads_ex_opt_2.lua (limited to 'test/test_threads_ex_opt_2.lua') diff --git a/test/test_threads_ex_opt_2.lua b/test/test_threads_ex_opt_2.lua new file mode 100644 index 0000000..b01eda5 --- /dev/null +++ b/test/test_threads_ex_opt_2.lua @@ -0,0 +1,38 @@ +local thread_code = function(...) + local function assert_equal(name, a, b, ...) + if a == b then return b, ... end + print(name .. " Fail! Expected `" .. tostring(a) .. "` got `" .. tostring(b) .. "`") + os.exit(1) + end + + local a,b,c,d = ... + assert_equal("1:", 1, a ) + assert_equal("2:", 2, b ) + assert_equal("3:", 3, c ) + assert_equal("4:", 4, d ) + assert_equal("#:", 4, select("#", ...)) +end + +local llthreads = require"llthreads.ex" + +local prelude1 = function(...) return 1, ... end + +local prelude2 = function(...) return 2, ... end + +local prelude = string.format([[ + local loadstring = loadstring or load + local prelude1 = loadstring(%q) + local prelude2 = loadstring(%q) + return prelude1(prelude2(...)) +]], string.dump(prelude1), string.dump(prelude2)) + +-- pass `prelude` function that change thread arguments +local thread = llthreads.new({thread_code, prelude = prelude}, 3, 4) + +local a = assert(thread:start()) + +assert(thread:join()) + +assert(a == thread) + +print("done!") -- cgit v1.2.3-55-g6feb