/datum/unit_test/designs /datum/unit_test/designs/Run() //Can't use allocate because of bug with certain datums var/datum/design/default_design = new /datum/design() var/datum/design/surgery/default_design_surgery = new /datum/design/surgery() for(var/path in subtypesof(/datum/design)) if (ispath(path, /datum/design/surgery)) //We are checking surgery design separatly later since they work differently continue var/datum/design/current_design = new path //Create an instance of each design if (current_design.id == DESIGN_ID_IGNORE) //Don't check designs with ignore ID continue if (isnull(current_design.name) || current_design.name == default_design.name) //Designs with ID must have non default/null Name TEST_FAIL("Design [current_design.type] has default or null name var but has an ID") if ((!isnull(current_design.materials) && LAZYLEN(current_design.materials)) || (!isnull(current_design.reagents_list) && LAZYLEN(current_design.reagents_list))) //Design requires materials if ((isnull(current_design.build_path) || current_design.build_path == default_design.build_path) && (isnull(current_design.make_reagent) || current_design.make_reagent == default_design.make_reagent)) //Check if design gives any output TEST_FAIL("Design [current_design.type] requires materials but does not have either build_path or make_reagent set") else if (!isnull(current_design.build_path) || !isnull(current_design.build_path)) // //Design requires no materials but creates stuff TEST_FAIL("Design [current_design.type] requires NO materials but has build_path or make_reagent set") if (length(current_design.reagents_list) && !(current_design.build_type & LIMBGROWER)) TEST_FAIL("Design [current_design.type] requires reagents but isn't a limb grower design. Reagent costs are only supported by limb grower designs") for(var/path in subtypesof(/datum/design/surgery)) var/datum/design/surgery/current_design = new path //Create an instance of each design if (isnull(current_design.id) || current_design.id == default_design_surgery.id) //Check if ID was not set TEST_FAIL("Surgery Design [current_design.type] has no ID set") if (isnull(current_design.id) || current_design.name == default_design_surgery.name) //Check if name was not set TEST_FAIL("Surgery Design [current_design.type] has default or null name var") if (isnull(current_design.desc) || current_design.desc == default_design_surgery.desc) //Check if desc was not set TEST_FAIL("Surgery Design [current_design.type] has default or null desc var") if (isnull(current_design.surgery) || current_design.surgery == default_design_surgery.surgery) //Check if surgery was not set TEST_FAIL("Surgery Design [current_design.type] has default or null surgery var") /datum/unit_test/design_source /datum/unit_test/design_source/Run() var/list/all_designs = list() var/list/exceptions = list( /datum/design/surgery/healing, // Ignored due to the above test // BUBBER EDIT ADDITION BEGIN - Exclude tg designs that we've removed from the techweb /datum/design/mag_autorifle, /datum/design/mag_autorifle/ap_mag, /datum/design/mag_autorifle/ic_mag, // BUBBER EDIT ADDITION END - Exclude tg designs that we've removed from the techweb ) for (var/datum/design/design as anything in subtypesof(/datum/design)) var/design_id = design::id if (design_id == DESIGN_ID_IGNORE || (design in exceptions)) continue if (design_id in all_designs) TEST_FAIL("Design [design] shares an ID \"[design_id]\" with another design") continue all_designs[design_id] = design for (var/datum/techweb_node/node as anything in subtypesof(/datum/techweb_node)) node = new node() for (var/design_id in node.design_ids) if (!all_designs[design_id]) TEST_FAIL("Techweb node [node.display_name] ([node.id]) has a design_id \"[design_id]\" which doesn't correspond to any existing design!") continue all_designs -= design_id qdel(node) // Designs can also be disk-exclusive for (var/obj/item/disk/design_disk/design_disk as anything in subtypesof(/obj/item/disk/design_disk)) design_disk = new design_disk() for (var/datum/design/design as anything in design_disk.blueprints) all_designs -= design.id qdel(design_disk) for (var/obj/item/disk/surgery/design_disk as anything in subtypesof(/obj/item/disk/surgery)) design_disk = new design_disk() for (var/surgery_type as anything in design_disk.surgeries) for (var/design_id in all_designs) var/datum/design/surgery/design = all_designs[design_id] if (ispath(design, /datum/design/surgery) && design::surgery == surgery_type) all_designs -= design::id qdel(design_disk) // Or machine-exclusive for (var/datum/techweb/autounlocking/techweb as anything in subtypesof(/datum/techweb/autounlocking)) techweb = new techweb() for (var/design_id in techweb.researched_designs + techweb.hacked_designs) var/datum/design/design = SSresearch.techweb_design_by_id(design_id) // If we have a design thats supposed to be printable from a protolathe and an autolathe, but only autolathes can print it // then we still should error because then we either have a missing design_id or redundant build flags if (!(design.build_type & (~techweb.allowed_buildtypes))) all_designs -= design_id qdel(techweb) for (var/missing_id in all_designs) TEST_FAIL("Design [all_designs[missing_id]] has an ID \"[missing_id]\" which is not in any of the techweb nodes or tech disks, or it is possibly misconfigured!")