import os
import sys
import time

sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
print(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
from util import get_input_dim
from typing import List
from action_freezer import ActionFreezer
from informal_verifier import Verifier, informal_verify
from generate_combs import Info, generate_all_combs, generate_all_combs_nocrash
from utils import parse_arg
from filter_combs import filter_combs


def evaluate(opt, all_combs):
    freezer = ActionFreezer(opt.protocol, enable_freeze=opt.freeze)
    all_combs_id = range(len(all_combs))
    if opt.test_id is not None:
        test_list = [opt.test_id]
        print(all_combs[test_list[0]])
        num_process = 1
    else:
        test_list = all_combs_id
        num_process = 8

    v = Verifier(num_process, all_combs, freezer)
    s = time.time()
    pass_all, failed_cases = informal_verify(
        opt,
        opt.load_dir,
        get_input_dim(opt),
        v,
        v.all_combs,
        test_list,
        v.num_process,
        is_testall=True,
        is_log=False,
        is_verbose=opt.verbose,
        is_gt=opt.gt,
    )
    e = time.time()
    print(f"elapsed time: {e - s} seconds")
    return pass_all, failed_cases


def main():
    opt = parse_arg()
    print(opt)
    if opt.protocol == "distributed_locking":
        all_combs: List[Info] = generate_all_combs_nocrash(opt.players, opt.rounds)
    else:
        all_combs: List[Info] = generate_all_combs(range(2**opt.players), opt.players, opt.rounds)
    pass_all, failed_cases = evaluate(opt, all_combs)
    print(f"pass_all: {pass_all}")
    print(f"failed_cases: {len(failed_cases)}")
    if opt.verbose:
        for case in failed_cases:
            print(case)


if __name__ == "__main__":
    main()
