mirror of
https://github.com/ChuckBuilds/LEDMatrix.git
synced 2026-04-10 21:03:01 +00:00
update record & rank logic, update leaderboard font and logo sizes
This commit is contained in:
@@ -170,7 +170,8 @@
|
|||||||
},
|
},
|
||||||
"ncaa_fb": {
|
"ncaa_fb": {
|
||||||
"enabled": true,
|
"enabled": true,
|
||||||
"top_teams": 25
|
"top_teams": 25,
|
||||||
|
"show_ranking": true
|
||||||
},
|
},
|
||||||
"nhl": {
|
"nhl": {
|
||||||
"enabled": false,
|
"enabled": false,
|
||||||
@@ -299,6 +300,7 @@
|
|||||||
],
|
],
|
||||||
"logo_dir": "assets/sports/ncaa_fbs_logos",
|
"logo_dir": "assets/sports/ncaa_fbs_logos",
|
||||||
"show_records": true,
|
"show_records": true,
|
||||||
|
"show_ranking": false,
|
||||||
"display_modes": {
|
"display_modes": {
|
||||||
"ncaa_fb_live": true,
|
"ncaa_fb_live": true,
|
||||||
"ncaa_fb_recent": true ,
|
"ncaa_fb_recent": true ,
|
||||||
|
|||||||
@@ -100,7 +100,8 @@ class LeaderboardManager:
|
|||||||
'league_logo': 'assets/sports/ncaa_fbs_logos/ncaa_fb.png',
|
'league_logo': 'assets/sports/ncaa_fbs_logos/ncaa_fb.png',
|
||||||
'teams_url': 'https://site.api.espn.com/apis/site/v2/sports/football/college-football/teams',
|
'teams_url': 'https://site.api.espn.com/apis/site/v2/sports/football/college-football/teams',
|
||||||
'enabled': self.enabled_sports.get('ncaa_fb', {}).get('enabled', False),
|
'enabled': self.enabled_sports.get('ncaa_fb', {}).get('enabled', False),
|
||||||
'top_teams': self.enabled_sports.get('ncaa_fb', {}).get('top_teams', 25)
|
'top_teams': self.enabled_sports.get('ncaa_fb', {}).get('top_teams', 25),
|
||||||
|
'show_ranking': self.enabled_sports.get('ncaa_fb', {}).get('show_ranking', True)
|
||||||
},
|
},
|
||||||
'nhl': {
|
'nhl': {
|
||||||
'sport': 'hockey',
|
'sport': 'hockey',
|
||||||
@@ -568,12 +569,29 @@ class LeaderboardManager:
|
|||||||
|
|
||||||
# Draw team standings horizontally in a single line
|
# Draw team standings horizontally in a single line
|
||||||
team_x = current_x
|
team_x = current_x
|
||||||
# Use the same dynamic logo size calculated earlier
|
# Use the same dynamic logo size as Odds Manager ticker
|
||||||
logo_size = int(height * 0.95)
|
logo_size = int(height * 1.2)
|
||||||
|
|
||||||
for i, team in enumerate(teams):
|
for i, team in enumerate(teams):
|
||||||
# Draw bold team number (centered vertically)
|
# Draw bold team number/ranking/record (centered vertically)
|
||||||
number_text = f"{i+1}."
|
if league_key == 'ncaa_fb':
|
||||||
|
if league_config.get('show_ranking', True):
|
||||||
|
# Show ranking number if available
|
||||||
|
if 'rank' in team and team['rank'] > 0:
|
||||||
|
number_text = f"#{team['rank']}"
|
||||||
|
else:
|
||||||
|
# Team is unranked - show position number as fallback
|
||||||
|
number_text = f"{i+1}."
|
||||||
|
else:
|
||||||
|
# Show record instead of ranking
|
||||||
|
if 'record_summary' in team:
|
||||||
|
number_text = team['record_summary']
|
||||||
|
else:
|
||||||
|
number_text = f"{i+1}."
|
||||||
|
else:
|
||||||
|
# For other leagues, show position
|
||||||
|
number_text = f"{i+1}."
|
||||||
|
|
||||||
number_bbox = self.fonts['large'].getbbox(number_text)
|
number_bbox = self.fonts['large'].getbbox(number_text)
|
||||||
number_width = number_bbox[2] - number_bbox[0]
|
number_width = number_bbox[2] - number_bbox[0]
|
||||||
number_height = number_bbox[3] - number_bbox[1]
|
number_height = number_bbox[3] - number_bbox[1]
|
||||||
@@ -593,24 +611,24 @@ class LeaderboardManager:
|
|||||||
|
|
||||||
# Draw team abbreviation after the logo (centered vertically)
|
# Draw team abbreviation after the logo (centered vertically)
|
||||||
team_text = team['abbreviation']
|
team_text = team['abbreviation']
|
||||||
text_bbox = self.fonts['large'].getbbox(team_text)
|
text_bbox = self.fonts['medium'].getbbox(team_text)
|
||||||
text_width = text_bbox[2] - text_bbox[0]
|
text_width = text_bbox[2] - text_bbox[0]
|
||||||
text_height = text_bbox[3] - text_bbox[1]
|
text_height = text_bbox[3] - text_bbox[1]
|
||||||
text_x = logo_x + logo_size + 4
|
text_x = logo_x + logo_size + 4
|
||||||
text_y = (height - text_height) // 2
|
text_y = (height - text_height) // 2
|
||||||
draw.text((text_x, text_y), team_text, font=self.fonts['large'], fill=(255, 255, 255))
|
draw.text((text_x, text_y), team_text, font=self.fonts['medium'], fill=(255, 255, 255))
|
||||||
|
|
||||||
# Calculate total width used by this team
|
# Calculate total width used by this team
|
||||||
team_width = number_width + 4 + logo_size + 4 + text_width + 12 # 12px spacing to next team
|
team_width = number_width + 4 + logo_size + 4 + text_width + 12 # 12px spacing to next team
|
||||||
else:
|
else:
|
||||||
# Fallback if no logo - draw team abbreviation after bold number (centered vertically)
|
# Fallback if no logo - draw team abbreviation after bold number (centered vertically)
|
||||||
team_text = team['abbreviation']
|
team_text = team['abbreviation']
|
||||||
text_bbox = self.fonts['large'].getbbox(team_text)
|
text_bbox = self.fonts['medium'].getbbox(team_text)
|
||||||
text_width = text_bbox[2] - text_bbox[0]
|
text_width = text_bbox[2] - text_bbox[0]
|
||||||
text_height = text_bbox[3] - text_bbox[1]
|
text_height = text_bbox[3] - text_bbox[1]
|
||||||
text_x = team_x + number_width + 4
|
text_x = team_x + number_width + 4
|
||||||
text_y = (height - text_height) // 2
|
text_y = (height - text_height) // 2
|
||||||
draw.text((text_x, text_y), team_text, font=self.fonts['large'], fill=(255, 255, 255))
|
draw.text((text_x, text_y), team_text, font=self.fonts['medium'], fill=(255, 255, 255))
|
||||||
|
|
||||||
# Calculate total width used by this team
|
# Calculate total width used by this team
|
||||||
team_width = number_width + 4 + text_width + 12 # 12px spacing to next team
|
team_width = number_width + 4 + text_width + 12 # 12px spacing to next team
|
||||||
|
|||||||
@@ -53,6 +53,7 @@ class BaseNCAAFBManager: # Renamed class
|
|||||||
self.logo_dir = self.ncaa_fb_config.get("logo_dir", "assets/sports/ncaa_fbs_logos") # Changed logo dir
|
self.logo_dir = self.ncaa_fb_config.get("logo_dir", "assets/sports/ncaa_fbs_logos") # Changed logo dir
|
||||||
self.update_interval = self.ncaa_fb_config.get("update_interval_seconds", 60)
|
self.update_interval = self.ncaa_fb_config.get("update_interval_seconds", 60)
|
||||||
self.show_records = self.ncaa_fb_config.get('show_records', False)
|
self.show_records = self.ncaa_fb_config.get('show_records', False)
|
||||||
|
self.show_ranking = self.ncaa_fb_config.get('show_ranking', False)
|
||||||
self.season_cache_duration = self.ncaa_fb_config.get("season_cache_duration_seconds", 86400) # 24 hours default
|
self.season_cache_duration = self.ncaa_fb_config.get("season_cache_duration_seconds", 86400) # 24 hours default
|
||||||
# Number of games to show (instead of time-based windows)
|
# Number of games to show (instead of time-based windows)
|
||||||
self.recent_games_to_show = self.ncaa_fb_config.get("recent_games_to_show", 5) # Show last 5 games
|
self.recent_games_to_show = self.ncaa_fb_config.get("recent_games_to_show", 5) # Show last 5 games
|
||||||
@@ -95,10 +96,57 @@ class BaseNCAAFBManager: # Renamed class
|
|||||||
self.display_height = self.display_manager.matrix.height
|
self.display_height = self.display_manager.matrix.height
|
||||||
|
|
||||||
self._logo_cache = {}
|
self._logo_cache = {}
|
||||||
|
|
||||||
|
# Initialize team rankings cache
|
||||||
|
self._team_rankings_cache = {}
|
||||||
|
self._rankings_cache_timestamp = 0
|
||||||
|
self._rankings_cache_duration = 3600 # Cache rankings for 1 hour
|
||||||
|
|
||||||
self.logger.info(f"Initialized NCAAFB manager with display dimensions: {self.display_width}x{self.display_height}")
|
self.logger.info(f"Initialized NCAAFB manager with display dimensions: {self.display_width}x{self.display_height}")
|
||||||
self.logger.info(f"Logo directory: {self.logo_dir}")
|
self.logger.info(f"Logo directory: {self.logo_dir}")
|
||||||
self.logger.info(f"Display modes - Recent: {self.recent_enabled}, Upcoming: {self.upcoming_enabled}, Live: {self.live_enabled}")
|
self.logger.info(f"Display modes - Recent: {self.recent_enabled}, Upcoming: {self.upcoming_enabled}, Live: {self.live_enabled}")
|
||||||
|
|
||||||
|
def _fetch_team_rankings(self) -> Dict[str, int]:
|
||||||
|
"""Fetch current team rankings from ESPN API."""
|
||||||
|
current_time = time.time()
|
||||||
|
|
||||||
|
# Check if we have cached rankings that are still valid
|
||||||
|
if (self._team_rankings_cache and
|
||||||
|
current_time - self._rankings_cache_timestamp < self._rankings_cache_duration):
|
||||||
|
return self._team_rankings_cache
|
||||||
|
|
||||||
|
try:
|
||||||
|
rankings_url = "https://site.api.espn.com/apis/site/v2/sports/football/college-football/rankings"
|
||||||
|
response = self.session.get(rankings_url, headers=self.headers, timeout=30)
|
||||||
|
response.raise_for_status()
|
||||||
|
data = response.json()
|
||||||
|
|
||||||
|
rankings = {}
|
||||||
|
rankings_data = data.get('rankings', [])
|
||||||
|
|
||||||
|
if rankings_data:
|
||||||
|
# Use the first ranking (usually AP Top 25)
|
||||||
|
first_ranking = rankings_data[0]
|
||||||
|
teams = first_ranking.get('ranks', [])
|
||||||
|
|
||||||
|
for team_data in teams:
|
||||||
|
team_info = team_data.get('team', {})
|
||||||
|
team_abbr = team_info.get('abbreviation', '')
|
||||||
|
current_rank = team_data.get('current', 0)
|
||||||
|
|
||||||
|
if team_abbr and current_rank > 0:
|
||||||
|
rankings[team_abbr] = current_rank
|
||||||
|
|
||||||
|
# Cache the results
|
||||||
|
self._team_rankings_cache = rankings
|
||||||
|
self._rankings_cache_timestamp = current_time
|
||||||
|
|
||||||
|
self.logger.debug(f"Fetched rankings for {len(rankings)} teams")
|
||||||
|
return rankings
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
self.logger.error(f"Error fetching team rankings: {e}")
|
||||||
|
return {}
|
||||||
|
|
||||||
def _get_timezone(self):
|
def _get_timezone(self):
|
||||||
try:
|
try:
|
||||||
@@ -1007,29 +1055,72 @@ class NCAAFBRecentManager(BaseNCAAFBManager): # Renamed class
|
|||||||
if 'odds' in game and game['odds']:
|
if 'odds' in game and game['odds']:
|
||||||
self._draw_dynamic_odds(draw_overlay, game['odds'], self.display_width, self.display_height)
|
self._draw_dynamic_odds(draw_overlay, game['odds'], self.display_width, self.display_height)
|
||||||
|
|
||||||
# Draw records if enabled
|
# Draw records or rankings if enabled
|
||||||
if self.show_records:
|
if self.show_records or self.show_ranking:
|
||||||
try:
|
try:
|
||||||
record_font = ImageFont.truetype("assets/fonts/4x6-font.ttf", 6)
|
record_font = ImageFont.truetype("assets/fonts/4x6-font.ttf", 6)
|
||||||
except IOError:
|
except IOError:
|
||||||
record_font = ImageFont.load_default()
|
record_font = ImageFont.load_default()
|
||||||
|
|
||||||
away_record = game.get('away_record', '')
|
# Get team abbreviations
|
||||||
home_record = game.get('home_record', '')
|
away_abbr = game.get('away_abbr', '')
|
||||||
|
home_abbr = game.get('home_abbr', '')
|
||||||
|
|
||||||
record_bbox = draw_overlay.textbbox((0,0), "0-0", font=record_font)
|
record_bbox = draw_overlay.textbbox((0,0), "0-0", font=record_font)
|
||||||
record_height = record_bbox[3] - record_bbox[1]
|
record_height = record_bbox[3] - record_bbox[1]
|
||||||
record_y = self.display_height - record_height
|
record_y = self.display_height - record_height
|
||||||
|
|
||||||
if away_record:
|
# Display away team info
|
||||||
away_record_x = 0
|
if away_abbr:
|
||||||
self._draw_text_with_outline(draw_overlay, away_record, (away_record_x, record_y), record_font)
|
if self.show_ranking:
|
||||||
|
# Show ranking if available
|
||||||
|
rankings = self._fetch_team_rankings()
|
||||||
|
away_rank = rankings.get(away_abbr, 0)
|
||||||
|
if away_rank > 0:
|
||||||
|
away_text = f"#{away_rank}"
|
||||||
|
elif self.show_records:
|
||||||
|
# Only show record if show_records is enabled
|
||||||
|
away_text = game.get('away_record', '')
|
||||||
|
else:
|
||||||
|
# Show nothing if show_records is false and team is unranked
|
||||||
|
away_text = ''
|
||||||
|
else:
|
||||||
|
# Show record only if show_records is enabled
|
||||||
|
if self.show_records:
|
||||||
|
away_text = game.get('away_record', '')
|
||||||
|
else:
|
||||||
|
away_text = ''
|
||||||
|
|
||||||
|
if away_text:
|
||||||
|
away_record_x = 0
|
||||||
|
self._draw_text_with_outline(draw_overlay, away_text, (away_record_x, record_y), record_font)
|
||||||
|
|
||||||
if home_record:
|
# Display home team info
|
||||||
home_record_bbox = draw_overlay.textbbox((0,0), home_record, font=record_font)
|
if home_abbr:
|
||||||
home_record_width = home_record_bbox[2] - home_record_bbox[0]
|
if self.show_ranking:
|
||||||
home_record_x = self.display_width - home_record_width
|
# Show ranking if available
|
||||||
self._draw_text_with_outline(draw_overlay, home_record, (home_record_x, record_y), record_font)
|
rankings = self._fetch_team_rankings()
|
||||||
|
home_rank = rankings.get(home_abbr, 0)
|
||||||
|
if home_rank > 0:
|
||||||
|
home_text = f"#{home_rank}"
|
||||||
|
elif self.show_records:
|
||||||
|
# Only show record if show_records is enabled
|
||||||
|
home_text = game.get('home_record', '')
|
||||||
|
else:
|
||||||
|
# Show nothing if show_records is false and team is unranked
|
||||||
|
home_text = ''
|
||||||
|
else:
|
||||||
|
# Show record only if show_records is enabled
|
||||||
|
if self.show_records:
|
||||||
|
home_text = game.get('home_record', '')
|
||||||
|
else:
|
||||||
|
home_text = ''
|
||||||
|
|
||||||
|
if home_text:
|
||||||
|
home_record_bbox = draw_overlay.textbbox((0,0), home_text, font=record_font)
|
||||||
|
home_record_width = home_record_bbox[2] - home_record_bbox[0]
|
||||||
|
home_record_x = self.display_width - home_record_width
|
||||||
|
self._draw_text_with_outline(draw_overlay, home_text, (home_record_x, record_y), record_font)
|
||||||
|
|
||||||
# Composite and display
|
# Composite and display
|
||||||
main_img = Image.alpha_composite(main_img, overlay)
|
main_img = Image.alpha_composite(main_img, overlay)
|
||||||
@@ -1245,29 +1336,72 @@ class NCAAFBUpcomingManager(BaseNCAAFBManager): # Renamed class
|
|||||||
if 'odds' in game and game['odds']:
|
if 'odds' in game and game['odds']:
|
||||||
self._draw_dynamic_odds(draw_overlay, game['odds'], self.display_width, self.display_height)
|
self._draw_dynamic_odds(draw_overlay, game['odds'], self.display_width, self.display_height)
|
||||||
|
|
||||||
# Draw records if enabled
|
# Draw records or rankings if enabled
|
||||||
if self.show_records:
|
if self.show_records or self.show_ranking:
|
||||||
try:
|
try:
|
||||||
record_font = ImageFont.truetype("assets/fonts/4x6-font.ttf", 6)
|
record_font = ImageFont.truetype("assets/fonts/4x6-font.ttf", 6)
|
||||||
except IOError:
|
except IOError:
|
||||||
record_font = ImageFont.load_default()
|
record_font = ImageFont.load_default()
|
||||||
|
|
||||||
away_record = game.get('away_record', '')
|
# Get team abbreviations
|
||||||
home_record = game.get('home_record', '')
|
away_abbr = game.get('away_abbr', '')
|
||||||
|
home_abbr = game.get('home_abbr', '')
|
||||||
|
|
||||||
record_bbox = draw_overlay.textbbox((0,0), "0-0", font=record_font)
|
record_bbox = draw_overlay.textbbox((0,0), "0-0", font=record_font)
|
||||||
record_height = record_bbox[3] - record_bbox[1]
|
record_height = record_bbox[3] - record_bbox[1]
|
||||||
record_y = self.display_height - record_height
|
record_y = self.display_height - record_height
|
||||||
|
|
||||||
if away_record:
|
# Display away team info
|
||||||
away_record_x = 0
|
if away_abbr:
|
||||||
self._draw_text_with_outline(draw_overlay, away_record, (away_record_x, record_y), record_font)
|
if self.show_ranking:
|
||||||
|
# Show ranking if available
|
||||||
|
rankings = self._fetch_team_rankings()
|
||||||
|
away_rank = rankings.get(away_abbr, 0)
|
||||||
|
if away_rank > 0:
|
||||||
|
away_text = f"#{away_rank}"
|
||||||
|
elif self.show_records:
|
||||||
|
# Only show record if show_records is enabled
|
||||||
|
away_text = game.get('away_record', '')
|
||||||
|
else:
|
||||||
|
# Show nothing if show_records is false and team is unranked
|
||||||
|
away_text = ''
|
||||||
|
else:
|
||||||
|
# Show record only if show_records is enabled
|
||||||
|
if self.show_records:
|
||||||
|
away_text = game.get('away_record', '')
|
||||||
|
else:
|
||||||
|
away_text = ''
|
||||||
|
|
||||||
|
if away_text:
|
||||||
|
away_record_x = 0
|
||||||
|
self._draw_text_with_outline(draw_overlay, away_text, (away_record_x, record_y), record_font)
|
||||||
|
|
||||||
if home_record:
|
# Display home team info
|
||||||
home_record_bbox = draw_overlay.textbbox((0,0), home_record, font=record_font)
|
if home_abbr:
|
||||||
home_record_width = home_record_bbox[2] - home_record_bbox[0]
|
if self.show_ranking:
|
||||||
home_record_x = self.display_width - home_record_width
|
# Show ranking if available
|
||||||
self._draw_text_with_outline(draw_overlay, home_record, (home_record_x, record_y), record_font)
|
rankings = self._fetch_team_rankings()
|
||||||
|
home_rank = rankings.get(home_abbr, 0)
|
||||||
|
if home_rank > 0:
|
||||||
|
home_text = f"#{home_rank}"
|
||||||
|
elif self.show_records:
|
||||||
|
# Only show record if show_records is enabled
|
||||||
|
home_text = game.get('home_record', '')
|
||||||
|
else:
|
||||||
|
# Show nothing if show_records is false and team is unranked
|
||||||
|
home_text = ''
|
||||||
|
else:
|
||||||
|
# Show record only if show_records is enabled
|
||||||
|
if self.show_records:
|
||||||
|
home_text = game.get('home_record', '')
|
||||||
|
else:
|
||||||
|
home_text = ''
|
||||||
|
|
||||||
|
if home_text:
|
||||||
|
home_record_bbox = draw_overlay.textbbox((0,0), home_text, font=record_font)
|
||||||
|
home_record_width = home_record_bbox[2] - home_record_bbox[0]
|
||||||
|
home_record_x = self.display_width - home_record_width
|
||||||
|
self._draw_text_with_outline(draw_overlay, home_text, (home_record_x, record_y), record_font)
|
||||||
|
|
||||||
# Composite and display
|
# Composite and display
|
||||||
main_img = Image.alpha_composite(main_img, overlay)
|
main_img = Image.alpha_composite(main_img, overlay)
|
||||||
|
|||||||
289
test/test_ranking_toggle.py
Normal file
289
test/test_ranking_toggle.py
Normal file
@@ -0,0 +1,289 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
"""
|
||||||
|
Test script to demonstrate the new ranking/record toggle functionality
|
||||||
|
for both the leaderboard manager and NCAA FB managers.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import os
|
||||||
|
import json
|
||||||
|
import time
|
||||||
|
from typing import Dict, Any
|
||||||
|
|
||||||
|
# Add the src directory to the path so we can import our modules
|
||||||
|
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..', 'src'))
|
||||||
|
|
||||||
|
from leaderboard_manager import LeaderboardManager
|
||||||
|
from ncaa_fb_managers import BaseNCAAFBManager
|
||||||
|
from cache_manager import CacheManager
|
||||||
|
from config_manager import ConfigManager
|
||||||
|
|
||||||
|
def test_leaderboard_ranking_toggle():
|
||||||
|
"""Test the leaderboard manager ranking toggle functionality."""
|
||||||
|
|
||||||
|
print("Testing Leaderboard Manager Ranking Toggle")
|
||||||
|
print("=" * 50)
|
||||||
|
|
||||||
|
# Create a mock display manager
|
||||||
|
class MockDisplayManager:
|
||||||
|
def __init__(self):
|
||||||
|
self.matrix = type('Matrix', (), {'width': 64, 'height': 32})()
|
||||||
|
self.image = None
|
||||||
|
self.draw = None
|
||||||
|
|
||||||
|
def update_display(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def set_scrolling_state(self, scrolling):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def process_deferred_updates(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
# Test configuration with show_ranking enabled
|
||||||
|
config_ranking_enabled = {
|
||||||
|
'leaderboard': {
|
||||||
|
'enabled': True,
|
||||||
|
'enabled_sports': {
|
||||||
|
'ncaa_fb': {
|
||||||
|
'enabled': True,
|
||||||
|
'top_teams': 10,
|
||||||
|
'show_ranking': True # Show rankings
|
||||||
|
}
|
||||||
|
},
|
||||||
|
'update_interval': 3600,
|
||||||
|
'scroll_speed': 2,
|
||||||
|
'scroll_delay': 0.05,
|
||||||
|
'display_duration': 60,
|
||||||
|
'loop': True,
|
||||||
|
'request_timeout': 30,
|
||||||
|
'dynamic_duration': True,
|
||||||
|
'min_duration': 30,
|
||||||
|
'max_duration': 300,
|
||||||
|
'duration_buffer': 0.1,
|
||||||
|
'time_per_team': 2.0,
|
||||||
|
'time_per_league': 3.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test configuration with show_ranking disabled
|
||||||
|
config_ranking_disabled = {
|
||||||
|
'leaderboard': {
|
||||||
|
'enabled': True,
|
||||||
|
'enabled_sports': {
|
||||||
|
'ncaa_fb': {
|
||||||
|
'enabled': True,
|
||||||
|
'top_teams': 10,
|
||||||
|
'show_ranking': False # Show records
|
||||||
|
}
|
||||||
|
},
|
||||||
|
'update_interval': 3600,
|
||||||
|
'scroll_speed': 2,
|
||||||
|
'scroll_delay': 0.05,
|
||||||
|
'display_duration': 60,
|
||||||
|
'loop': True,
|
||||||
|
'request_timeout': 30,
|
||||||
|
'dynamic_duration': True,
|
||||||
|
'min_duration': 30,
|
||||||
|
'max_duration': 300,
|
||||||
|
'duration_buffer': 0.1,
|
||||||
|
'time_per_team': 2.0,
|
||||||
|
'time_per_league': 3.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
try:
|
||||||
|
display_manager = MockDisplayManager()
|
||||||
|
|
||||||
|
# Test with ranking enabled
|
||||||
|
print("1. Testing with show_ranking = True")
|
||||||
|
leaderboard_manager = LeaderboardManager(config_ranking_enabled, display_manager)
|
||||||
|
ncaa_fb_config = leaderboard_manager.league_configs['ncaa_fb']
|
||||||
|
print(f" show_ranking config: {ncaa_fb_config.get('show_ranking', 'Not set')}")
|
||||||
|
|
||||||
|
standings = leaderboard_manager._fetch_standings(ncaa_fb_config)
|
||||||
|
if standings:
|
||||||
|
print(f" Fetched {len(standings)} teams")
|
||||||
|
print(" Top 5 teams with rankings:")
|
||||||
|
for i, team in enumerate(standings[:5]):
|
||||||
|
rank = team.get('rank', 'N/A')
|
||||||
|
record = team.get('record_summary', 'N/A')
|
||||||
|
print(f" {i+1}. {team['name']} ({team['abbreviation']}) - Rank: #{rank}, Record: {record}")
|
||||||
|
|
||||||
|
print("\n2. Testing with show_ranking = False")
|
||||||
|
leaderboard_manager = LeaderboardManager(config_ranking_disabled, display_manager)
|
||||||
|
ncaa_fb_config = leaderboard_manager.league_configs['ncaa_fb']
|
||||||
|
print(f" show_ranking config: {ncaa_fb_config.get('show_ranking', 'Not set')}")
|
||||||
|
|
||||||
|
standings = leaderboard_manager._fetch_standings(ncaa_fb_config)
|
||||||
|
if standings:
|
||||||
|
print(f" Fetched {len(standings)} teams")
|
||||||
|
print(" Top 5 teams with records:")
|
||||||
|
for i, team in enumerate(standings[:5]):
|
||||||
|
rank = team.get('rank', 'N/A')
|
||||||
|
record = team.get('record_summary', 'N/A')
|
||||||
|
print(f" {i+1}. {team['name']} ({team['abbreviation']}) - Rank: #{rank}, Record: {record}")
|
||||||
|
|
||||||
|
print("\n✓ Leaderboard ranking toggle test completed!")
|
||||||
|
return True
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
print(f"✗ Error testing leaderboard ranking toggle: {e}")
|
||||||
|
import traceback
|
||||||
|
traceback.print_exc()
|
||||||
|
return False
|
||||||
|
|
||||||
|
def test_ncaa_fb_ranking_toggle():
|
||||||
|
"""Test the NCAA FB manager ranking toggle functionality."""
|
||||||
|
|
||||||
|
print("\nTesting NCAA FB Manager Ranking Toggle")
|
||||||
|
print("=" * 50)
|
||||||
|
|
||||||
|
# Create a mock display manager
|
||||||
|
class MockDisplayManager:
|
||||||
|
def __init__(self):
|
||||||
|
self.matrix = type('Matrix', (), {'width': 64, 'height': 32})()
|
||||||
|
self.image = None
|
||||||
|
self.draw = None
|
||||||
|
|
||||||
|
def update_display(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def set_scrolling_state(self, scrolling):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def process_deferred_updates(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
# Test configurations
|
||||||
|
configs = [
|
||||||
|
{
|
||||||
|
'name': 'show_ranking=true, show_records=true',
|
||||||
|
'config': {
|
||||||
|
'ncaa_fb_scoreboard': {
|
||||||
|
'enabled': True,
|
||||||
|
'show_records': True,
|
||||||
|
'show_ranking': True,
|
||||||
|
'logo_dir': 'assets/sports/ncaa_fbs_logos',
|
||||||
|
'display_modes': {
|
||||||
|
'ncaa_fb_live': True,
|
||||||
|
'ncaa_fb_recent': True,
|
||||||
|
'ncaa_fb_upcoming': True
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'name': 'show_ranking=true, show_records=false',
|
||||||
|
'config': {
|
||||||
|
'ncaa_fb_scoreboard': {
|
||||||
|
'enabled': True,
|
||||||
|
'show_records': False,
|
||||||
|
'show_ranking': True,
|
||||||
|
'logo_dir': 'assets/sports/ncaa_fbs_logos',
|
||||||
|
'display_modes': {
|
||||||
|
'ncaa_fb_live': True,
|
||||||
|
'ncaa_fb_recent': True,
|
||||||
|
'ncaa_fb_upcoming': True
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'name': 'show_ranking=false, show_records=true',
|
||||||
|
'config': {
|
||||||
|
'ncaa_fb_scoreboard': {
|
||||||
|
'enabled': True,
|
||||||
|
'show_records': True,
|
||||||
|
'show_ranking': False,
|
||||||
|
'logo_dir': 'assets/sports/ncaa_fbs_logos',
|
||||||
|
'display_modes': {
|
||||||
|
'ncaa_fb_live': True,
|
||||||
|
'ncaa_fb_recent': True,
|
||||||
|
'ncaa_fb_upcoming': True
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'name': 'show_ranking=false, show_records=false',
|
||||||
|
'config': {
|
||||||
|
'ncaa_fb_scoreboard': {
|
||||||
|
'enabled': True,
|
||||||
|
'show_records': False,
|
||||||
|
'show_ranking': False,
|
||||||
|
'logo_dir': 'assets/sports/ncaa_fbs_logos',
|
||||||
|
'display_modes': {
|
||||||
|
'ncaa_fb_live': True,
|
||||||
|
'ncaa_fb_recent': True,
|
||||||
|
'ncaa_fb_upcoming': True
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
try:
|
||||||
|
display_manager = MockDisplayManager()
|
||||||
|
cache_manager = CacheManager()
|
||||||
|
|
||||||
|
for i, test_config in enumerate(configs, 1):
|
||||||
|
print(f"{i}. Testing: {test_config['name']}")
|
||||||
|
ncaa_fb_manager = BaseNCAAFBManager(test_config['config'], display_manager, cache_manager)
|
||||||
|
print(f" show_records: {ncaa_fb_manager.show_records}")
|
||||||
|
print(f" show_ranking: {ncaa_fb_manager.show_ranking}")
|
||||||
|
|
||||||
|
# Test fetching rankings
|
||||||
|
rankings = ncaa_fb_manager._fetch_team_rankings()
|
||||||
|
if rankings:
|
||||||
|
print(f" Fetched rankings for {len(rankings)} teams")
|
||||||
|
print(" Sample rankings:")
|
||||||
|
for j, (team_abbr, rank) in enumerate(list(rankings.items())[:3]):
|
||||||
|
print(f" {team_abbr}: #{rank}")
|
||||||
|
print()
|
||||||
|
|
||||||
|
print("✓ NCAA FB ranking toggle test completed!")
|
||||||
|
print("\nLogic Summary:")
|
||||||
|
print("- show_ranking=true, show_records=true: Shows #5 if ranked, 2-0 if unranked")
|
||||||
|
print("- show_ranking=true, show_records=false: Shows #5 if ranked, nothing if unranked")
|
||||||
|
print("- show_ranking=false, show_records=true: Shows 2-0 (record)")
|
||||||
|
print("- show_ranking=false, show_records=false: Shows nothing")
|
||||||
|
return True
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
print(f"✗ Error testing NCAA FB ranking toggle: {e}")
|
||||||
|
import traceback
|
||||||
|
traceback.print_exc()
|
||||||
|
return False
|
||||||
|
|
||||||
|
def main():
|
||||||
|
"""Main function to run all tests."""
|
||||||
|
print("NCAA Football Ranking/Record Toggle Test")
|
||||||
|
print("=" * 60)
|
||||||
|
print("This test demonstrates the new functionality:")
|
||||||
|
print("- Leaderboard manager can show poll rankings (#5) or records (2-0)")
|
||||||
|
print("- NCAA FB managers can show poll rankings (#5) or records (2-0)")
|
||||||
|
print("- Configuration controls which is displayed")
|
||||||
|
print()
|
||||||
|
|
||||||
|
try:
|
||||||
|
success1 = test_leaderboard_ranking_toggle()
|
||||||
|
success2 = test_ncaa_fb_ranking_toggle()
|
||||||
|
|
||||||
|
if success1 and success2:
|
||||||
|
print("\n🎉 All tests passed! The ranking/record toggle is working correctly.")
|
||||||
|
print("\nConfiguration Summary:")
|
||||||
|
print("- Set 'show_ranking': true in config to show poll rankings (#5)")
|
||||||
|
print("- Set 'show_ranking': false in config to show season records (2-0)")
|
||||||
|
print("- Works in both leaderboard and NCAA FB scoreboard managers")
|
||||||
|
else:
|
||||||
|
print("\n❌ Some tests failed. Please check the errors above.")
|
||||||
|
except KeyboardInterrupt:
|
||||||
|
print("\nTest interrupted by user")
|
||||||
|
except Exception as e:
|
||||||
|
print(f"Error running tests: {e}")
|
||||||
|
import traceback
|
||||||
|
traceback.print_exc()
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
Reference in New Issue
Block a user