1
1
mirror of https://github.com/anoma/juvix.git synced 2025-01-07 08:08:44 +03:00
juvix/test/Scope/Positive.hs

221 lines
7.3 KiB
Haskell
Raw Normal View History

2022-02-18 15:01:42 +03:00
module Scope.Positive where
import Base
2022-04-05 20:57:21 +03:00
import Data.HashMap.Strict qualified as HashMap
import Juvix.Compiler.Builtins (iniState)
import Juvix.Compiler.Concrete qualified as Concrete
import Juvix.Compiler.Concrete.Extra
import Juvix.Compiler.Concrete.Pretty qualified as M
import Juvix.Compiler.Concrete.Print qualified as P
2022-12-20 15:05:40 +03:00
import Juvix.Compiler.Concrete.Translation.FromParsed.Analysis.PathResolver
import Juvix.Compiler.Concrete.Translation.FromParsed.Analysis.Scoping qualified as Scoper
import Juvix.Compiler.Concrete.Translation.FromSource qualified as Parser
import Juvix.Compiler.Pipeline
import Juvix.Compiler.Pipeline.Setup
2022-12-20 15:05:40 +03:00
import Juvix.Prelude.Aeson
import Juvix.Prelude.Pretty
2022-02-18 15:01:42 +03:00
2022-04-05 20:57:21 +03:00
data PosTest = PosTest
2022-04-07 19:10:53 +03:00
{ _name :: String,
2022-12-20 15:05:40 +03:00
_relDir :: Path Rel Dir,
_file :: Path Rel File
2022-02-18 15:01:42 +03:00
}
2022-04-07 19:10:53 +03:00
makeLenses ''PosTest
2022-12-20 15:05:40 +03:00
root :: Path Abs Dir
root = relToProject $(mkRelDir "tests/positive")
2022-02-18 15:01:42 +03:00
renderCodeOld :: M.PrettyCode c => c -> Text
renderCodeOld = prettyText . M.ppOutDefault
renderCodeNew :: (HasLoc c, P.PrettyPrint c) => c -> Text
renderCodeNew = prettyText . P.ppOutDefault emptyComments
2022-12-20 15:05:40 +03:00
type Pipe =
'[ PathResolver,
Reader EntryPoint,
Files,
NameIdGen,
Error JuvixError,
Reader GenericOptions,
Embed IO
]
testDescr :: PosTest -> [TestDescr]
testDescr PosTest {..} = helper renderCodeOld "" : [helper renderCodeNew " (with comments)"]
where
helper :: (forall c. (HasLoc c, P.PrettyPrint c, M.PrettyCode c) => c -> Text) -> String -> TestDescr
helper renderer tag =
let tRoot = root <//> _relDir
file' = tRoot <//> _file
in TestDescr
{ _testName = _name <> tag,
_testRoot = tRoot,
_testAssertion = Steps $ \step -> do
pkg <- readPackageIO tRoot (rootBuildDir tRoot)
let entryPoint = entryPointFromPackage tRoot file' pkg
runHelper :: HashMap (Path Abs File) Text -> Sem Pipe a -> IO (ResolverState, a)
runHelper files =
runM
. runErrorIO' @JuvixError
. runNameIdGen
. runFilesPure files tRoot
. runReader entryPoint
. runPathResolverPipe
evalHelper :: HashMap (Path Abs File) Text -> Sem Pipe a -> IO a
evalHelper files = fmap snd . runHelper files
step "Parsing"
p :: Parser.ParserResult <- snd <$> runIO' iniState entryPoint upToParsing
step "Scoping"
(artif :: Artifacts, s :: Scoper.ScoperResult) <-
runIO'
iniState
entryPoint
( do
void entrySetup
Concrete.fromParsed p
)
let yamlFiles :: [(Path Abs File, Text)]
yamlFiles =
[ (pkgi ^. packageRoot <//> juvixYamlFile, encodeToText (rawPackage (pkgi ^. packagePackage)))
| pkgi <- toList (artif ^. artifactResolver . resolverPackages)
]
fsScoped :: HashMap (Path Abs File) Text
fsScoped =
HashMap.fromList $
[ (getModuleFilePath m, renderer m)
| m <- toList (s ^. Scoper.resultScoperTable . Scoper.infoModules)
]
<> yamlFiles
fsParsed :: HashMap (Path Abs File) Text
fsParsed =
HashMap.fromList $
[ (getModuleFilePath m, renderCodeOld m)
| m <- toList (p ^. Parser.resultTable . Parser.infoParsedModules)
]
<> yamlFiles
step "Parsing pretty scoped"
p' :: Parser.ParserResult <- evalHelper fsScoped upToParsing
step "Parsing pretty parsed"
parsedPretty' :: Parser.ParserResult <- evalHelper fsParsed upToParsing
step "Scoping the scoped"
s' :: Scoper.ScoperResult <- evalHelper fsScoped upToScoping
step "Checks"
let smodules = s ^. Scoper.resultModules
smodules' = s' ^. Scoper.resultModules
let pmodules = p ^. Parser.resultModules
pmodules' = p' ^. Parser.resultModules
parsedPrettyModules = parsedPretty' ^. Parser.resultModules
assertEqDiff "check: scope . parse . pretty . scope . parse = scope . parse" smodules smodules'
assertEqDiff "check: parse . pretty . scope . parse = parse" pmodules pmodules'
assertEqDiff "check: parse . pretty . parse = parse" pmodules parsedPrettyModules
}
2022-02-18 15:01:42 +03:00
allTests :: TestTree
2022-04-05 20:57:21 +03:00
allTests =
testGroup
"Scope positive tests"
(map mkTest (concatMap testDescr tests))
2022-02-18 15:01:42 +03:00
tests :: [PosTest]
2022-04-05 20:57:21 +03:00
tests =
[ PosTest
"Inductive"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Inductive.juvix"),
PosTest
"Pipes symbol as possible prefix for each data constructor"
$(mkRelDir ".")
$(mkRelFile "InductivePipes.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Imports and qualified names"
2022-12-20 15:05:40 +03:00
$(mkRelDir "Imports")
$(mkRelFile "A.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Data.Bool from the stdlib"
2022-12-20 15:05:40 +03:00
$(mkRelDir "StdlibList")
$(mkRelFile "Data/Bool.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Data.Nat from the stdlib"
2022-12-20 15:05:40 +03:00
$(mkRelDir "StdlibList")
$(mkRelFile "Data/Nat.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Data.Ord from the stdlib"
2022-12-20 15:05:40 +03:00
$(mkRelDir "StdlibList")
$(mkRelFile "Data/Ord.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Data.Product from the stdlib"
2022-12-20 15:05:40 +03:00
$(mkRelDir "StdlibList")
$(mkRelFile "Data/Product.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Data.List and friends from the stdlib"
2022-12-20 15:05:40 +03:00
$(mkRelDir "StdlibList")
$(mkRelFile "Data/List.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Operators (+)"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Operators.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Literals"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Literals.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Axiom with backends"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Axiom.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Foreign block parsing"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Foreign.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Multiple modules non-ambiguous symbol - same file"
2022-12-20 15:05:40 +03:00
$(mkRelDir "QualifiedSymbol")
$(mkRelFile "M.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Multiple modules non-ambiguous symbol"
2022-12-20 15:05:40 +03:00
$(mkRelDir "QualifiedSymbol2")
$(mkRelFile "N.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"Multiple modules constructor non-ambiguous symbol"
2022-12-20 15:05:40 +03:00
$(mkRelDir "QualifiedConstructor")
$(mkRelFile "M.juvix"),
PosTest
"Parsing"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Parsing.juvix"),
2022-04-05 20:57:21 +03:00
PosTest
"open overrides open public"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "ShadowPublicOpen.juvix"),
PosTest
"Infix chains"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Ape.juvix"),
PosTest
"Import embedded standard library"
2022-12-20 15:05:40 +03:00
$(mkRelDir "StdlibImport")
$(mkRelFile "StdlibImport.juvix"),
PosTest
"Basic dependencies"
$(mkRelDir "Dependencies")
$(mkRelFile "Input.juvix"),
PosTest
"Check Valid Symbols"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "Symbols.juvix"),
PosTest
"Builtin bool"
2022-12-20 15:05:40 +03:00
$(mkRelDir ".")
$(mkRelFile "BuiltinsBool.juvix")
2022-04-05 20:57:21 +03:00
]