123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- -- Test minetest.clear_craft function
- local function test_clear_craft()
- minetest.log("info", "[unittests] Testing minetest.clear_craft")
- -- Clearing by output
- minetest.register_craft({
- output = "foo",
- recipe = {{"bar"}}
- })
- minetest.register_craft({
- output = "foo 4",
- recipe = {{"foo", "bar"}}
- })
- assert(#minetest.get_all_craft_recipes("foo") == 2)
- minetest.clear_craft({output="foo"})
- assert(minetest.get_all_craft_recipes("foo") == nil)
- -- Clearing by input
- minetest.register_craft({
- output = "foo 4",
- recipe = {{"foo", "bar"}}
- })
- assert(#minetest.get_all_craft_recipes("foo") == 1)
- minetest.clear_craft({recipe={{"foo", "bar"}}})
- assert(minetest.get_all_craft_recipes("foo") == nil)
- end
- -- Test minetest.get_craft_result function
- local function test_get_craft_result()
- minetest.log("info", "[unittests] Testing minetest.get_craft_result")
- -- normal
- local input = {
- method = "normal",
- width = 2,
- items = {"", "unittests:coal_lump", "", "unittests:stick"}
- }
- minetest.log("info", "[unittests] torch crafting input: "..dump(input))
- local output, decremented_input = minetest.get_craft_result(input)
- minetest.log("info", "[unittests] torch crafting output: "..dump(output))
- minetest.log("info", "[unittests] torch crafting decremented input: "..dump(decremented_input))
- assert(output.item)
- minetest.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"}
- }
- minetest.log("info", "[unittests] coal fuel input: "..dump(input))
- output, decremented_input = minetest.get_craft_result(input)
- minetest.log("info", "[unittests] coal fuel output: "..dump(output))
- minetest.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"}
- }
- minetest.log("info", "[unittests] iron lump cooking input: "..dump(output))
- output, decremented_input = minetest.get_craft_result(input)
- minetest.log("info", "[unittests] iron lump cooking output: "..dump(output))
- minetest.log("info", "[unittests] iron lump cooking decremented input: "..dump(decremented_input))
- assert(output.time)
- assert(output.time > 0)
- assert(output.item)
- minetest.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"}
- }
- minetest.log("info", "[unittests] repairable tool crafting input: "..dump(input))
- output, decremented_input = minetest.get_craft_result(input)
- minetest.log("info", "[unittests] repairable tool crafting output: "..dump(output))
- minetest.log("info", "[unittests] repairable tool crafting decremented input: "..dump(decremented_input))
- assert(output.item)
- minetest.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 Minetest 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"}
- }
- minetest.log("info", "[unittests] unrepairable tool crafting input: "..dump(input))
- output, decremented_input = minetest.get_craft_result(input)
- minetest.log("info", "[unittests] unrepairable tool crafting output: "..dump(output))
- minetest.log("info", "[unittests] unrepairable tool crafting decremented input: "..dump(decremented_input))
- assert(output.item)
- minetest.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:get_name() == "")
- end
- function unittests.test_crafting()
- test_clear_craft()
- test_get_craft_result()
- minetest.log("action", "[unittests] Crafting tests passed!")
- return true
- end
|