mirror of
https://github.com/MarioSpore/Grinch-AP.git
synced 2025-10-21 20:21:32 -06:00
The Witness: Add info about which door items exist in the pool to slot data (#3583)
* This feature is just broken lol * simplify * mypy * Expand the unit test for forbidden doors
This commit is contained in:
@@ -84,7 +84,8 @@ class WitnessWorld(World):
|
||||
"victory_location": int(self.player_logic.VICTORY_LOCATION, 16),
|
||||
"panelhex_to_id": self.player_locations.CHECK_PANELHEX_TO_ID,
|
||||
"item_id_to_door_hexes": static_witness_items.get_item_to_door_mappings(),
|
||||
"door_hexes_in_the_pool": self.player_items.get_door_ids_in_pool(),
|
||||
"door_items_in_the_pool": self.player_items.get_door_item_ids_in_pool(),
|
||||
"doors_that_shouldnt_be_locked": [int(h, 16) for h in self.player_logic.FORBIDDEN_DOORS],
|
||||
"symbols_not_in_the_game": self.player_items.get_symbol_ids_not_in_pool(),
|
||||
"disabled_entities": [int(h, 16) for h in self.player_logic.COMPLETELY_DISABLED_ENTITIES],
|
||||
"hunt_entities": [int(h, 16) for h in self.player_logic.HUNT_ENTITIES],
|
||||
@@ -150,7 +151,8 @@ class WitnessWorld(World):
|
||||
)
|
||||
self.player_regions: WitnessPlayerRegions = WitnessPlayerRegions(self.player_locations, self)
|
||||
|
||||
self.log_ids_to_hints = {}
|
||||
self.log_ids_to_hints: Dict[int, CompactHintData] = {}
|
||||
self.laser_ids_to_hints: Dict[int, CompactHintData] = {}
|
||||
|
||||
self.determine_sufficient_progression()
|
||||
|
||||
@@ -325,9 +327,6 @@ class WitnessWorld(World):
|
||||
self.options.local_items.value.add(item_name)
|
||||
|
||||
def fill_slot_data(self) -> Dict[str, Any]:
|
||||
self.log_ids_to_hints: Dict[int, CompactHintData] = {}
|
||||
self.laser_ids_to_hints: Dict[int, CompactHintData] = {}
|
||||
|
||||
already_hinted_locations = set()
|
||||
|
||||
# Laser hints
|
||||
|
@@ -222,20 +222,15 @@ class WitnessPlayerItems:
|
||||
# Sort the output for consistency across versions if the implementation changes but the logic does not.
|
||||
return sorted(output)
|
||||
|
||||
def get_door_ids_in_pool(self) -> List[int]:
|
||||
def get_door_item_ids_in_pool(self) -> List[int]:
|
||||
"""
|
||||
Returns the total set of all door IDs that are controlled by items in the pool.
|
||||
Returns the ids of all door items that exist in the pool.
|
||||
"""
|
||||
output: List[int] = []
|
||||
|
||||
for item_name, item_data in self.item_data.items():
|
||||
if not isinstance(item_data.definition, DoorItemDefinition):
|
||||
continue
|
||||
|
||||
output += [int(hex_string, 16) for hex_string in item_data.definition.panel_id_hexes
|
||||
if hex_string not in self._logic.FORBIDDEN_DOORS]
|
||||
|
||||
return output
|
||||
return [
|
||||
cast_not_none(item_data.ap_code) for item_data in self.item_data.values()
|
||||
if isinstance(item_data.definition, DoorItemDefinition)
|
||||
]
|
||||
|
||||
def get_symbol_ids_not_in_pool(self) -> List[int]:
|
||||
"""
|
||||
@@ -257,5 +252,3 @@ class WitnessPlayerItems:
|
||||
output[cast_not_none(item.ap_code)] = [cast_not_none(static_witness_items.ITEM_DATA[child_item].ap_code)
|
||||
for child_item in item.definition.child_item_names]
|
||||
return output
|
||||
|
||||
|
||||
|
@@ -1,3 +1,6 @@
|
||||
from typing import cast
|
||||
|
||||
from .. import WitnessWorld
|
||||
from ..test import WitnessMultiworldTestBase, WitnessTestBase
|
||||
|
||||
|
||||
@@ -32,6 +35,10 @@ class TestForbiddenDoors(WitnessMultiworldTestBase):
|
||||
{
|
||||
"early_caves": "add_to_pool",
|
||||
},
|
||||
{
|
||||
"early_caves": "add_to_pool",
|
||||
"door_groupings": "regional",
|
||||
},
|
||||
]
|
||||
|
||||
common_options = {
|
||||
@@ -40,11 +47,35 @@ class TestForbiddenDoors(WitnessMultiworldTestBase):
|
||||
}
|
||||
|
||||
def test_forbidden_doors(self) -> None:
|
||||
self.assertTrue(
|
||||
self.get_items_by_name("Caves Mountain Shortcut (Panel)", 1),
|
||||
"Caves Mountain Shortcut (Panel) should exist in panels shuffle, but it didn't."
|
||||
)
|
||||
self.assertFalse(
|
||||
self.get_items_by_name("Caves Mountain Shortcut (Panel)", 2),
|
||||
"Caves Mountain Shortcut (Panel) should be removed when Early Caves is enabled, but it still exists."
|
||||
)
|
||||
with self.subTest("Test that Caves Mountain Shortcut (Panel) exists if Early Caves is off"):
|
||||
self.assertTrue(
|
||||
self.get_items_by_name("Caves Mountain Shortcut (Panel)", 1),
|
||||
"Caves Mountain Shortcut (Panel) should exist in panels shuffle, but it didn't."
|
||||
)
|
||||
|
||||
with self.subTest("Test that Caves Mountain Shortcut (Panel) doesn't exist if Early Caves is start_to_pool"):
|
||||
self.assertFalse(
|
||||
self.get_items_by_name("Caves Mountain Shortcut (Panel)", 2),
|
||||
"Caves Mountain Shortcut (Panel) should be removed when Early Caves is enabled, but it still exists."
|
||||
)
|
||||
|
||||
with self.subTest("Test that slot data is set up correctly for a panels seed with Early Caves"):
|
||||
slot_data = cast(WitnessWorld, self.multiworld.worlds[3])._get_slot_data()
|
||||
|
||||
self.assertIn(
|
||||
WitnessWorld.item_name_to_id["Caves Panels"],
|
||||
slot_data["door_items_in_the_pool"],
|
||||
'Caves Panels should still exist in slot_data under "door_items_in_the_pool".'
|
||||
)
|
||||
|
||||
self.assertIn(
|
||||
0x021D7,
|
||||
slot_data["item_id_to_door_hexes"][WitnessWorld.item_name_to_id["Caves Panels"]],
|
||||
"Caves Panels should still contain Caves Mountain Shortcut Panel as a door they unlock.",
|
||||
)
|
||||
|
||||
self.assertIn(
|
||||
0x021D7,
|
||||
slot_data["doors_that_shouldnt_be_locked"],
|
||||
"Caves Mountain Shortcut Panel should be marked as \"shouldn't be locked\".",
|
||||
)
|
||||
|
Reference in New Issue
Block a user