Exemplo n.º 1
0
 def test_3stmt_op(self):
     prg1 = "havoc x; assume x > 10; assert x < 15"
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 2
0
 def test_Bexp(self):
     prg1 = "x := -1; y := 3; if x = y or x >= y and not false then skip"
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 3
0
 def test_if(self):
     prg1 = "havoc x ; if x > 10 then x := x + 1 else x := x+2 "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 2)
Exemplo n.º 4
0
 def test_While_noinv2(self):
     prg1 = "havoc x; while x<=5  do x:=x-1 "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 5
0
 def test_While_inv(self):
     prg1 = "havoc x,y; assume y >= 0; c:= 0; r:= x; while c<y inv c <= y  and r = x + c do { r:= r+1; c:= c+1 }; assert r= x+y "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 6
0
 def test_assert_error(self):
     prg1 = "x:=10; y := 11; assert y = x "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 0)
Exemplo n.º 7
0
 def test_bexp_skip(self):
     prg1 = "x := 0 ; y:= 0; if x=y then skip; print_state y "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 8
0
 def test_aexp_twoHavoc2(self):
     prg1 = " x := 0; y := 1; if x>y+1 then x := 100"
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 9
0
 def test_aexp_twoHavoc(self):
     prg1 = "havoc x, y; x := x * ( x/y - 3) + 0  ; while x > y do x := x - 1"
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 11)
Exemplo n.º 10
0
 def test_solver(self):
     prg1 = "havoc x; while x<=5  do x:=x-1 "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     import z3
     st = _sym_.SymState(z3.Solver())
     out = [s for s in sym.run(ast1, st)]
     self.assertEquals(len(out), 1)
Exemplo n.º 11
0
 def test_While3(self):
     prg1 = "x := 7; while x>5  do x:=x-1 "
     ast1 = _ast_.parse_string(prg1)
     sym = _sym_.SymExec()
     st = _sym_.SymState()
     out = [s for s in sym.run(ast1, st)]
     self.assertIsNotNone(st.to_smt2())
     self.assertEquals(len(out), 1)