diff options
author | daurnimator <quae@daurnimator.com> | 2018-04-20 21:16:24 +1000 |
---|---|---|
committer | daurnimator <quae@daurnimator.com> | 2018-04-20 21:16:24 +1000 |
commit | a260f381d30e036b39078fee0295e539067c10a3 (patch) | |
tree | 4f3b2ecb264ec8dd29cac74d23223d15d297eb8e /test/lauxlib.test.js | |
parent | fe9b43374c2e8dc28df0ce460aefaf50b933aaa7 (diff) | |
parent | 9f5d4d35de0b88334bba7c11a9e960a19ee0740b (diff) | |
download | fengari-a260f381d30e036b39078fee0295e539067c10a3.tar.gz fengari-a260f381d30e036b39078fee0295e539067c10a3.tar.bz2 fengari-a260f381d30e036b39078fee0295e539067c10a3.zip |
Merge branch 'test-with-jest'
Diffstat (limited to 'test/lauxlib.test.js')
-rw-r--r-- | test/lauxlib.test.js | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/test/lauxlib.test.js b/test/lauxlib.test.js new file mode 100644 index 0000000..62198ac --- /dev/null +++ b/test/lauxlib.test.js @@ -0,0 +1,22 @@ +"use strict"; + +const lua = require('../src/lua.js'); +const lauxlib = require("../src/lauxlib.js"); +const {to_luastring} = require("../src/fengaricore.js"); + + +test('luaL_ref, lua_rawgeti, luaL_unref, LUA_REGISTRYINDEX', () => { + let L = lauxlib.luaL_newstate(); + if (!L) throw Error("failed to create lua state"); + + { + lua.lua_pushstring(L, to_luastring("hello references!")); + + let r = lauxlib.luaL_ref(L, lua.LUA_REGISTRYINDEX); // pops a value, stores it and returns a reference + lua.lua_rawgeti(L, lua.LUA_REGISTRYINDEX, r); // pushes a value associated with the reference + lauxlib.luaL_unref(L, lua.LUA_REGISTRYINDEX, r); // releases the reference + } + + expect(lua.lua_tojsstring(L, -1)) + .toBe("hello references!"); +}); |