forked from pmariglia/foul-play
-
Notifications
You must be signed in to change notification settings - Fork 0
/
run.py
executable file
·111 lines (91 loc) · 3.67 KB
/
run.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/env python3
import asyncio
import json
import logging
import traceback
from datetime import datetime
from copy import deepcopy
import constants
from config import ShowdownConfig, init_logging
from teams import load_team
from showdown.run_battle import pokemon_battle
from showdown.websocket_client import PSWebsocketClient
from data import all_move_json
from data import pokedex
from data.mods.apply_mods import apply_mods
logger = logging.getLogger(__name__)
def check_dictionaries_are_unmodified(original_pokedex, original_move_json):
# The bot should not modify the data dictionaries
# This is a "just-in-case" check to make sure and will stop the bot if it mutates either of them
if original_move_json != all_move_json:
logger.critical("Move JSON changed!\nDumping modified version to `modified_moves.json`")
with open("modified_moves.json", 'w') as f:
json.dump(all_move_json, f, indent=4)
exit(1)
else:
logger.debug("Move JSON unmodified!")
if original_pokedex != pokedex:
logger.critical(
"Pokedex JSON changed!\nDumping modified version to `modified_pokedex.json`"
)
with open("modified_pokedex.json", 'w') as f:
json.dump(pokedex, f, indent=4)
exit(1)
else:
logger.debug("Pokedex JSON unmodified!")
async def showdown():
ShowdownConfig.configure()
init_logging(
ShowdownConfig.log_level,
ShowdownConfig.log_to_file
)
apply_mods(ShowdownConfig.pokemon_mode)
original_pokedex = deepcopy(pokedex)
original_move_json = deepcopy(all_move_json)
ps_websocket_client = await PSWebsocketClient.create(
ShowdownConfig.username,
ShowdownConfig.password,
ShowdownConfig.websocket_uri
)
await ps_websocket_client.login()
battles_run = 0
wins = 0
losses = 0
while True:
if ShowdownConfig.log_to_file:
ShowdownConfig.log_handler.do_rollover(datetime.now().strftime("%Y-%m-%dT%H:%M:%S.log"))
is_random_battle = any(mode in ShowdownConfig.team for mode in ["random", "bssfactory", "battlefactory", "challengecup", "computergeneratedteams"])
team = load_team(ShowdownConfig.team) if not is_random_battle else 'null'
if ShowdownConfig.bot_mode == constants.CHALLENGE_USER:
await ps_websocket_client.challenge_user(
ShowdownConfig.user_to_challenge,
ShowdownConfig.pokemon_mode,
team
)
elif ShowdownConfig.bot_mode == constants.ACCEPT_CHALLENGE:
await ps_websocket_client.accept_challenge(
ShowdownConfig.pokemon_mode,
team,
ShowdownConfig.room_name
)
elif ShowdownConfig.bot_mode == constants.SEARCH_LADDER:
await ps_websocket_client.search_for_match(ShowdownConfig.pokemon_mode, team)
else:
raise ValueError("Invalid Bot Mode: {}".format(ShowdownConfig.bot_mode))
winner = await pokemon_battle(ps_websocket_client, ShowdownConfig.pokemon_mode)
if winner == ShowdownConfig.username:
wins += 1
else:
losses += 1
logger.info("W: {}\tL: {}".format(wins, losses))
await ps_websocket_client.send_message('lobby', [f'My stats are W:{wins}, L:{losses}'])
check_dictionaries_are_unmodified(original_pokedex, original_move_json)
battles_run += 1
if ShowdownConfig.run_count > 0 and battles_run >= ShowdownConfig.run_count:
break
if __name__ == "__main__":
try:
asyncio.run(showdown())
except Exception as e:
logger.error(traceback.format_exc())
raise