{-# LANGUAGE ScopedTypeVariables #-} module TestNoAssoc ( noAssocTests, mkNoAssocTests ) where import Data.List import System.FilePath ( () ) import qualified Test.Tasty as TT import Test.Tasty.HUnit import Test.Tasty.Runners ( testsNames ) import Test.Tasty.Sugar import TestUtils import Sample1 ( sample1 ) testInpPath = "tests/samples" sugarCube = mkCUBE { rootName = "*.c" , expectedSuffix = "expected" , inputDir = testInpPath , associatedNames = [] , validParams = [ ("arch", Just ["x86", "ppc"]) , ("form", Just ["base", "refined"]) ] } noAssocTests :: [TT.TestTree] noAssocTests = let (sugar1,s1desc) = findSugarIn sugarCube sample1 in [ -- This is simply the number of entries in sample1; if this -- fails in means that sample1 has been changed and the other -- tests here are likely to need updating. testCase "valid sample" $ 58 @=? length sample1 , sugarTestEq "correct found count" sugarCube sample1 6 length , testCase "results" $ compareBags "results" sugar1 $ let p = (testInpPath ) in [ Sweets { rootMatchName = "global-max-good.c" , rootBaseName = "global-max-good" , rootFile = p "global-max-good.c" , cubeParams = validParams sugarCube , expected = [ Expectation { expectedFile = p "global-max-good.x86.expected" , expParamsMatch = [("arch", Explicit "x86"), ("form", Assumed "base")] , associated = [] } , Expectation { expectedFile = p "global-max-good.x86.expected" , expParamsMatch = [("arch", Explicit "x86"), ("form", Assumed "refined")] , associated = [] } , Expectation { expectedFile = p "global-max-good.ppc.expected" , expParamsMatch = [("arch", Explicit "ppc"), ("form", Assumed "base")] , associated = [] } , Expectation { expectedFile = p "global-max-good.ppc.expected" , expParamsMatch = [("arch", Explicit "ppc"), ("form", Assumed "refined")] , associated = [] } ] } , Sweets { rootMatchName = "jumpfar.c" , rootBaseName = "jumpfar" , rootFile = p "jumpfar.c" , cubeParams = validParams sugarCube , expected = [ Expectation { expectedFile = p "jumpfar.x86.expected" , expParamsMatch = [ ("arch", Explicit "x86") , ("form", Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "jumpfar.x86.expected" , expParamsMatch = [ ("arch", Explicit "x86") , ("form", Assumed "refined")] , associated = [] } , Expectation { expectedFile = p "jumpfar.ppc.expected" , expParamsMatch = [ ("arch" , Explicit "ppc") , ("form" , Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "jumpfar.ppc.expected" , expParamsMatch = [ ("arch" , Explicit "ppc") , ("form" , Assumed "refined") ] , associated = [] } ] } , Sweets { rootMatchName = "looping.c" , rootBaseName = "looping" , rootFile = p "looping.c" , cubeParams = validParams sugarCube , expected = [ Expectation { expectedFile = p "looping.x86.expected" , expParamsMatch = [ ("arch", Explicit "x86") , ("form", Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "looping.x86.expected" , expParamsMatch = [ ("arch", Explicit "x86") , ("form", Assumed "refined")] , associated = [] } , Expectation { expectedFile = p "looping.ppc.expected" , expParamsMatch = [ ("arch" , Explicit "ppc") , ("form" , Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "looping.ppc.expected" , expParamsMatch = [ ("arch" , Explicit "ppc") , ("form" , Assumed "refined") ] , associated = [] } ] } , Sweets { rootMatchName = "looping-around.c" , rootBaseName = "looping-around" , rootFile = p "looping-around.c" , cubeParams = validParams sugarCube , expected = [ Expectation { expectedFile = p "looping-around.expected" , expParamsMatch = [ ("arch", Assumed "x86") , ("form", Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "looping-around.expected" , expParamsMatch = [ ("arch", Assumed "x86") , ("form", Assumed "refined")] , associated = [] } , Expectation { expectedFile = p "looping-around.ppc.expected" , expParamsMatch = [ ("arch" , Explicit "ppc") , ("form" , Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "looping-around.ppc.expected" , expParamsMatch = [ ("arch" , Explicit "ppc") , ("form" , Assumed "refined") ] , associated = [] } ] } , Sweets { rootMatchName = "switching.c" , rootBaseName = "switching" , rootFile = p "switching.c" , cubeParams = validParams sugarCube , expected = [ Expectation { expectedFile = p "switching.x86.base-expected" , expParamsMatch = [ ("form", Explicit "base") , ("arch", Explicit "x86") ] , associated = [] } , Expectation { expectedFile = p "switching.ppc.base-expected" , expParamsMatch = [ ("form", Explicit "base") , ("arch", Explicit "ppc") ] , associated = [] } , Expectation { expectedFile = p "switching.x86.refined-expected" , expParamsMatch = [ ("form", Explicit "refined") , ("arch", Explicit "x86") ] , associated = [] } ] } , Sweets { rootMatchName = "tailrecurse.c" , rootBaseName = "tailrecurse" , rootFile = p "tailrecurse.c" , cubeParams = validParams sugarCube , expected = [ Expectation { expectedFile = p "tailrecurse.x86.expected" , expParamsMatch = [ ("arch", Explicit "x86"), ("form", Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "tailrecurse.x86.expected" , expParamsMatch = [ ("arch", Explicit "x86") , ("form", Assumed "refined") ] , associated = [] } , Expectation { expectedFile = p "tailrecurse.expected" , expParamsMatch = [ ("arch", Assumed "ppc"), ("form", Assumed "base") ] , associated = [] } , Expectation { expectedFile = p "tailrecurse.expected" , expParamsMatch = [ ("arch", Assumed "ppc") , ("form", Assumed "refined") ] , associated = [] } ] } ] ] mkNoAssocTests :: IO [TT.TestTree] mkNoAssocTests = let (sugar1,s1desc) = findSugarIn sugarCube sample1 in do tt <- withSugarGroups sugar1 TT.testGroup $ \sw idx exp -> -- Verify this will suppress the "refined" tests for -- "looping-around.c" if (rootMatchName sw == "looping-around.c" && Just (Assumed "refined") == lookup "form" (expParamsMatch exp)) then (return []) else return [ testCase (rootMatchName sw <> "." <> show idx) $ return () ] return $ (testCase "generated count" $ 21 @=? length (concatMap (testsNames mempty) tt)) : tt