Beanzilla 03e3666d51
Attempting to fix tests
It is found that testing causes dirt to become a blacklisted item, which it should not be.

Next to reorder it so tests run before pre-defined settings based on gamemode is handled.
2022-05-23 15:51:42 -04:00

95 lines
4.4 KiB
Lua

-- Test file for the API
minetest.log("action", "[item_replicator] Test: ....")
-- This allows me to make a copy of the settings without getting the values hosed up (thanks to lua defaulting to reference)
item_replicator_settings.copy = function (something)
return something
end
-- Get the original settings (This appears to result in corrupt data, i.e. it doesn't actually work right, want copy gettting ref)
local old_settings = {}
old_settings.log_api = item_replicator_settings.copy(item_replicator_settings.log_api)
old_settings.log_production = item_replicator_settings.copy(item_replicator_settings.log_production)
old_settings.allow_unknown = item_replicator_settings.copy(item_replicator_settings.allow_unknown)
old_settings.unknown_item_amount = item_replicator_settings.copy(item_replicator_settings.unknown_item_amount)
old_settings.unknown_item_time = item_replicator_settings.copy(item_replicator_settings.unknown_item_time)
old_settings.blacklist_removes_allowed = item_replicator_settings.copy(item_replicator_settings.blacklist_removes_allowed)
-- Set the stuff to a good known value
item_replicator_settings.log_api = true
item_replicator_settings.log_production = true
item_replicator_settings.allow_unknown = false
item_replicator_settings.unknown_item_amount = 1
item_replicator_settings.unknown_item_time = 30
item_replicator_settings.blacklist_removes_allowed = true
-- Test adding an item (Insert and Update check
item_replicator.add("default:dirt", 2, 5)
item_replicator.add("default:dirt", 4, 10)
item_replicator.add("default:dirt", 2, 15)
item_replicator.bl_add("default:sand")
item_replicator.bl_add("default:sand") -- This should report not able to, because it already exists
item_replicator.bl_add("default:dirt") -- This should remove the above 3 adding/updating the dirt
if item_replicator.is("default:dirt") then
item_replicator_internal.throw_error("item_replicator.bl_add('default:dirt') should have removed but didn't")
end
-- Re-add the item back in.
item_replicator.add("default:dirt", 2, 15)
-- Test validity
if item_replicator.is("default:dirt_with_grass") then
item_replicator_internal.throw_error("item_replicator.is('default:dirt_with_grass') ~= false")
end
if not item_replicator.is("default:dirt") then
item_replicator_internal.throw_error("item_replicator.is('default:dirt') ~= true")
end
if not item_replicator.bl_is("default:sand") then
item_replicator_internal.throw_error("item_replicator.bl_is('default:sand') ~= true")
end
-- Test amounts
if item_replicator.get_amount("default:dirt_with_grass") ~= -1 then
item_replicator_internal.throw_error("item_replicator.get_amount('default:dirt_with_grass') ~= -1")
end
if item_replicator.get_amount("default:dirt") ~= 2 then
item_replicator_internal.throw_error("item_replicator.get_amount('default:dirt') ~= 2")
end
-- Test times
if item_replicator.get_time("default:dirt_with_grass") ~= -1 then
item_replicator_internal.throw_error("item_replicator.get_time('default:dirt_with_grass') ~= -1")
end
if item_replicator.get_time("default:dirt") ~= 15 then
item_replicator_internal.throw_error("item_replicator.get_time('default:dirt') ~= 15")
end
-- Test Cleanup (Also a test against removals)
item_replicator.remove("default:dirt")
if item_replicator.is("default:dirt") then
item_replicator_internal.throw_error("item_replicator.remove('default:dirt') did not remove!")
end
item_replicator.bl_remove("default:sand")
if item_replicator.bl_is("default:sand") then
item_replicator_internal.throw_error("item_replicator.bl_remove('default:sand' did not remove!")
end
item_replicator.bl_remove("default:dirt")
-- Restore settings
item_replicator_settings.log_api = old_settings.log_api
item_replicator_settings.log_production = old_settings.log_production
item_replicator_settings.allow_unknown = old_settings.allow_unknown
item_replicator_settings.unknown_item_amount = old_settings.unknown_item_amount
item_replicator_settings.unknown_item_time = old_settings.unknown_item_time
item_replicator_settings.blacklist_removes_allowed = old_settings.blacklist_removes_allowed
-- If the user wants to... just have them exit
if item_replicator_settings.exit_after_test then
minetest.log("action", "[item_replicator] Test: OKAY")
error("[item_replicator] Test: OKAY (Your seeing this because exit_after_test is true)")
end
-- The user chosen to keep running... so let's just let them know the tests passed
minetest.log("action", "[item_replicator] Test: OKAY")