Add test that removeJob() actually removes jobs

develop
lethosor 2023-08-31 17:41:52 -04:00
parent 40bfb6b8ff
commit bb79755efd
No known key found for this signature in database
GPG Key ID: 76A269552F4F58C1
1 changed files with 19 additions and 0 deletions

@ -0,0 +1,19 @@
config.target = 'core'
config.mode = 'title' -- alters world state, not safe when a world is loaded
function test.removeJob()
-- removeJob() calls DF code, so ensure that that DF code is actually running
-- for an explanation of why this is necessary to check,
-- see https://github.com/DFHack/dfhack/pull/3713 and Job.cpp:removeJob()
expect.nil_(df.global.world.jobs.list.next, 'job list is not empty')
local job = df.job:new() -- will be deleted by removeJob() if the test passes
dfhack.job.linkIntoWorld(job)
expect.true_(df.global.world.jobs.list.next, 'job list is empty')
expect.eq(df.global.world.jobs.list.next.item, job, 'expected job not found in list')
expect.true_(dfhack.job.removeJob(job))
expect.nil_(df.global.world.jobs.list.next, 'job list is not empty after removeJob()')
end