mirror of
https://github.com/VOREStation/VOREStation.git
synced 2026-05-14 10:51:29 +01:00
0c8488b0ae
* testing makes me feel good * invalid lists * get rid of those boards * show expected mats * oop * error * wip techweb porting * more techweb entries * ported too * disable those for now * okay nevermind i guess * already exists * assemblies * moar * welding helmet * many entries * lol tg * fix test * again * fixagain * more moved * update techweb test * catch that too * screeee * more fixes * missing announcement * orphaned sleevecard * some more fixing * test * more * oops * glasses * illegal icons * non starting * it's starting * messed up * cleanup * more generic stuff * morrrreee * the plastic set * oops * correct value * barbed wires * more cleaning * many more * gone * cleanup * no longer * do not allow duped designs * it's own node * proper order no dupes * last of the broken nodes * fix bad path * cleanup * more test more limits * gone * almost done * these are gone * syringe gun * bioregenerator design * all moved * organized and webbed * more fixes * oops * cleaning up * organization * clean up * organize * organized * didn't save * wrong mat * adds many missing ammo types * svd doesn't exist * 10mm pistol added * magazines not casings * these are pistols * this is used by like, one weapon * m1 is ancient * this is hunting * extremely botched untested lathe * disk junk * rough foundations * slowly converting * slowly building this * local materials * almost * big reorganization * more cleanup * more cleaning * lathe stuff * small fixes * oops * many fixes * mat fix * more fixes * actually isolate the hacked designs * protolathe hacking * imprinter hacking * missing ammos * sheet printing for autolathe * fixs * again * fixed test * test test * fix * fix * WHY * fix it... * here we go * material print * on turf * body disk * consistant name * Many weapons to hacked lathe * missing node * wrong section * fixes * this list should be unified * ammo boxes * don't do single shells anymore * wat * specifics * snowflake * not needed * already available * pickaxe too * tweak * removed unneeded node * missing surgery items * Apply suggestion from @Cameron-The-Raven * Adds RMS * typo * illegal needs hacked * disabled material weapons * circuit testing * STRING TEST * test * fixing some things * huh? * hidden circuits * some flakey boards * grammar * fixes * more hidden * wrong board * security cams * alert consoles * spaceheater is simple enough to not have one * pcus * cargo vendors * tcomms stuff * solar tracker circuit * artifact stuff * SM stuff * illegal machines * med machines * no longer needed * more stuff * these are not standard * moreeee * doppler and more * organized * finishing * oop * use the define * inheret * dopper fixes * space heater * doing some organization * explain the var * some tweaks * wrong one * fixed test * material test too * simple roto gens * use the define * emergency power node * tgui fixes for icons * not needed * color blended material designs * icons for large research * oops * unshit that * use stack here * center math * . * . * . * . * . * unifi * fix these * NO COPYPASTA * ILLEEGGALLL * mandate descriptions * agony * actually lets do this * use macros * description * desc * desc * desc * desc * desc * desc * gps desc * telecomms component desc --------- Co-authored-by: Cameron Lennox <killer65311@gmail.com> Co-authored-by: Kashargul <144968721+Kashargul@users.noreply.github.com>
169 lines
7.0 KiB
Plaintext
169 lines
7.0 KiB
Plaintext
/datum/unit_test/techwebs_must_all_be_valid
|
|
|
|
/datum/unit_test/techwebs_must_all_be_valid/Run()
|
|
var/failed = FALSE
|
|
var/list/unique_nodes = list()
|
|
|
|
// Each node in the web
|
|
var/list/used_designs = list()
|
|
for(var/node_id in SSresearch.techweb_nodes)
|
|
var/datum/techweb_node/node = SSresearch.techweb_nodes[node_id]
|
|
if(node.id == /datum/techweb_node/error_node::id)
|
|
continue
|
|
|
|
// Nodes must always be unique
|
|
if(node.id in unique_nodes)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] used an id already in use by another node: \"[node.id]\"")
|
|
failed = TRUE
|
|
unique_nodes += node.id
|
|
|
|
// Must have a description
|
|
if(node.description == /datum/techweb_node::description)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] did not have a description set.")
|
|
failed = TRUE
|
|
|
|
// Must have an announcement channel
|
|
if(!node.starting_node && !node.announce_channels?.len)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] did not have any announce_channels set.")
|
|
failed = TRUE
|
|
if(node.starting_node && node.announce_channels?.len)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] starting node has announcement channels, it should not.")
|
|
failed = TRUE
|
|
|
|
// Must have costs set
|
|
if(!node.starting_node && !node.research_costs?.len)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] did not have any research_costs set.")
|
|
failed = TRUE
|
|
|
|
// Must have category set
|
|
if(!length(node.category))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] did not have a category set.")
|
|
failed = TRUE
|
|
|
|
// Must have valid designs
|
|
if(!length(node.design_ids))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] does not have any design_ids.")
|
|
failed = TRUE
|
|
else
|
|
for(var/design in node.design_ids)
|
|
if(design in used_designs)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] has an already in use design_id: \"[design]\"")
|
|
failed = TRUE
|
|
|
|
used_designs += design
|
|
if(!(design in SSresearch.techweb_designs))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] has a non-existant design_id: \"[design]\"")
|
|
failed = TRUE
|
|
|
|
// Must have valid prereqs
|
|
if(node.prereq_ids.len)
|
|
for(var/req in node.prereq_ids)
|
|
if(!(req in SSresearch.techweb_nodes))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] has a non-existant prereq_id: \"[req]\"")
|
|
failed = TRUE
|
|
|
|
// We can't check for for some stuff in here if we haven't already checked and made sure the nodes are valid first
|
|
if(!failed)
|
|
for(var/node_id in SSresearch.techweb_nodes)
|
|
var/datum/techweb_node/node = SSresearch.techweb_nodes[node_id]
|
|
|
|
// Check that our cost and make sure it's more expensive than our prior tier, unless they have a required experiment.
|
|
if(!node.required_experiments.len && node.prereq_ids.len)
|
|
if(!node.starting_node)
|
|
var/current_cost = node.research_costs.len ? INFINITY : 0
|
|
for(var/check_cost_type in node.research_costs)
|
|
// Get the LOWEST cost of us
|
|
if(node.research_costs[check_cost_type] < current_cost)
|
|
current_cost = node.research_costs[check_cost_type]
|
|
|
|
for(var/prereq_node_id in node.prereq_ids)
|
|
var/datum/techweb_node/prereq_node = SSresearch.techweb_nodes[prereq_node_id]
|
|
var/prereq_currentcost = prereq_node.research_costs ? INFINITY : 0
|
|
if(prereq_node.starting_node)
|
|
continue
|
|
|
|
for(var/req_cost_type in prereq_node.research_costs)
|
|
// Get the LOWEST cost of prereq
|
|
if(prereq_node.research_costs[req_cost_type] < prereq_currentcost)
|
|
prereq_currentcost = prereq_node.research_costs[req_cost_type]
|
|
|
|
if(prereq_currentcost > current_cost)
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] costs less to make then the previous node, must always be at least the same or more expensive. ours lowest is \[[current_cost]\], prereq lowest is \[[prereq_currentcost]\]. Lesser costs than the previous node is only allowed if the node has a required experiment.")
|
|
failed = TRUE
|
|
|
|
// forbid designs with RND_CATEGORY_INITIAL in non-starting nodes
|
|
for(var/design_id in node.design_ids)
|
|
var/datum/design_techweb/design = SSresearch.techweb_designs[design_id]
|
|
if((RND_CATEGORY_INITIAL in design.category))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type]'s [design_id] is flagged as RND_CATEGORY_INITIAL in a non-starting techweb node.")
|
|
failed = TRUE
|
|
else
|
|
// if we have prereqs we did something wrong
|
|
if(length(node.prereq_ids))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type] is a starting node, but has prereq_ids assigned.")
|
|
failed = TRUE
|
|
|
|
// starting nodes need to have all design inside it flagged with RND_CATEGORY_INITIAL
|
|
for(var/design_id in node.design_ids)
|
|
var/datum/design_techweb/design = SSresearch.techweb_designs[design_id]
|
|
if(!(RND_CATEGORY_INITIAL in design.category))
|
|
TEST_NOTICE(src, "TECHWEB NODE - [node.type]'s [design_id] was part of a starting node, but is not category tagged RND_CATEGORY_INITIAL.")
|
|
failed = TRUE
|
|
|
|
// Each design
|
|
var/used_design_paths = list()
|
|
for(var/design_id in SSresearch.techweb_designs)
|
|
var/datum/design_techweb/design = SSresearch.techweb_designs[design_id]
|
|
if(design.id == DESIGN_ID_IGNORE)
|
|
continue
|
|
|
|
/* Later
|
|
// Must have desc
|
|
if(!design.desc)
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] did not have a description.")
|
|
failed = TRUE
|
|
*/
|
|
|
|
// Must all be accessible by science
|
|
if(!(design.departmental_flags & DEPARTMENT_BITFLAG_SCIENCE))
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] was not flagged for science department, all designs must be accessible by science.")
|
|
failed = TRUE
|
|
|
|
// Designs SHOULD be accessible, only a warning
|
|
if(!(design.id in used_designs))
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - WARNING [design.type] is orphaned and not accessible from any techweb node. Is this intended?")
|
|
|
|
// Design must have materials
|
|
if(!length(design.materials))
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] has no materials assigned.")
|
|
failed = TRUE
|
|
else
|
|
for(var/mat in design.materials)
|
|
var/datum/material/mat_datum = get_material_by_name(mat)
|
|
if(!mat_datum)
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] had a non-existant material assigned \"[mat]\".")
|
|
failed = TRUE
|
|
else
|
|
var/amount = design.materials[mat]
|
|
if(!amount)
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] assigned material \"[mat]\" had no amount specified, or a negative amount.")
|
|
failed = TRUE
|
|
|
|
// Design must produce something
|
|
if(!design.build_path)
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] did not have a build_path.")
|
|
failed = TRUE
|
|
else if(design.build_path in subtypesof(/obj/machinery))
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] had a buildpath that directly prints a machine: \"[design.build_path]\"")
|
|
failed = TRUE
|
|
|
|
// Design must be a unique path produced
|
|
if(design.build_path in used_design_paths)
|
|
TEST_NOTICE(src, "TECHWEB DESIGN - [design.type] had a build_path that was already used by another design: \"[design.build_path]\"")
|
|
failed = TRUE
|
|
|
|
used_design_paths += design.build_path
|
|
|
|
if(failed)
|
|
TEST_FAIL("All techweb entries must be valid")
|