mirror of
https://github.com/minetest/minetest.git
synced 2024-12-23 14:42:24 +01:00
113 lines
4.3 KiB
Lua
113 lines
4.3 KiB
Lua
dofile(core.get_modpath(core.get_current_modname()) .. "/crafting_prepare.lua")
|
|
|
|
-- Test core.clear_craft function
|
|
local function test_clear_craft()
|
|
-- Clearing by output
|
|
core.register_craft({
|
|
output = "foo",
|
|
recipe = {{"bar"}}
|
|
})
|
|
core.register_craft({
|
|
output = "foo 4",
|
|
recipe = {{"foo", "bar"}}
|
|
})
|
|
assert(#core.get_all_craft_recipes("foo") == 2)
|
|
core.clear_craft({output="foo"})
|
|
assert(core.get_all_craft_recipes("foo") == nil)
|
|
-- Clearing by input
|
|
core.register_craft({
|
|
output = "foo 4",
|
|
recipe = {{"foo", "bar"}}
|
|
})
|
|
assert(#core.get_all_craft_recipes("foo") == 1)
|
|
core.clear_craft({recipe={{"foo", "bar"}}})
|
|
assert(core.get_all_craft_recipes("foo") == nil)
|
|
end
|
|
unittests.register("test_clear_craft", test_clear_craft)
|
|
|
|
-- Test core.get_craft_result function
|
|
local function test_get_craft_result()
|
|
-- normal
|
|
local input = {
|
|
method = "normal",
|
|
width = 2,
|
|
items = {"", "unittests:coal_lump", "", "unittests:stick"}
|
|
}
|
|
core.log("info", "[unittests] torch crafting input: "..dump(input))
|
|
local output, decremented_input = core.get_craft_result(input)
|
|
core.log("info", "[unittests] torch crafting output: "..dump(output))
|
|
core.log("info", "[unittests] torch crafting decremented input: "..dump(decremented_input))
|
|
assert(output.item)
|
|
core.log("info", "[unittests] torch crafting output.item:to_table(): "..dump(output.item:to_table()))
|
|
assert(output.item:get_name() == "unittests:torch")
|
|
assert(output.item:get_count() == 4)
|
|
|
|
-- fuel
|
|
input = {
|
|
method = "fuel",
|
|
width = 1,
|
|
items = {"unittests:coal_lump"}
|
|
}
|
|
core.log("info", "[unittests] coal fuel input: "..dump(input))
|
|
output, decremented_input = core.get_craft_result(input)
|
|
core.log("info", "[unittests] coal fuel output: "..dump(output))
|
|
core.log("info", "[unittests] coal fuel decremented input: "..dump(decremented_input))
|
|
assert(output.time)
|
|
assert(output.time > 0)
|
|
|
|
-- cooking
|
|
input = {
|
|
method = "cooking",
|
|
width = 1,
|
|
items = {"unittests:iron_lump"}
|
|
}
|
|
core.log("info", "[unittests] iron lump cooking input: "..dump(output))
|
|
output, decremented_input = core.get_craft_result(input)
|
|
core.log("info", "[unittests] iron lump cooking output: "..dump(output))
|
|
core.log("info", "[unittests] iron lump cooking decremented input: "..dump(decremented_input))
|
|
assert(output.time)
|
|
assert(output.time > 0)
|
|
assert(output.item)
|
|
core.log("info", "[unittests] iron lump cooking output.item:to_table(): "..dump(output.item:to_table()))
|
|
assert(output.item:get_name() == "unittests:steel_ingot")
|
|
assert(output.item:get_count() == 1)
|
|
|
|
-- tool repair (repairable)
|
|
input = {
|
|
method = "normal",
|
|
width = 2,
|
|
-- Using a wear of 60000
|
|
items = {"unittests:repairable_tool 1 60000", "unittests:repairable_tool 1 60000"}
|
|
}
|
|
core.log("info", "[unittests] repairable tool crafting input: "..dump(input))
|
|
output, decremented_input = core.get_craft_result(input)
|
|
core.log("info", "[unittests] repairable tool crafting output: "..dump(output))
|
|
core.log("info", "[unittests] repairable tool crafting decremented input: "..dump(decremented_input))
|
|
assert(output.item)
|
|
core.log("info", "[unittests] repairable tool crafting output.item:to_table(): "..dump(output.item:to_table()))
|
|
assert(output.item:get_name() == "unittests:repairable_tool")
|
|
-- Test the wear value.
|
|
-- See src/craftdef.cpp in Luanti source code for the formula. The formula to calculate
|
|
-- the value 51187 is:
|
|
-- 65536 - ((65536-60000)+(65536-60000)) + floor(additonal_wear * 65536 + 0.5) = 51187
|
|
-- where additional_wear = 0.05
|
|
assert(output.item:get_wear() == 51187)
|
|
assert(output.item:get_count() == 1)
|
|
|
|
-- failing tool repair (unrepairable)
|
|
input = {
|
|
method = "normal",
|
|
width = 2,
|
|
items = {"unittests:unrepairable_tool 1 60000", "unittests:unrepairable_tool 1 60000"}
|
|
}
|
|
core.log("info", "[unittests] unrepairable tool crafting input: "..dump(input))
|
|
output, decremented_input = core.get_craft_result(input)
|
|
core.log("info", "[unittests] unrepairable tool crafting output: "..dump(output))
|
|
core.log("info", "[unittests] unrepairable tool crafting decremented input: "..dump(decremented_input))
|
|
assert(output.item)
|
|
core.log("info", "[unittests] unrepairable tool crafting output.item:to_table(): "..dump(output.item:to_table()))
|
|
-- unrepairable tool must not yield any output
|
|
assert(output.item:is_empty())
|
|
end
|
|
unittests.register("test_get_craft_result", test_get_craft_result)
|