Files
Will 0c8488b0ae Move autolathe design datums to techweb datums (#19202)
* 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>
2026-03-20 19:38:00 -04:00

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")