----------------------------------------------------------------------------- -- | -- Module : TestSuite.Queries.Int_Mathsat -- Copyright : (c) Levent Erkok -- License : BSD3 -- Maintainer: erkokl@gmail.com -- Stability : experimental -- -- Testing MathSAT specific interactive features. ----------------------------------------------------------------------------- {-# LANGUAGE ScopedTypeVariables #-} module TestSuite.Queries.Int_Mathsat (tests) where import Data.SBV.Control import Control.Monad (unless) import Utils.SBVTestFramework -- Test suite tests :: TestTree tests = testGroup "Basics.QueryIndividual" [ goldenCapturedIO "query_mathsat" $ \rf -> runSMTWith mathSAT{verbose=True, redirectVerbose=Just rf} q ] q :: Symbolic () q = do a <- sInt32 "a" b <- sInt32 "b" namedConstraint "a > 0" $ a .> 0 constrain $ b .> 0 query $ do constrain $ a+2 .<= 15 constrain $ a .< 3 constrain $ b .< 2 namedConstraint "a+b_<_12" $ a+b .< 12 constrain $ a .< 2 cs <- checkSat case cs of Sat -> return () Unk -> getInfo ReasonUnknown >>= error . show r -> error $ "Something went bad, why not-sat/unk?: " ++ show r -- Now assert so that we get even a bigger value.. namedConstraint "extra" $ a .>= 1 _ <- checkSat res <- (,) <$> getValue a <*> getValue b unless (res == (1, 1)) $ error $ "Didn't get (1,1): " ++ show res