mirror of
https://github.com/mwisnowski/mtg_python_deckbuilder.git
synced 2025-12-17 08:00:13 +01:00
fix(lint): improved type checking and code maintainability
This commit is contained in:
parent
83fe527979
commit
40023e93b8
62 changed files with 187 additions and 197 deletions
|
|
@ -9,17 +9,17 @@ def setup_module(module): # ensure deterministic env weights
|
|||
|
||||
def test_rarity_diminishing():
|
||||
# Monkeypatch internal index
|
||||
card_index._CARD_INDEX.clear() # type: ignore
|
||||
card_index._CARD_INDEX.clear()
|
||||
theme = "Test Theme"
|
||||
card_index._CARD_INDEX[theme] = [ # type: ignore
|
||||
card_index._CARD_INDEX[theme] = [
|
||||
{"name": "Mythic One", "tags": [theme], "color_identity": "G", "mana_cost": "G", "rarity": "mythic"},
|
||||
{"name": "Mythic Two", "tags": [theme], "color_identity": "G", "mana_cost": "G", "rarity": "mythic"},
|
||||
]
|
||||
def no_build():
|
||||
return None
|
||||
sampling.maybe_build_index = no_build # type: ignore
|
||||
sampling.maybe_build_index = no_build
|
||||
cards = sampling.sample_real_cards_for_theme(theme, 2, None, synergies=[theme], commander=None)
|
||||
rarity_weights = [r for c in cards for r in c["reasons"] if r.startswith("rarity_weight_calibrated")] # type: ignore
|
||||
rarity_weights = [r for c in cards for r in c["reasons"] if r.startswith("rarity_weight_calibrated")]
|
||||
assert len(rarity_weights) >= 2
|
||||
v1 = float(rarity_weights[0].split(":")[-1])
|
||||
v2 = float(rarity_weights[1].split(":")[-1])
|
||||
|
|
@ -40,15 +40,15 @@ def test_commander_overlap_monotonic_diminishing():
|
|||
|
||||
|
||||
def test_splash_off_color_penalty_applied():
|
||||
card_index._CARD_INDEX.clear() # type: ignore
|
||||
card_index._CARD_INDEX.clear()
|
||||
theme = "Splash Theme"
|
||||
# Commander W U B R (4 colors)
|
||||
commander = {"name": "CommanderTest", "tags": [theme], "color_identity": "WUBR", "mana_cost": "", "rarity": "mythic"}
|
||||
# Card with single off-color G (W U B R G)
|
||||
splash_card = {"name": "CardSplash", "tags": [theme], "color_identity": "WUBRG", "mana_cost": "G", "rarity": "rare"}
|
||||
card_index._CARD_INDEX[theme] = [commander, splash_card] # type: ignore
|
||||
sampling.maybe_build_index = lambda: None # type: ignore
|
||||
card_index._CARD_INDEX[theme] = [commander, splash_card]
|
||||
sampling.maybe_build_index = lambda: None
|
||||
cards = sampling.sample_real_cards_for_theme(theme, 2, None, synergies=[theme], commander="CommanderTest")
|
||||
splash = next((c for c in cards if c["name"] == "CardSplash"), None)
|
||||
assert splash is not None
|
||||
assert any(r.startswith("splash_off_color_penalty") for r in splash["reasons"]) # type: ignore
|
||||
assert any(r.startswith("splash_off_color_penalty") for r in splash["reasons"])
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue