Files
Citadel-Station-13-RP/code/modules/unit_tests/map_tests.dm
silicons b335fa012a atmos cleanup - turf API, repaths (#3909)
* initial

* wack

* even more wack

* wack

* wack

* e

* lower

* wack

* wack

* more

* wack

* fix

* wack

* force git to recheck

* fixes

* fix

* wack

Co-authored-by: fake_vm_user <fake_vm_user>
2022-04-21 21:09:44 -07:00

103 lines
3.0 KiB
Plaintext

/datum/unit_test/apc_area_test
name = "MAP: Area Test APC / Scrubbers / Vents Z level 1"
/datum/unit_test/apc_area_test/Run()
var/list/bad_areas = list()
var/area_test_count = 0
var/list/exempt_areas = typesof(/area/space,
/area/syndicate_station,
/area/skipjack_station,
/area/solar,
/area/shuttle,
/area/holodeck,
/area/supply/station,
/area/mine,
/area/vacant/vacant_shop,
/area/turbolift,
/area/submap )
var/list/exempt_from_atmos = typesof(/area/maintenance,
/area/storage,
/area/engineering/atmos/storage,
/area/rnd/test_area,
/area/construction,
/area/server,
/area/mine,
/area/vacant/vacant_shop,
/area/rnd/research_storage, // This should probably be fixed,
/area/security/riot_control // This should probably be fixed,
)
var/list/exempt_from_apc = typesof(/area/construction,
/area/medical/genetics,
/area/mine,
/area/vacant/vacant_shop
)
// Some maps have areas specific to the map, so include those.
exempt_areas += GLOB.using_map.unit_test_exempt_areas.Copy()
exempt_from_atmos += GLOB.using_map.unit_test_exempt_from_atmos.Copy()
exempt_from_apc += GLOB.using_map.unit_test_exempt_from_apc.Copy()
var/list/zs_to_test = GLOB.using_map.unit_test_z_levels || list(1) //Either you set it, or you just get z1
for(var/area/A in GLOB.sortedAreas)
if((A.z in zs_to_test) && !(A.type in exempt_areas))
area_test_count++
var/area_good = 1
var/bad_msg = "--------------- [A.name]([A.type])"
if(isnull(A.apc) && !(A.type in exempt_from_apc))
Fail("[bad_msg] lacks an APC.")
if(!A.air_scrub_info.len && !(A.type in exempt_from_atmos))
Fail("[bad_msg] lacks an Air scrubber.")
if(!A.air_vent_info.len && !(A.type in exempt_from_atmos))
Fail("[bad_msg] lacks an Air vent.")
/datum/unit_test/wire_test
name = "MAP: Cable Test Z level 1"
/datum/unit_test/wire_test/Run()
var/wire_test_count = 0
var/bad_tests = 0
var/turf/T = null
var/obj/structure/cable/C = null
var/list/cable_turfs = list()
var/list/dirs_checked = list()
for(C in world)
T = null
T = get_turf(C)
if(T && T.z == 1)
cable_turfs |= get_turf(C)
for(T in cable_turfs)
var/bad_msg = "--------------- [T.name] \[[T.x] / [T.y] / [T.z]\]"
dirs_checked.Cut()
for(C in T)
wire_test_count++
var/combined_dir = "[C.d1]-[C.d2]"
if(combined_dir in dirs_checked)
Fail("[bad_msg] Contains multiple wires with same direction on top of each other.")
dirs_checked.Add(combined_dir)
/datum/unit_test/active_edges
name = "MAP: Active edges (all maps)"
/datum/unit_test/active_edges/Run()
var/active_edges = air_master.active_edges.len
var/list/edge_log = list()
if(active_edges)
for(var/datum/zas_edge/E in air_master.active_edges)
edge_log += "Active Edge [E] ([E.type])"
for(var/turf/T in E.connecting_turfs)
edge_log += "+--- Connecting Turf [T] @ [T.x], [T.y], [T.z]"
if(active_edges)
Fail("Maps contained [active_edges] active edges at round-start.\n" + edge_log.Join("\n"))