mirror of
https://github.com/MarioSpore/Grinch-AP.git
synced 2025-10-21 20:21:32 -06:00

* add shop shuffle options and items * add logic for the shop slots * write cost tests * start on shop item logic * make strike and second wind early items * some cleanup * remove 5 shards * double cost requirement for really expensive items and raise the rates * add test for shop shuffle with minimum other locations * put power seal in front of shards * rename locations and items * update rules, regions, and shop * update tests and misc fixes * minor cleanup * implement money wrench and figurines * clean out now unneeded info from slot_data * docs update and fix a failure when not shuffling shops * remove shop shuffle option * Finish out shop rules * make seals generation easier to read and fix tests * rule adjustments * oop * adjust the prices to be a bit more generous * add max price to slot data for tracker * update the hard rules a bit * remove unnecessary test * update data_version * bump version and remove info for fixed issues * remove now unneeded assert * review updates * minor bug fix * add a test for minimum locations shop costing * minor optimizations and cleanup * remove whitespace
98 lines
4.2 KiB
Python
98 lines
4.2 KiB
Python
from BaseClasses import ItemClassification, CollectionState
|
|
from . import MessengerTestBase
|
|
|
|
|
|
class AllSealsRequired(MessengerTestBase):
|
|
options = {
|
|
"shuffle_seals": "false",
|
|
"goal": "power_seal_hunt",
|
|
}
|
|
|
|
def testSealsShuffled(self) -> None:
|
|
"""Shuffle seals should be forced on when shop chest is the goal so test it."""
|
|
self.assertTrue(self.multiworld.shuffle_seals[self.player])
|
|
|
|
def testChestAccess(self) -> None:
|
|
"""Defaults to a total of 45 power seals in the pool and required."""
|
|
with self.subTest("Access Dependency"):
|
|
self.assertEqual(len([seal for seal in self.multiworld.itempool if seal.name == "Power Seal"]),
|
|
self.multiworld.total_seals[self.player])
|
|
locations = ["Shop Chest"]
|
|
items = [["Power Seal"]]
|
|
self.assertAccessDependency(locations, items)
|
|
self.multiworld.state = CollectionState(self.multiworld)
|
|
|
|
self.assertEqual(self.can_reach_location("Shop Chest"), False)
|
|
self.assertBeatable(False)
|
|
self.collect_all_but(["Power Seal", "Shop Chest", "Rescue Phantom"])
|
|
self.assertEqual(self.can_reach_location("Shop Chest"), False)
|
|
self.assertBeatable(False)
|
|
self.collect_by_name("Power Seal")
|
|
self.assertEqual(self.can_reach_location("Shop Chest"), True)
|
|
self.assertBeatable(True)
|
|
|
|
|
|
class HalfSealsRequired(MessengerTestBase):
|
|
options = {
|
|
"goal": "power_seal_hunt",
|
|
"percent_seals_required": 50,
|
|
}
|
|
|
|
def testSealsAmount(self) -> None:
|
|
"""Should have 45 power seals in the item pool and half that required"""
|
|
self.assertEqual(self.multiworld.total_seals[self.player], 45)
|
|
self.assertEqual(self.multiworld.worlds[self.player].total_seals, 45)
|
|
self.assertEqual(self.multiworld.worlds[self.player].required_seals, 22)
|
|
total_seals = [seal for seal in self.multiworld.itempool if seal.name == "Power Seal"]
|
|
required_seals = [seal for seal in total_seals if seal.classification == ItemClassification.progression_skip_balancing]
|
|
self.assertEqual(len(total_seals), 45)
|
|
self.assertEqual(len(required_seals), 22)
|
|
|
|
|
|
class ThirtyThirtySeals(MessengerTestBase):
|
|
options = {
|
|
"goal": "power_seal_hunt",
|
|
"total_seals": 30,
|
|
"percent_seals_required": 34,
|
|
}
|
|
|
|
def testSealsAmount(self) -> None:
|
|
"""Should have 30 power seals in the pool and 33 percent of that required."""
|
|
self.assertEqual(self.multiworld.total_seals[self.player], 30)
|
|
self.assertEqual(self.multiworld.worlds[self.player].total_seals, 30)
|
|
self.assertEqual(self.multiworld.worlds[self.player].required_seals, 10)
|
|
total_seals = [seal for seal in self.multiworld.itempool if seal.name == "Power Seal"]
|
|
required_seals = [seal for seal in total_seals if seal.classification == ItemClassification.progression_skip_balancing]
|
|
self.assertEqual(len(total_seals), 30)
|
|
self.assertEqual(len(required_seals), 10)
|
|
|
|
|
|
class MaxSealsNoShards(MessengerTestBase):
|
|
options = {
|
|
"goal": "power_seal_hunt",
|
|
"total_seals": 85,
|
|
}
|
|
|
|
def testSealsAmount(self) -> None:
|
|
"""Should set total seals to 57 since shards aren't shuffled."""
|
|
self.assertEqual(self.multiworld.total_seals[self.player], 85)
|
|
self.assertEqual(self.multiworld.worlds[self.player].total_seals, 57)
|
|
|
|
|
|
class MaxSealsWithShards(MessengerTestBase):
|
|
options = {
|
|
"goal": "power_seal_hunt",
|
|
"total_seals": 85,
|
|
"shuffle_shards": "true",
|
|
}
|
|
|
|
def testSealsAmount(self) -> None:
|
|
"""Should have 85 seals in the pool with all required and be a valid seed."""
|
|
self.assertEqual(self.multiworld.total_seals[self.player], 85)
|
|
self.assertEqual(self.multiworld.worlds[self.player].total_seals, 85)
|
|
self.assertEqual(self.multiworld.worlds[self.player].required_seals, 85)
|
|
total_seals = [seal for seal in self.multiworld.itempool if seal.name == "Power Seal"]
|
|
required_seals = [seal for seal in total_seals if seal.classification == ItemClassification.progression_skip_balancing]
|
|
self.assertEqual(len(total_seals), 85)
|
|
self.assertEqual(len(required_seals), 85)
|