module Main where import Test.Tasty import Test.Tasty.Golden import System.FilePath import System.IO (hPutStrLn, stderr) import Data.List (intercalate) import qualified Language.Haskell.Exts as HS import qualified HsImport as HI main = defaultMain tests tests :: TestTree tests = testGroup "Tests" [moduleTests, symbolTests] moduleTests :: TestTree moduleTests = testGroup "Module Tests" [ test "ModuleTest0" $ HI.defaultArgs { HI.moduleName = "Foo.Bar" } , test "ModuleTest1" $ HI.defaultArgs { HI.moduleName = "Foo.Bar" } , test "ModuleTest2" $ HI.defaultArgs { HI.moduleName = "Foo.Bar.Blub" } , test "ModuleTest3" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest4" $ HI.defaultArgs { HI.moduleName = "Ugah.Argh2" } , test "ModuleTest5" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest6" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest7" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest8" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest9" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest10" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest11" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest12" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest13" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest14" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest15" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest16" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest17" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest18" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest19" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest20" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest21" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest22" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test "ModuleTest23" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.qualifiedName = "CM" } , test "ModuleTest24" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.qualifiedName = "CM" } , test "ModuleTest25" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.qualifiedName = "Control.Monad" } , test "ModuleTest26" $ HI.defaultArgs { HI.moduleName = "Control.Monad" } , test_ "ModuleTest27" (HI.defaultConfig { HI.findImportPos = importPosBeforeFirst }) (HI.defaultArgs { HI.moduleName = "Control.Monad" }) , test_ "ModuleTest28" (HI.defaultConfig { HI.findImportPos = importPosAfterFirst }) (HI.defaultArgs { HI.moduleName = "Control.Monad" }) , test_ "ModuleTest29" (HI.defaultConfig { HI.findImportPos = importPosBeforeLast }) (HI.defaultArgs { HI.moduleName = "Control.Monad" }) , test_ "ModuleTest30" (HI.defaultConfig { HI.findImportPos = importPosAfterLast }) (HI.defaultArgs { HI.moduleName = "Control.Monad" }) , test "ModuleTest31" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.as = "CM" } ] symbolTests :: TestTree symbolTests = testGroup "Symbol Tests" [ test "SymbolTest0" $ HI.defaultArgs { HI.moduleName = "Foo.Bar", HI.symbolName = "foo" } , test "SymbolTest1" $ HI.defaultArgs { HI.moduleName = "Foo.Bar", HI.symbolName = "foo" } , test "SymbolTest2" $ HI.defaultArgs { HI.moduleName = "Foo.Bar.Blub", HI.symbolName = "foo" } , test "SymbolTest3" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "when" } , test "SymbolTest4" $ HI.defaultArgs { HI.moduleName = "Ugah.Argh2", HI.symbolName = "argh" } , test "SymbolTest5" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "when" } , test "SymbolTest6" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "unless" } , test "SymbolTest7" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "unless" } , test "SymbolTest8" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "unless" } , test "SymbolTest9" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "unless" } , test "SymbolTest10" $ HI.defaultArgs { HI.moduleName = "Control.Applicative", HI.symbolName = "<$>" } , test "SymbolTest11" $ HI.defaultArgs { HI.moduleName = "Control.Applicative", HI.symbolName = "<$>" } , test "SymbolTest12" $ HI.defaultArgs { HI.moduleName = "Control.Applicative", HI.symbolName = "<$>" } , test "SymbolTest13" $ HI.defaultArgs { HI.moduleName = "Control.Applicative", HI.symbolName = "<*" } , test "SymbolTest14" $ HI.defaultArgs { HI.moduleName = "Control.Applicative", HI.symbolName = "<*" } , test "SymbolTest15" $ HI.defaultArgs { HI.moduleName = "Control.Applicative", HI.symbolName = "*>" } , test "SymbolTest16" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "when", HI.qualifiedName = "CM" } , test "SymbolTest17" $ HI.defaultArgs { HI.moduleName = "Control.Monad", HI.symbolName = "when", HI.qualifiedName = "CM" } , test "SymbolTest18" $ HI.defaultArgs { HI.moduleName = "Data.Text", HI.symbolName = "Text" } , test "SymbolTest19" $ HI.defaultArgs { HI.moduleName = "Data.List", HI.symbolName = "foldl'" } , test "SymbolTest20" $ HI.defaultArgs { HI.moduleName = "Data.Maybe", HI.symbolName = "Maybe", HI.all = True } , test "SymbolTest21" $ HI.defaultArgs { HI.moduleName = "Data.Maybe", HI.symbolName = "Maybe", HI.all = True } , test "SymbolTest22" $ HI.defaultArgs { HI.moduleName = "Data.Maybe", HI.symbolName = "Maybe", HI.with = ["Just"] } , test "SymbolTest23" $ HI.defaultArgs { HI.moduleName = "Data.Maybe", HI.symbolName = "Maybe", HI.all = True, HI.with = ["Just"] } , test "SymbolTest24" $ HI.defaultArgs { HI.moduleName = "Data.Maybe", HI.symbolName = "Maybe", HI.with = ["Just"] } , test "SymbolTest25" $ HI.defaultArgs { HI.moduleName = "Data.Maybe", HI.symbolName = "Maybe", HI.with = ["Nothing", "Just"] } , test "SymbolTest26" $ HI.defaultArgs { HI.moduleName = "Foo", HI.symbolName = "bar" } , test "SymbolTest27" $ HI.defaultArgs { HI.moduleName = "Ugah.Blub", HI.symbolName = "g" } , test "SymbolTest28" $ HI.defaultArgs { HI.moduleName = "Ugah.Blub", HI.symbolName = "d" } , test_ "SymbolTest29" (HI.defaultConfig { HI.prettyPrint = prettyPrint }) (HI.defaultArgs { HI.moduleName = "X.Y", HI.symbolName = "x" }) , test_ "SymbolTest30" (HI.defaultConfig { HI.prettyPrint = prettyPrint }) (HI.defaultArgs { HI.moduleName = "X.Y", HI.symbolName = "x" }) , test "SymbolTest31" $ HI.defaultArgs { HI.moduleName = "Ugah.Blub", HI.symbolName = "d" } , test "SymbolTest32" $ HI.defaultArgs { HI.moduleName = "Control.Foo", HI.symbolName = "foo" } ] test :: String -> HI.HsImportArgs -> TestTree test testName args = test_ testName HI.defaultConfig args test_ :: String -> HI.Config -> HI.HsImportArgs -> TestTree test_ testName config args = goldenVsFileDiff testName diff goldenFile outputFile command where command = do maybeErr <- HI.hsimportWithArgs config (args { HI.inputSrcFile = inputFile, HI.outputSrcFile = outputFile }) case maybeErr of Just err -> hPutStrLn stderr ("hsimport: " ++ err) _ -> return () diff ref new = ["diff", "-u", ref, new] goldenFile = "tests" "goldenFiles" testName <.> "hs" outputFile = "tests" "outputFiles" testName <.> "hs" inputFile = "tests" "inputFiles" testName <.> "hs" prettyPrint :: HS.ImportDecl -> String prettyPrint HS.ImportDecl { HS.importModule = HS.ModuleName modName, HS.importSpecs = Just (False, syms) } = "import " ++ modName ++ " ( " ++ ppSyms ++ " )" where ppSyms = intercalate " , " symNames symNames = map symName syms symName (HS.IVar HS.NoNamespace (HS.Ident name)) = name symName _ = "" prettyPrint _ = "Uupps" importPosAfterLast :: HS.ImportDecl -> [HS.ImportDecl] -> Maybe HI.ImportPos importPosAfterLast _ [] = Nothing importPosAfterLast _ imports = Just . HI.After . last $ imports importPosBeforeLast :: HS.ImportDecl -> [HS.ImportDecl] -> Maybe HI.ImportPos importPosBeforeLast _ [] = Nothing importPosBeforeLast _ imports = Just . HI.Before . last $ imports importPosAfterFirst :: HS.ImportDecl -> [HS.ImportDecl] -> Maybe HI.ImportPos importPosAfterFirst _ [] = Nothing importPosAfterFirst _ imports = Just . HI.After . head $ imports importPosBeforeFirst :: HS.ImportDecl -> [HS.ImportDecl] -> Maybe HI.ImportPos importPosBeforeFirst _ [] = Nothing importPosBeforeFirst _ imports = Just . HI.Before . head $ imports