#!/usr/bin/env python3
"""
测试filter_groups修复
"""

def test_metric_handling():
    """测试不同metric_name的处理"""
    
    # 模拟配置
    configs = [
        {"metric": "seq_final_reward", "expected": "seq_final_reward"},
        {"metric": "seq_reward", "expected": "seq_reward"},
        {"metric": "acc", "expected": "acc"},
        {"metric": "unknown_metric", "expected": "seq_final_reward"},
    ]
    
    print("测试metric_name处理逻辑:")
    print("=" * 50)
    
    for config in configs:
        metric_name = config["metric"]
        expected = config["expected"]
        
        # 模拟处理逻辑
        if metric_name == "seq_final_reward":
            result = "seq_final_reward"
        elif metric_name == "seq_reward":
            result = "seq_reward"
        elif metric_name == "acc":
            result = "acc"
        else:
            result = "seq_final_reward"  # fallback
        
        status = "✅" if result == expected else "❌"
        print(f"{status} {metric_name} -> {result} (expected: {expected})")
    
    print("\n修复说明:")
    print("- 将debug脚本中的metric从'acc'改为'seq_final_reward'")
    print("- 代码中添加了对'acc'的支持（如果存在）")
    print("- 添加了fallback机制处理未知metric")

if __name__ == "__main__":
    test_metric_handling()
