{-# LANGUAGE LambdaCase #-} -- {-# LANGUAGE ViewPatterns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE ScopedTypeVariables #-} module Class ( tests ) where import Control.Lens hiding ((<.>)) import Control.Monad.IO.Class (MonadIO(liftIO)) import qualified Data.ByteString.Lazy as BS import qualified Data.Text.Encoding as T import Language.Haskell.LSP.Test import Language.Haskell.LSP.Types hiding (_title, _command) import qualified Language.Haskell.LSP.Types.Lens as J import System.FilePath import Test.Hls.Util import Test.Tasty import Test.Tasty.Golden import Test.Tasty.HUnit tests :: TestTree tests = testGroup "class" [ testCase "Produces addMinimalMethodPlaceholders code actions for one instance" $ do runSession hlsCommand fullCaps classPath $ do doc <- openDoc "T1.hs" "haskell" _ <- waitForDiagnosticsFromSource doc "typecheck" caResults <- getAllCodeActions doc liftIO $ map (^? _CACodeAction . J.title) caResults @?= [ Just "Add placeholders for '=='" , Just "Add placeholders for '/='" ] , glodenTest "Creates a placeholder for '=='" "T1" "eq" $ \(eqAction:_) -> do executeCodeAction eqAction , glodenTest "Creates a placeholder for '/='" "T1" "ne" $ \(_:neAction:_) -> do executeCodeAction neAction , glodenTest "Creates a placeholder for 'fmap'" "T2" "fmap" $ \(_:_:fmapAction:_) -> do executeCodeAction fmapAction , glodenTest "Creates a placeholder for multiple methods 1" "T3" "1" $ \(mmAction:_) -> do executeCodeAction mmAction , glodenTest "Creates a placeholder for multiple methods 2" "T3" "2" $ \(_:mmAction:_) -> do executeCodeAction mmAction ] _CACodeAction :: Prism' CAResult CodeAction _CACodeAction = prism' CACodeAction $ \case CACodeAction action -> Just action _ -> Nothing classPath :: FilePath classPath = "test" "testdata" "class" glodenTest :: String -> FilePath -> FilePath -> ([CodeAction] -> Session ()) -> TestTree glodenTest name fp deco execute = goldenVsStringDiff name goldenGitDiff (classPath fp <.> deco <.> "expected" <.> "hs") $ runSession hlsCommand fullCaps classPath $ do doc <- openDoc (fp <.> "hs") "haskell" _ <- waitForDiagnosticsFromSource doc "typecheck" actions <- concatMap (^.. _CACodeAction) <$> getAllCodeActions doc execute actions BS.fromStrict . T.encodeUtf8 <$> getDocumentEdit doc goldenGitDiff :: FilePath -> FilePath -> [String] goldenGitDiff fRef fNew = ["git", "diff", "--no-index", "--text", "--exit-code", fRef, fNew]