HK: fix grubhunt required grubs count (#4094)

* somehow this mixup got into the final grubhunt PR

* catch a case I didn't test before

* Update worlds/hk/__init__.py

Co-authored-by: Mysteryem <Mysteryem@users.noreply.github.com>

* first pass at adding grub count tests

* add tests to explicitly show counting/not counting of player2s grubs

* forgot a test rename

---------

Co-authored-by: Mysteryem <Mysteryem@users.noreply.github.com>
This commit is contained in:
qwint 2024-10-30 18:58:40 -04:00 committed by GitHub
parent aaf25f8c6f
commit 0b5c7fe8a9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 232 additions and 1 deletions

View File

@ -509,9 +509,13 @@ class HKWorld(World):
per_player_grubs_per_player[player][player] += 1
if grub.location and grub.location.player in group_lookup.keys():
for real_player in group_lookup[grub.location.player]:
# will count the item linked grub instead
pass
elif player in group_lookup:
for real_player in group_lookup[player]:
grub_count_per_player[real_player] += 1
else:
# for non-linked grubs
grub_count_per_player[player] += 1
for player, count in grub_count_per_player.items():

View File

@ -0,0 +1,62 @@
import typing
from argparse import Namespace
from BaseClasses import CollectionState, MultiWorld
from Options import ItemLinks
from test.bases import WorldTestBase
from worlds.AutoWorld import AutoWorldRegister, call_all
from .. import HKWorld
class linkedTestHK():
run_default_tests = False
game = "Hollow Knight"
world: HKWorld
expected_grubs: int
item_link_group: typing.List[typing.Dict[str, typing.Any]]
def setup_item_links(self, args):
setattr(args, "item_links",
{
1: ItemLinks.from_any(self.item_link_group),
2: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Grub"],
"link_replacement": False,
"replacement_item": "One_Geo",
}])
})
return args
def world_setup(self) -> None:
"""
Create a multiworld with two players that share an itemlink
"""
self.multiworld = MultiWorld(2)
self.multiworld.game = {1: self.game, 2: self.game}
self.multiworld.player_name = {1: "Linker 1", 2: "Linker 2"}
self.multiworld.set_seed()
args = Namespace()
options_dataclass = AutoWorldRegister.world_types[self.game].options_dataclass
for name, option in options_dataclass.type_hints.items():
setattr(args, name, {
1: option.from_any(self.options.get(name, option.default)),
2: option.from_any(self.options.get(name, option.default))
})
args = self.setup_item_links(args)
self.multiworld.set_options(args)
self.multiworld.set_item_links()
# groups get added to state during its constructor so this has to be after item links are set
self.multiworld.state = CollectionState(self.multiworld)
gen_steps = ("generate_early", "create_regions", "create_items", "set_rules", "generate_basic")
for step in gen_steps:
call_all(self.multiworld, step)
# link the items together and stop at prefill
self.multiworld.link_items()
self.multiworld._all_state = None
call_all(self.multiworld, "pre_fill")
self.world = self.multiworld.worlds[self.player]
def test_grub_count(self) -> None:
assert self.world.grub_count == self.expected_grubs, \
f"Expected {self.expected_grubs} but found {self.world.grub_count}"

View File

@ -0,0 +1,165 @@
from . import linkedTestHK, WorldTestBase
from Options import ItemLinks
class test_grubcount_limited(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": 20,
"Goal": "any",
}
item_link_group = [{
"name": "ItemLinkTest",
"item_pool": ["Grub"],
"link_replacement": True,
"replacement_item": "Grub",
}]
expected_grubs = 20
class test_grubcount_default(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"Goal": "any",
}
item_link_group = [{
"name": "ItemLinkTest",
"item_pool": ["Grub"],
"link_replacement": True,
"replacement_item": "Grub",
}]
expected_grubs = 46
class test_grubcount_all_unlinked(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": "all",
"Goal": "any",
}
item_link_group = []
expected_grubs = 46
class test_grubcount_all_linked(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": "all",
"Goal": "any",
}
item_link_group = [{
"name": "ItemLinkTest",
"item_pool": ["Grub"],
"link_replacement": True,
"replacement_item": "Grub",
}]
expected_grubs = 46 + 23
class test_replacement_only(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": "all",
"Goal": "any",
}
expected_grubs = 46 + 18 # the count of grubs + skills removed from item links
def setup_item_links(self, args):
setattr(args, "item_links",
{
1: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": True,
"replacement_item": "Grub",
}]),
2: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": True,
"replacement_item": "Grub",
}])
})
return args
class test_replacement_only_unlinked(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": "all",
"Goal": "any",
}
expected_grubs = 46 + 9 # Player1s replacement Grubs
def setup_item_links(self, args):
setattr(args, "item_links",
{
1: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": False,
"replacement_item": "Grub",
}]),
2: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": False,
"replacement_item": "Grub",
}])
})
return args
class test_ignore_others(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": "all",
"Goal": "any",
}
# player2 has more than 46 grubs but they are unlinked so player1s grubs are vanilla
expected_grubs = 46
def setup_item_links(self, args):
setattr(args, "item_links",
{
1: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": False,
"replacement_item": "One_Geo",
}]),
2: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": False,
"replacement_item": "Grub",
}])
})
return args
class test_replacement_only_linked(linkedTestHK, WorldTestBase):
options = {
"RandomizeGrubs": True,
"GrubHuntGoal": "all",
"Goal": "any",
}
expected_grubs = 46 + 9 # Player2s linkreplacement grubs
def setup_item_links(self, args):
setattr(args, "item_links",
{
1: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": True,
"replacement_item": "One_Geo",
}]),
2: ItemLinks.from_any([{
"name": "ItemLinkTest",
"item_pool": ["Skills"],
"link_replacement": True,
"replacement_item": "Grub",
}])
})
return args