mirror of
https://github.com/github/semantic.git
synced 2024-11-23 16:37:50 +03:00
32 lines
902 B
Haskell
32 lines
902 B
Haskell
{-# LANGUAGE CPP, DisambiguateRecordFields, OverloadedStrings, TypeApplications, ImplicitParams #-}
|
|
{-# OPTIONS_GHC -Wno-unused-imports #-}
|
|
module Main (main) where
|
|
|
|
|
|
import TreeSitter.TSX
|
|
import AST.TestHelpers
|
|
import AST.Unmarshal
|
|
import qualified Language.TSX.AST as Tsx
|
|
import qualified System.Path as Path
|
|
import Test.Tasty
|
|
import qualified System.Path.Fixture as Fixture
|
|
|
|
main :: IO ()
|
|
main = do
|
|
#if BAZEL_BUILD
|
|
rf <- Fixture.create
|
|
let ?project = Path.relDir "external/semantic-typescript"
|
|
?runfiles = rf
|
|
let dirs = Fixture.absRelDir "tsx/corpus"
|
|
#else
|
|
dirs <- Path.absRel <$> Tsx.getTestCorpusDir
|
|
#endif
|
|
|
|
readCorpusFiles' dirs
|
|
>>= traverse (testCorpus parse)
|
|
>>= defaultMain . tests
|
|
where parse = parseByteString @Tsx.Program @() tree_sitter_tsx
|
|
|
|
tests :: [TestTree] -> TestTree
|
|
tests = testGroup "tree-sitter-tsx corpus tests"
|