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.
This commit is contained in:
Refringe 2023-11-07 22:59:04 -05:00
parent ea7d6117ea
commit 0ad85b45e1
No known key found for this signature in database
GPG Key ID: 64E03E5F892C6F9E
2 changed files with 40 additions and 23 deletions

View File

@ -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);
}
/**

View File

@ -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();
});
});
});