import numpy as np
import tensorflow as tf
import matplotlib
matplotlib.use('agg')
import matplotlib.pyplot as plt
import subprocess
import os
import json
import pandas as pd
import argparse
import time


query_configurations = [
    [1, 2, 3, 4, 5],             
    [13, 14, 15, 16, 17, 18, 19, 20, 21, 22],   
    [1, 3, 5, 7, 9, 11, 13, 15, 17, 19],        
    [2, 4, 6, 8, 10, 12, 14, 16, 18, 20],       
    [1, 4, 7, 10, 13, 16, 19, 22, 2, 5],       
    [3, 6, 9, 12, 15, 18, 21, 1, 8, 11],         
    [2, 5, 8, 11, 14, 17, 20, 3, 6, 9],          
    [1, 5, 9, 13, 17, 21, 2, 6, 10, 14],         
    [3, 7, 11, 15, 19, 4, 8, 12, 16, 20],        
    [1, 6, 11, 16, 21, 3, 8, 13, 18, 22]         
]

def main():

    parser = argparse.ArgumentParser(description='Run tests for a specific configuration')
    parser.add_argument('--exec_cap', type=int, default=10,
                        help='Number of total executors')
    parser.add_argument('--init_stream_config', type=str, default="1_0",
                        help='Configuration of initial and streaming DAGs (e.g., 1_0, 2_0, 1_1)')
    parser.add_argument('--config_idx', type=int, default=0,
                        help='Index of the query configuration to use (0-9)')
    parser.add_argument('--test_schemes', type=str, default='dynamic_partition',
                        help='Test schemes to evaluate (comma-separated)')
    parser.add_argument('--query_size', type=str, default="10g",
                        help='Query size to use')
    parser.add_argument('--num_exp', type=int, default=1,
                        help='Number of experiments')
    args = parser.parse_args()
    

    num_init_dags, num_stream_dags = map(int, args.init_stream_config.split('_'))
    



    first_config = query_configurations[args.config_idx]
    second_config = first_config 
    config_name = f"config_{args.config_idx}"

    

    result_folder = f"results/group_test_results/{args.exec_cap}_{args.init_stream_config}/{config_name}/{args.test_schemes}"
    if not os.path.exists(result_folder):
        os.makedirs(result_folder)
    

    if not os.path.exists('log'):
        os.makedirs('log')
    

    all_results = {scheme: [] for scheme in args.test_schemes.split(',')}
    

    for i in range(len(first_config)):
        first_query_idx = first_config[i]
        second_query_idx = second_config[i]
        
        print(f"\n===== Running {args.init_stream_config}, {config_name}, exec_cap={args.exec_cap}, first_query={first_query_idx}, second_query={second_query_idx} =====")
        
  
        cmd = [
            "python", "test.py",
            "--test_schemes", args.test_schemes,
            "--exec_cap", str(args.exec_cap),
            "--num_init_dags", str(num_init_dags),
            "--num_stream_dags", str(num_stream_dags),
            "--deterministic=True",
            "--num_exp", str(args.num_exp),
            "--first_job_query_idx", str(first_query_idx),
            "--first_job_query_size", args.query_size,
            "--second_job_query_idx", str(second_query_idx),
            "--second_job_query_size", args.query_size
        ]
        
     
        process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
        stdout, stderr = process.communicate()
        

if __name__ == "__main__":
    main()