From 933fbe76f989ee96bf8021334032788f450b9ea4 Mon Sep 17 00:00:00 2001 From: ajfAfg <56056962+ajfAfg@users.noreply.github.com> Date: Wed, 3 Jan 2024 17:30:59 +0900 Subject: [PATCH] Test `solve_in_exp_time_with_correctness` for the special case --- ...all_local_minimum_vertex_splitters_solver.erl | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/test/prop_all_local_minimum_vertex_splitters_solver.erl b/test/prop_all_local_minimum_vertex_splitters_solver.erl index dff0502..1d624e2 100644 --- a/test/prop_all_local_minimum_vertex_splitters_solver.erl +++ b/test/prop_all_local_minimum_vertex_splitters_solver.erl @@ -86,3 +86,19 @@ prop_solve_in_exp_time_with_correctness3() -> end, all_local_minimum_vertex_splitters_solver:solve_in_exp_time_with_correctness(ConnectedDAG)) end). + +prop_solve_in_exp_time_with_correctness4(doc) -> + "The return value equals the vertices of the argument graph if only one entrance vertex". + +prop_solve_in_exp_time_with_correctness4() -> + ?FORALL(ConnectedDAG, + dependency_connected_dag(), + begin + ?IMPLIES(length([V + || V <- digraph:vertices(ConnectedDAG), + digraph:in_degree(ConnectedDAG, V) =:= 0]) + =:= 1, + lists:sort( + digraph:vertices(ConnectedDAG)) + =:= lists:sort(hd(all_local_minimum_vertex_splitters_solver:solve_in_exp_time_with_correctness(ConnectedDAG)))) + end).