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
|
2022-08-03 14:20:40 +03:00
|
|
|
import Juvix.Compiler.Concrete qualified as Concrete
|
|
|
|
import Juvix.Compiler.Concrete.Extra
|
|
|
|
import Juvix.Compiler.Concrete.Pretty qualified as M
|
|
|
|
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-07-08 14:59:45 +03:00
|
|
|
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,
|
|
|
|
_relDir :: FilePath,
|
2022-06-30 12:31:08 +03:00
|
|
|
_stdlibMode :: StdlibMode,
|
2022-04-07 19:10:53 +03:00
|
|
|
_file :: FilePath
|
2022-02-18 15:01:42 +03:00
|
|
|
}
|
|
|
|
|
2022-04-07 19:10:53 +03:00
|
|
|
makeLenses ''PosTest
|
|
|
|
|
2022-02-18 15:01:42 +03:00
|
|
|
root :: FilePath
|
|
|
|
root = "tests/positive"
|
|
|
|
|
2022-05-18 18:10:10 +03:00
|
|
|
renderCode :: M.PrettyCode c => c -> Text
|
|
|
|
renderCode = prettyText . M.ppOutDefault
|
|
|
|
|
2022-02-18 15:01:42 +03:00
|
|
|
testDescr :: PosTest -> TestDescr
|
2022-04-05 20:57:21 +03:00
|
|
|
testDescr PosTest {..} =
|
2022-04-08 13:46:37 +03:00
|
|
|
let tRoot = root </> _relDir
|
2022-04-07 19:10:53 +03:00
|
|
|
in TestDescr
|
|
|
|
{ _testName = _name,
|
2022-04-08 13:46:37 +03:00
|
|
|
_testRoot = tRoot,
|
2022-04-07 19:10:53 +03:00
|
|
|
_testAssertion = Steps $ \step -> do
|
2022-05-13 17:17:26 +03:00
|
|
|
cwd <- getCurrentDirectory
|
2022-06-15 13:38:24 +03:00
|
|
|
entryFile <- canonicalizePath _file
|
2022-06-30 12:31:08 +03:00
|
|
|
let noStdlib = _stdlibMode == StdlibExclude
|
|
|
|
entryPoint =
|
2022-08-19 17:57:07 +03:00
|
|
|
(defaultEntryPoint entryFile)
|
2022-06-30 12:31:08 +03:00
|
|
|
{ _entryPointRoot = cwd,
|
2022-08-19 17:57:07 +03:00
|
|
|
_entryPointNoStdlib = noStdlib
|
2022-06-30 12:31:08 +03:00
|
|
|
}
|
|
|
|
stdlibMap :: HashMap FilePath Text
|
|
|
|
stdlibMap = HashMap.mapKeys (cwd </>) (HashMap.fromList stdlibDir)
|
|
|
|
unionStdlib :: HashMap FilePath Text -> HashMap FilePath Text
|
|
|
|
unionStdlib fs
|
|
|
|
| noStdlib = fs
|
|
|
|
| otherwise = HashMap.union fs stdlibMap
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
step "Parsing"
|
2022-09-14 17:16:15 +03:00
|
|
|
p :: Parser.ParserResult <- runIO' entryPoint upToParsing
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
let p2 = head (p ^. Parser.resultModules)
|
|
|
|
|
|
|
|
step "Scoping"
|
2022-06-30 12:31:08 +03:00
|
|
|
s :: Scoper.ScoperResult <-
|
2022-09-01 14:22:32 +03:00
|
|
|
runIO'
|
2022-09-14 17:16:15 +03:00
|
|
|
entryPoint
|
2022-06-30 12:31:08 +03:00
|
|
|
( do
|
2022-09-14 17:16:15 +03:00
|
|
|
void entrySetup
|
2022-08-03 14:20:40 +03:00
|
|
|
Concrete.fromParsed p
|
2022-06-30 12:31:08 +03:00
|
|
|
)
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
let s2 = head (s ^. Scoper.resultModules)
|
|
|
|
|
2022-05-13 17:17:26 +03:00
|
|
|
fs :: HashMap FilePath Text
|
2022-04-07 19:10:53 +03:00
|
|
|
fs =
|
2022-06-30 12:31:08 +03:00
|
|
|
unionStdlib
|
|
|
|
( HashMap.fromList
|
|
|
|
[ (getModuleFileAbsPath cwd m, renderCode m)
|
|
|
|
| m <- toList (getAllModules s2)
|
|
|
|
]
|
|
|
|
)
|
2022-04-07 19:10:53 +03:00
|
|
|
|
2022-05-18 18:10:10 +03:00
|
|
|
let scopedPretty = renderCode s2
|
|
|
|
parsedPretty = renderCode p2
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
step "Parsing pretty scoped"
|
2022-06-30 12:31:08 +03:00
|
|
|
let fs2 = unionStdlib (HashMap.singleton entryFile scopedPretty)
|
2022-05-30 14:40:52 +03:00
|
|
|
p' :: Parser.ParserResult <-
|
2022-09-14 17:16:15 +03:00
|
|
|
(runM . runErrorIO' @JuvixError . runNameIdGen . runFilesPure fs2 . runReader entryPoint)
|
|
|
|
upToParsing
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
step "Parsing pretty parsed"
|
2022-06-30 12:31:08 +03:00
|
|
|
let fs3 = unionStdlib (HashMap.singleton entryFile parsedPretty)
|
2022-05-30 14:40:52 +03:00
|
|
|
parsedPretty' :: Parser.ParserResult <-
|
2022-09-14 17:16:15 +03:00
|
|
|
(runM . runErrorIO' @JuvixError . runNameIdGen . runFilesPure fs3 . runReader entryPoint)
|
|
|
|
upToParsing
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
step "Scoping the scoped"
|
2022-05-30 14:40:52 +03:00
|
|
|
s' :: Scoper.ScoperResult <-
|
2022-09-14 17:16:15 +03:00
|
|
|
(runM . runErrorIO' @JuvixError . runNameIdGen . runFilesPure fs . runReader entryPoint)
|
|
|
|
upToScoping
|
2022-04-07 19:10:53 +03:00
|
|
|
|
|
|
|
step "Checks"
|
2022-04-08 13:46:37 +03:00
|
|
|
let smodules = s ^. Scoper.resultModules
|
2022-05-13 17:17:26 +03:00
|
|
|
smodules' = s' ^. Scoper.resultModules
|
2022-04-08 13:46:37 +03:00
|
|
|
|
|
|
|
let pmodules = p ^. Parser.resultModules
|
2022-05-13 17:17:26 +03:00
|
|
|
pmodules' = p' ^. Parser.resultModules
|
|
|
|
parsedPrettyModules = parsedPretty' ^. Parser.resultModules
|
2022-04-08 13:46:37 +03:00
|
|
|
|
|
|
|
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-04-07 19:10:53 +03:00
|
|
|
}
|
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 . testDescr) tests)
|
2022-02-18 15:01:42 +03:00
|
|
|
|
|
|
|
tests :: [PosTest]
|
2022-04-05 20:57:21 +03:00
|
|
|
tests =
|
|
|
|
[ PosTest
|
|
|
|
"Inductive"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibInclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Inductive.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Imports and qualified names"
|
|
|
|
"Imports"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibInclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"A.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Data.Bool from the stdlib"
|
|
|
|
"StdlibList"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Data/Bool.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Data.Nat from the stdlib"
|
|
|
|
"StdlibList"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Data/Nat.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Data.Ord from the stdlib"
|
|
|
|
"StdlibList"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Data/Ord.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Data.Product from the stdlib"
|
|
|
|
"StdlibList"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Data/Product.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Data.List and friends from the stdlib"
|
|
|
|
"StdlibList"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Data/List.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Operators (+)"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Operators.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Literals"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Literals.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Axiom with backends"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Axiom.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Foreign block parsing"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Foreign.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Multiple modules non-ambiguous symbol - same file"
|
|
|
|
"QualifiedSymbol"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"M.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Multiple modules non-ambiguous symbol"
|
|
|
|
"QualifiedSymbol2"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"N.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"Multiple modules constructor non-ambiguous symbol"
|
|
|
|
"QualifiedConstructor"
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"M.juvix",
|
2022-06-16 11:13:13 +03:00
|
|
|
PosTest
|
|
|
|
"Parsing"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"Parsing.juvix",
|
2022-04-05 20:57:21 +03:00
|
|
|
PosTest
|
|
|
|
"open overrides open public"
|
|
|
|
"."
|
2022-06-30 12:31:08 +03:00
|
|
|
StdlibExclude
|
2022-07-08 14:59:45 +03:00
|
|
|
"ShadowPublicOpen.juvix",
|
2022-06-30 12:31:08 +03:00
|
|
|
PosTest
|
|
|
|
"Import embedded standard library"
|
|
|
|
"StdlibImport"
|
|
|
|
StdlibInclude
|
2022-07-18 14:32:43 +03:00
|
|
|
"StdlibImport.juvix",
|
|
|
|
PosTest
|
|
|
|
"Check Valid Symbols"
|
|
|
|
""
|
|
|
|
StdlibInclude
|
2022-10-13 16:03:49 +03:00
|
|
|
"Symbols.juvix",
|
|
|
|
PosTest
|
2022-10-14 19:42:03 +03:00
|
|
|
"Builtin bool"
|
2022-10-13 16:03:49 +03:00
|
|
|
"."
|
|
|
|
StdlibExclude
|
|
|
|
"BuiltinsBool.juvix"
|
2022-04-05 20:57:21 +03:00
|
|
|
]
|