From 0ad85b45e1889f3492ac49d1e0650b59fd5801e3 Mon Sep 17 00:00:00 2001 From: Refringe Date: Tue, 7 Nov 2023 22:59:04 -0500 Subject: [PATCH] Small `ItemHelper.getRandomCompatibleCaliberTemplateId()` Improvements - Updated to safely access a deeply nested property. - Updated to safely access the item `_id` and `_name` properties in the warning log. - Updated to use the `RandomUtil.getArrayValue()` method to select a random ammo item template ID. - Finished up some tests. --- project/src/helpers/ItemHelper.ts | 8 ++-- project/tests/helpers/ItemHelper.test.ts | 55 ++++++++++++++++-------- 2 files changed, 40 insertions(+), 23 deletions(-) diff --git a/project/src/helpers/ItemHelper.ts b/project/src/helpers/ItemHelper.ts index 2d7b4c3d..85d4a49b 100644 --- a/project/src/helpers/ItemHelper.ts +++ b/project/src/helpers/ItemHelper.ts @@ -912,17 +912,17 @@ class ItemHelper * @param item Db item template to look up Cartridge filter values from * @returns Caliber of cartridge */ - public getRandomCompatibleCaliberTemplateId(item: ITemplateItem): string + public getRandomCompatibleCaliberTemplateId(item: ITemplateItem): string | null { - const cartridges = item._props.Cartridges[0]._props.filters[0].Filter; + const cartridges = item?._props?.Cartridges[0]?._props?.filters[0]?.Filter; if (!cartridges) { - this.logger.warning(`no cartridges found for item: ${item._id} ${item._name}`); + this.logger.warning(`Failed to find cartridge for item: ${item?._id} ${item?._name}`); return null; } - return cartridges[Math.floor(Math.random() * item._props.Cartridges[0]._props.filters[0].Filter.length)]; + return this.randomUtil.getArrayValue(cartridges); } /** diff --git a/project/tests/helpers/ItemHelper.test.ts b/project/tests/helpers/ItemHelper.test.ts index 52ee42b5..875d8576 100644 --- a/project/tests/helpers/ItemHelper.test.ts +++ b/project/tests/helpers/ItemHelper.test.ts @@ -1076,31 +1076,39 @@ describe("ItemHelper", () => describe("getRandomCompatibleCaliberTemplateId", () => { - it("Should return an item from the passed in items Filter array", () => + it("should return an item from the passed template's cartridge filter array", () => { - const fakeTemplateItem = { - _props: { - Cartridges: [ - { - _props: { - filters: [ - { - Filter: [ - "desiredItemTpl" - ] - } - ] - } + const validAmmoItems = [ + "5735ff5c245977640e39ba7e", + "573601b42459776410737435", + "573602322459776445391df1", + "5736026a245977644601dc61", + "573603562459776430731618", + "573603c924597764442bd9cb", + "5735fdcd2459776445391d61" + ]; + const mockTemplateItem = { + "_id": "571a29dc2459771fb2755a6a", + "_name": "mag_tt_toz_std_762x25tt_8", + "_props": { + "Cartridges": [{ + "_props": { + "filters": [{ + "Filter": validAmmoItems + }] } - ] + }] } }; - const result = itemHelper.getRandomCompatibleCaliberTemplateId(fakeTemplateItem as ITemplateItem); - expect(result).toBe("desiredItemTpl"); + vi.spyOn((itemHelper as any).randomUtil, "getArrayValue").mockReturnValue(validAmmoItems[0]); + + const result = itemHelper.getRandomCompatibleCaliberTemplateId(mockTemplateItem as ITemplateItem); + + expect(validAmmoItems).toContain(result); }); - it("Should return null when item passed in has empty cartridges data", () => + it("should return null when passed template has empty cartridge property", () => { const fakeTemplateItem = { _props: { @@ -1114,11 +1122,20 @@ describe("ItemHelper", () => expect(result).toBe(null); }); - it("Should return null when undefined passed in", () => + it("should return null when undefined passed in", () => { const result = itemHelper.getRandomCompatibleCaliberTemplateId(undefined as ITemplateItem); expect(result).toBe(null); }); + + it("should log a warning when the template cartridge can not be found", () => + { + const mockLoggerWarning = vi.spyOn((itemHelper as any).logger, "warning"); + + itemHelper.getRandomCompatibleCaliberTemplateId(undefined as ITemplateItem); + + expect(mockLoggerWarning).toHaveBeenCalled(); + }); }); });