import pytest

from evaluation.smoothing_measures.mad_gap import bfs_all_distances


def test_single_node():
    adj = [[]]  # One node, no edges
    assert bfs_all_distances(adj, 0) == [0]


def test_two_connected_nodes():
    adj = [[1], [0]]  # Two nodes connected
    assert bfs_all_distances(adj, 0) == [0, 1]
    assert bfs_all_distances(adj, 1) == [1, 0]


def test_disconnected_graph():
    adj = [[1], [0], []]  # Third node disconnected
    assert bfs_all_distances(adj, 0) == [0, 1, -1]
    assert bfs_all_distances(adj, 2) == [-1, -1, 0]


def test_line_graph():
    adj = [[1], [0, 2], [1, 3], [2]]  # 0 - 1 - 2 - 3
    assert bfs_all_distances(adj, 0) == [0, 1, 2, 3]
    assert bfs_all_distances(adj, 3) == [3, 2, 1, 0]


def test_star_graph():
    adj = [[1, 2, 3], [0], [0], [0]]  # Star centered at node 0
    assert bfs_all_distances(adj, 0) == [0, 1, 1, 1]
    assert bfs_all_distances(adj, 1) == [1, 0, 2, 2]


def test_cycle_graph():
    adj = [[1, 3], [0, 2], [1, 3], [0, 2]]  # 0-1-2-3-0
    assert bfs_all_distances(adj, 0) == [0, 1, 2, 1]
    assert bfs_all_distances(adj, 2) == [2, 1, 0, 1]


def test_graph_with_isolated_nodes():
    adj = [[1], [0], [], [4], [3]]  # Two components: 0-1 and 3-4, plus isolated node 2
    assert bfs_all_distances(adj, 0) == [0, 1, -1, -1, -1]
    assert bfs_all_distances(adj, 3) == [-1, -1, -1, 0, 1]