mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 11:56:37 +00:00 
			
		
		
		
	This implements #7966 - adds the Lua API read-only access to the player's stored journal text entries (quest & topics data). See the issue ticket for some details on the proposal.
		
			
				
	
	
		
			129 lines
		
	
	
	
		
			8.2 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
	
		
			8.2 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| local core = require('openmw.core')
 | |
| local calendar = require('openmw_aux.calendar')
 | |
| local input = require('openmw.input')
 | |
| local self = require('openmw.self')
 | |
| local testing = require('testing_util')
 | |
| local util = require('openmw.util')
 | |
| local types = require('openmw.types')
 | |
| local nearby = require('openmw.nearby')
 | |
| local matchers = require('matchers')
 | |
| 
 | |
| types.Player.setControlSwitch(self, types.Player.CONTROL_SWITCH.Fighting, false)
 | |
| types.Player.setControlSwitch(self, types.Player.CONTROL_SWITCH.Jumping, false)
 | |
| types.Player.setControlSwitch(self, types.Player.CONTROL_SWITCH.Looking, false)
 | |
| types.Player.setControlSwitch(self, types.Player.CONTROL_SWITCH.Magic, false)
 | |
| types.Player.setControlSwitch(self, types.Player.CONTROL_SWITCH.VanityMode, false)
 | |
| types.Player.setControlSwitch(self, types.Player.CONTROL_SWITCH.ViewMode, false)
 | |
| 
 | |
| testing.registerLocalTest('Player should be able to walk up stairs in Ebonheart docks (#4247)',
 | |
|     function()
 | |
|         local startPos = self.position
 | |
|         local dest = util.vector3(20296, -102194, 73)
 | |
|         local endTime = core.getSimulationTime() + 3
 | |
|         while (self.position.x <= dest.x or self.position.z <= dest.z) and core.getSimulationTime() < endTime do
 | |
|             self.controls.jump = false
 | |
|             self.controls.run = true
 | |
|             self.controls.movement = 1
 | |
|             self.controls.sideMovement = 0
 | |
|             self.controls.yawChange = 0
 | |
|             coroutine.yield()
 | |
|         end
 | |
|         testing.expectGreaterThan(self.position.x, dest.x, 'Final position, X')
 | |
|         testing.expectEqualWithDelta(self.position.y, dest.y, 10, 'Final position, Y')
 | |
|         testing.expectGreaterThan(self.position.z, dest.z, 'Final position, Z')
 | |
|     end)
 | |
| 
 | |
| testing.registerLocalTest('Guard in Imperial Prison Ship should find path (#7241)',
 | |
|     function()
 | |
|         local src = util.vector3(34.297367095947265625, 806.3817138671875, 109.278961181640625)
 | |
|         local dst = util.vector3(90, -90, -88)
 | |
|         local agentBounds = types.Actor.getPathfindingAgentBounds(self)
 | |
|         local options = {
 | |
|             agentBounds = agentBounds,
 | |
|             destinationTolerance = 0,
 | |
|         }
 | |
|         local status, path = nearby.findPath(src, dst, options)
 | |
|         testing.expectEqual(status, nearby.FIND_PATH_STATUS.Success, 'Status')
 | |
|         testing.expectLessOrEqual((util.vector2(path[#path].x, path[#path].y) - util.vector2(dst.x, dst.y)):length(), 1, 'Last path point x, y')
 | |
|         testing.expectLessOrEqual(path[#path].z - dst.z, 20, 'Last path point z')
 | |
|         if agentBounds.shapeType == nearby.COLLISION_SHAPE_TYPE.Aabb then
 | |
|             testing.expectThat(path, matchers.elementsAreArray({
 | |
|                 matchers.closeToVector(util.vector3(34.29737091064453125, 806.3817138671875, 112.76610565185546875), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(15, 1102, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-112, 1110, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-118, 1393, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-67.99993896484375, 1421.2000732421875, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-33.999935150146484375, 1414.4000244140625, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-6.79993534088134765625, 1380.4000244140625, 85.094573974609375), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(79, 724, -104.83390045166015625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(84, 290.000030517578125, -104.83390045166015625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(83.552001953125, 42.26399993896484375, -104.58989715576171875), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(89, -105, -98.72841644287109375), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(90, -90, -99.7056884765625), 1e-1),
 | |
|             }))
 | |
|         elseif agentBounds.shapeType == nearby.COLLISION_SHAPE_TYPE.Cylinder then
 | |
|             testing.expectThat(path, matchers.elementsAreArray({
 | |
|                 matchers.closeToVector(util.vector3(34.29737091064453125, 806.3817138671875, 112.76610565185546875), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-13.5999355316162109375, 1060.800048828125, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-27.1999359130859375, 1081.2000732421875, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-81.59993743896484375, 1128.800048828125, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-101.99993896484375, 1156.0001220703125, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(-118, 1393, 112.2945709228515625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(7, 1470, 114.73973846435546875), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(79, 724, -104.83390045166015625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(84, 290.000030517578125, -104.83390045166015625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(95, 27, -104.83390045166015625), 1e-1),
 | |
|                 matchers.closeToVector(util.vector3(90, -90, -104.83390045166015625), 1e-1),
 | |
|             }))
 | |
|         end
 | |
|     end)
 | |
| 
 | |
| testing.registerLocalTest('Player quest status should update and its journal entries should be accessible',
 | |
|     function()
 | |
|         testing.expectEqual(#types.Player.journal(self).topics, 0, 'Fresh player has more journal topics than zero')
 | |
|         testing.expectEqual(#types.Player.journal(self).journalTextEntries, 0, 'Fresh player has more journal text entries than zero')
 | |
|         testing.expectEqual(types.Player.quests(self)["ms_fargothring"].stage, 0, "Player's not started quest has an unexpected stage")
 | |
|         types.Player.quests(self)["ms_fargothring"]:addJournalEntry(10)
 | |
|         coroutine.yield()
 | |
|         testing.expectEqual(types.Player.quests(self)["ms_fargothring"].stage, 10, "Unexpected quest stage number")
 | |
|         testing.expectEqual(types.Player.quests(self)["ms_fargothring"].finished, false, "Quest should not have been finished yet")
 | |
|         testing.expectEqual(#types.Player.journal(self).journalTextEntries, 1, 'Unexpected number of entries in the player journal')
 | |
| 
 | |
|         local expectedJournalEntry = core.dialogue.journal.records["ms_fargothring"].infos[#core.dialogue.journal.records["ms_fargothring"].infos-1]
 | |
|         testing.expectEqual(
 | |
|             types.Player.journal(self).journalTextEntries[1].id,
 | |
|             expectedJournalEntry.id, 'Quest journal entries ids differ')
 | |
|         testing.expectEqual(
 | |
|             types.Player.journal(self).journalTextEntries[1].text,
 | |
|             expectedJournalEntry.text, 'Quest journal entries texts differ')
 | |
| 
 | |
|         local dateWhenStageShouldHaveBeenUpdated = calendar.formatGameTime('*t')
 | |
|         testing.expectEqual(
 | |
|             types.Player.journal(self).journalTextEntries[1].dayOfMonth,
 | |
|             dateWhenStageShouldHaveBeenUpdated.day, 'Unexpected journal update day (of month)')
 | |
|         testing.expectEqual(
 | |
|             types.Player.journal(self).journalTextEntries[1].month,
 | |
|             dateWhenStageShouldHaveBeenUpdated.month, 'Unexpected journal update month')
 | |
| 
 | |
|         types.Player.quests(self)["ms_fargothring"]:addJournalEntry(100)
 | |
|         types.Player.quests(self)["ms_fargothring"].finished = true
 | |
|         coroutine.yield()
 | |
|         testing.expectEqual(types.Player.quests(self)["ms_fargothring"].stage, 100, "Unexpected quest stage number")
 | |
|         testing.expectEqual(types.Player.quests(self)["ms_fargothring"].finished, true, "Quest should have been finished now")
 | |
|         testing.expectEqual(#types.Player.journal(self).journalTextEntries, 2, 'Unexpected number of entries in the player journal')
 | |
|         expectedJournalEntry = core.dialogue.journal.records["ms_fargothring"].infos[#core.dialogue.journal.records["ms_fargothring"].infos]
 | |
|         testing.expectEqual(
 | |
|             types.Player.journal(self).journalTextEntries[2].id,
 | |
|             expectedJournalEntry.id, 'Quest journal entries ids differ')
 | |
|         testing.expectEqual(
 | |
|             types.Player.journal(self).journalTextEntries[2].text,
 | |
|             expectedJournalEntry.text,
 | |
|             'Quest journal entries texts differ')
 | |
|     end)
 | |
| 
 | |
| return {
 | |
|     engineHandlers = {
 | |
|         onFrame = testing.updateLocal,
 | |
|     },
 | |
|     eventHandlers = testing.localEventHandlers,
 | |
| }
 |