summaryrefslogtreecommitdiff
path: root/test/tests.js
diff options
context:
space:
mode:
authordaurnimator <quae@daurnimator.com>2018-04-20 21:16:24 +1000
committerdaurnimator <quae@daurnimator.com>2018-04-20 21:16:24 +1000
commita260f381d30e036b39078fee0295e539067c10a3 (patch)
tree4f3b2ecb264ec8dd29cac74d23223d15d297eb8e /test/tests.js
parentfe9b43374c2e8dc28df0ce460aefaf50b933aaa7 (diff)
parent9f5d4d35de0b88334bba7c11a9e960a19ee0740b (diff)
downloadfengari-a260f381d30e036b39078fee0295e539067c10a3.tar.gz
fengari-a260f381d30e036b39078fee0295e539067c10a3.tar.bz2
fengari-a260f381d30e036b39078fee0295e539067c10a3.zip
Merge branch 'test-with-jest'
Diffstat (limited to 'test/tests.js')
-rw-r--r--test/tests.js23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/tests.js b/test/tests.js
new file mode 100644
index 0000000..631594b
--- /dev/null
+++ b/test/tests.js
@@ -0,0 +1,23 @@
+"use strict";
+
+const lua = require("../src/lua.js");
+const lauxlib = require("../src/lauxlib.js");
+const {to_luastring} = require("../src/fengaricore.js");
+
+const toByteCode = function(luaCode) {
+ let L = lauxlib.luaL_newstate();
+ if (!L) throw Error("failed to create lua state");
+
+ if (lauxlib.luaL_loadstring(L, to_luastring(luaCode)) !== lua.LUA_OK)
+ throw Error(lua.lua_tojsstring(L, -1));
+
+ let b = [];
+ if (lua.lua_dump(L, function(L, b, size, B) {
+ B.push(...b.slice(0, size));
+ return 0;
+ }, b, false) !== 0)
+ throw Error("unable to dump given function");
+ return Uint8Array.from(b);
+};
+
+module.exports.toByteCode = toByteCode;