package alice.tuprolog;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
import org.junit.Before;
import org.junit.Test;
public class IfThenTest {
Prolog engine;
@Before
public void setUp() {
engine = new Prolog();
}
@Test public void ifTrueThenTrue() throws PrologException {
SolveInfo solution = engine.solve("'->'(true, true).");
assertTrue(solution.isSuccess());
}
@Test public void ifTrueThenFail() throws PrologException {
SolveInfo solution = engine.solve("'->'(true, fail).");
assertFalse(solution.isSuccess());
}
@Test public void ifFailThenTrue() throws PrologException {
SolveInfo solution = engine.solve("'->'(fail, true).");
assertFalse(solution.isSuccess());
}
@Test public void noReexecution() throws PrologException {
SolveInfo solution = engine.solve("'->'(true, X=1).");
assertTrue(solution.isSuccess());
assertEquals(new Int(1), solution.getTerm("X"));
assertFalse(engine.hasOpenAlternatives());
}
@Test public void noReexecutionWithDisjunctiveCondition() throws PrologException {
SolveInfo solution = engine.solve("'->'(';'(X=1, X=2), true).");
assertTrue(solution.isSuccess());
assertEquals(new Int(1), solution.getTerm("X"));
assertFalse(engine.hasOpenAlternatives());
}
@Test public void reexecutionWithDisjunctiveBody() throws PrologException {
SolveInfo solution = engine.solve("'->'(true, ';'(X=1, X=2)).");
assertTrue(solution.isSuccess());
assertEquals(new Int(1), solution.getTerm("X"));
solution = engine.solveNext();
assertTrue(solution.isSuccess());
assertEquals(new Int(2), solution.getTerm("X"));
assertFalse(engine.hasOpenAlternatives());
}
}