From f355b8ae82f88478b3b7d3bc0c7e6bab715a56f1 Mon Sep 17 00:00:00 2001 From: swkeep <49286776+swkeep@users.noreply.github.com> Date: Tue, 13 Feb 2024 12:02:14 +0330 Subject: [PATCH] chore: add new tests --- interactionMenu/lua/examples/onPosition.lua | 44 ++-- interactionMenu/lua/examples/stressTest.lua | 267 ++++++++++++++++++++ 2 files changed, 288 insertions(+), 23 deletions(-) create mode 100644 interactionMenu/lua/examples/stressTest.lua diff --git a/interactionMenu/lua/examples/onPosition.lua b/interactionMenu/lua/examples/onPosition.lua index 21514e1..8949dfc 100644 --- a/interactionMenu/lua/examples/onPosition.lua +++ b/interactionMenu/lua/examples/onPosition.lua @@ -134,42 +134,36 @@ CreateThread(function() end end - exports['interactionMenu']:Create { + local toggle = false + CreateThread(function() + while true do + toggle = not toggle + + Wait(2000) + end + end) + + local id = exports['interactionMenu']:Create { type = 'position', - position = vector3(-1978.47, 3194.68, 32.81), - rotation = vec3(0, 0, 0), + position = vec3(controlPoint.x, controlPoint.y, controlPoint.z), maxDistance = 2.0, options = { { video = { - url = 'http://127.0.0.1:8080/1.mp4', + url = 'http://127.0.0.1:8080/AMV The Garden of Words Stay.mp4', loop = true, autoplay = true, - volume = 0.0 + volume = 0.3 } }, { label = 'Spawn Vehicles', icon = 'fas fa-car', - action = { - type = 'sync', + canInteract = { func = function() - Wait(500) - SpawnVehiclesAtAllPoints() + return toggle end - } - }, - } - } - - local id = exports['interactionMenu']:Create { - type = 'position', - position = vec3(controlPoint.x, controlPoint.y, controlPoint.z), - maxDistance = 2.0, - options = { - { - label = 'Spawn Vehicles', - icon = 'fas fa-car', + }, action = { type = 'sync', func = function() @@ -214,11 +208,15 @@ CreateThread(function() } } - SetTimeout(6000, function() + SetTimeout(2000, function() exports['interactionMenu']:set { menuId = id, type = 'position', value = vector4(-1981.69, 3188.51, 32.81, 111.91) } end) + + -- SetTimeout(6000, function() + -- exports['interactionMenu']:remove(id) + -- end) end) diff --git a/interactionMenu/lua/examples/stressTest.lua b/interactionMenu/lua/examples/stressTest.lua new file mode 100644 index 0000000..49c1f6f --- /dev/null +++ b/interactionMenu/lua/examples/stressTest.lua @@ -0,0 +1,267 @@ +if not DEVMODE then return end +if true then return end +-- local function test() +-- local centerPoint = vector3(-2002.83, 3222.66, 32.81) +-- local positions = {} +-- local ids = {} +-- local numPoints = 20 +-- local radius = 5.0 +-- local direction = false + +-- for i = 1, numPoints do +-- local angle = (2 * math.pi / numPoints) * i +-- local x = centerPoint.x + radius * math.cos(angle) +-- local y = centerPoint.y + radius * math.sin(angle) +-- local heading = math.deg(math.atan(centerPoint.y - y, centerPoint.x - x)) +-- if direction then +-- heading = heading - 90 +-- else +-- heading = heading + 90 +-- end +-- if heading < 0 then +-- heading = heading + 360 +-- end +-- local spawnPoint = vector4(x, y, centerPoint.z, heading) +-- table.insert(positions, spawnPoint) +-- end + +-- for i = 1, numPoints, 1 do +-- local point = positions[i] +-- ids[#ids + 1] = exports['interactionMenu']:Create { +-- type = 'position', +-- position = vec3(point.x, point.y, point.z), +-- maxDistance = 2.0, +-- options = { +-- { +-- label = 'Menu|' .. i, +-- icon = 'fas fa-car', +-- action = { +-- type = 'sync', +-- func = function() +-- end +-- } +-- }, +-- } +-- } +-- end + +-- Wait(50) + +-- for index, value in ipairs(ids) do +-- exports['interactionMenu']:remove(value) +-- end +-- end + +-- local function test_zone() +-- local centerPoint = vector3(-2002.83, 3222.66, 32.81) +-- local positions = {} +-- local ids = {} +-- local numPoints = 100 +-- local radius = 5.0 +-- local direction = false + +-- for i = 1, numPoints do +-- local angle = (2 * math.pi / numPoints) * i +-- local x = centerPoint.x + radius * math.cos(angle) +-- local y = centerPoint.y + radius * math.sin(angle) +-- local heading = math.deg(math.atan(centerPoint.y - y, centerPoint.x - x)) +-- if direction then +-- heading = heading - 90 +-- else +-- heading = heading + 90 +-- end +-- if heading < 0 then +-- heading = heading + 360 +-- end +-- local spawnPoint = vector4(x, y, centerPoint.z, heading) +-- table.insert(positions, spawnPoint) +-- end + +-- for i = 1, numPoints, 1 do +-- local point = positions[i] +-- ids[#ids + 1] = exports['interactionMenu']:Create { +-- position = point, +-- zone = { +-- type = 'boxZone', -- entityZone/circleZone/polyZone/comboZone +-- name = "onZoneTest" .. i, +-- position = point, +-- heading = point.w, +-- width = 4.0, +-- length = 6.0, +-- debugPoly = true, +-- minZ = point.z - 1, +-- maxZ = point.z + 1, +-- }, +-- maxDistance = 2.0, +-- options = { +-- { +-- label = 'Menu|' .. i, +-- icon = 'fas fa-car', +-- action = { +-- type = 'sync', +-- func = function() +-- end +-- } +-- }, +-- } +-- } +-- end + +-- Wait(50) + +-- for index, value in ipairs(ids) do +-- exports['interactionMenu']:remove(value) +-- end +-- end + +-- local function test_onPlayer() +-- local ids = {} +-- local numPoints = 100 + +-- for i = 1, numPoints, 1 do +-- ids[#ids + 1] = exports['interactionMenu']:create { +-- player = i, +-- offset = vec3(0, 0, 0), +-- maxDistance = 1.0, +-- options = { +-- { +-- label = 'Just On Player Id: ' .. i, +-- icon = 'fa fa-person', +-- action = { +-- type = 'sync', +-- func = function(data) +-- Util.print_table(data) +-- end +-- } +-- } +-- } +-- } +-- end + +-- Wait(50) + +-- for index, value in ipairs(ids) do +-- exports['interactionMenu']:remove(value) +-- end +-- end + +-- local function test_entity() +-- local centerPoint = vector3(-2002.83, 3222.66, 32.81) +-- local positions = {} +-- local ids = {} +-- local entities = {} +-- local numPoints = 30 +-- local radius = 5.0 +-- local direction = false + +-- for i = 1, numPoints do +-- local angle = (2 * math.pi / numPoints) * i +-- local x = centerPoint.x + radius * math.cos(angle) +-- local y = centerPoint.y + radius * math.sin(angle) +-- local heading = math.deg(math.atan(centerPoint.y - y, centerPoint.x - x)) +-- if direction then +-- heading = heading - 90 +-- else +-- heading = heading + 90 +-- end +-- if heading < 0 then +-- heading = heading + 360 +-- end +-- local spawnPoint = vector4(x, y, centerPoint.z, heading) +-- table.insert(positions, spawnPoint) +-- end + +-- for i = 1, numPoints, 1 do +-- entities[i] = Util.spawnObject(`prop_vend_snak_01`, positions[i]) + +-- ids[#ids + 1] = exports['interactionMenu']:Create { +-- entity = entities[i], +-- maxDistance = 2.0, +-- options = { +-- { +-- label = 'Menu|' .. i, +-- icon = 'fas fa-car', +-- action = { +-- type = 'sync', +-- func = function() +-- end +-- } +-- }, +-- } +-- } +-- end + +-- Wait(500) + +-- for index, value in ipairs(ids) do +-- exports['interactionMenu']:remove(value) +-- end +-- for index, value in ipairs(entities) do +-- DeleteEntity(value) +-- end +-- end + +-- CreateThread(function() +-- Wait(1000) + +-- while true do +-- test() +-- print(Container.count()) +-- Wait(500) +-- end +-- end) + +-- CreateThread(function() +-- Wait(1000) +-- local numPoints = 10000 + +-- for i = 1, 10, 1 do +-- for ij = 1, numPoints, 1 do +-- exports['interactionMenu']:Create { +-- type = 'position', +-- position = vec3(math.random(0, 5000), math.random(0, 5000), math.random(0, 5000)), +-- maxDistance = 2.0, +-- options = { +-- { +-- label = 'Menu|' .. ij, +-- icon = 'fas fa-car', +-- action = { +-- type = 'sync', +-- func = function() +-- end +-- } +-- }, +-- } +-- } +-- end +-- Wait(500) +-- end +-- end) + +-- CreateThread(function() +-- local veh_pos = vector4(-1974.9, 3178.76, 32.81, 59.65) +-- local vehicle = Util.spawnVehicle('adder', veh_pos) + +-- while true do +-- for i = 1, 100, 1 do +-- local id = exports['interactionMenu']:Create { +-- bone = 'platelight', +-- vehicle = vehicle, +-- offset = vec3(0, 0, 0), +-- maxDistance = 2.0, +-- indicator = { +-- prompt = 'E', +-- keyPress = { +-- -- https://docs.fivem.net/docs/game-references/controls/#controls +-- padIndex = 0, +-- control = 38 +-- } +-- }, +-- options = {} +-- } + +-- exports['interactionMenu']:remove(id) +-- end +-- Wait(50) +-- end +-- end)