mlua-lspec
BDD test framework for Lua on mlua.
Embeds a forked copy of lust and provides Rust APIs for executing Lua tests with structured result collection. Includes Rust-backed spy/stub/mock test doubles.
Quick start
let summary = run_tests.unwrap;
assert_eq!;
assert_eq!;
Assertions
-- Equality
expect..
expect.. -- float tolerance
expect..
-- Identity
expect..
-- Truthiness / existence
expect...
expect..
expect..
-- Type checking
expect...
expect...
-- Comparison
expect... -- greater than
expect... -- greater than or equal
expect... -- less than
expect... -- less than or equal
-- Tables
expect.. -- contains value
expect.. -- has key
expect.. -- #tbl == 3
-- Strings
expect.. -- #str == 5
expect.. -- Lua pattern match
-- Errors
expect..
expect...
-- Negation (all assertions support to_not)
expect..
expect...
expect..
Test doubles
-- Spy: records calls, delegates to original
local s = test_doubles.
s
s: -- 1
s: -- {5}
s: -- true
s: -- clear call history
-- Stub: returns fixed values
local st = test_doubles.
st:
st -- 42
-- Spy on table method (with revert)
local spy = test_doubles.
obj.
spy: -- 1
spy: -- restore original
Granular control
For pre-existing Lua VMs (e.g. testing Rust APIs exposed to Lua):
use *;
let lua = new;
// Register your application globals
lua.globals.set.unwrap;
// Register lspec
register.unwrap;
register_doubles.unwrap;
// Run tests
lua.load.exec.unwrap;
let summary = collect_results.unwrap;
assert_eq!;
License
MIT OR Apache-2.0