+ diag ^. severity `shouldBe` Just DsWarning
+ diag ^. source `shouldBe` Just "dummy-server"
+
+ -- describe "rename" $ do
+ -- it "works" $ pendingWith "HaRe not in hie-bios yet"
+ -- it "works on javascript" $
+ -- runSession "javascript-typescript-stdio" fullCaps "test/data/javascriptPass" $ do
+ -- doc <- openDoc "test.js" "javascript"
+ -- rename doc (Position 2 11) "bar"
+ -- documentContents doc >>= liftIO . (`shouldContain` "function bar()") . T.unpack
+
+ describe "getHover" $
+ it "works" $ runSession serverExe fullCaps "test/data/renamePass" $ do
+ doc <- openDoc "Desktop/simple.hs" "haskell"
+ hover <- getHover doc (Position 45 9)
+ liftIO $ hover `shouldSatisfy` isJust
+
+ -- describe "getHighlights" $
+ -- it "works" $ runSession serverExe fullCaps "test/data/renamePass" $ do
+ -- doc <- openDoc "Desktop/simple.hs" "haskell"
+ -- skipManyTill loggingNotification $ count 2 noDiagnostics
+ -- highlights <- getHighlights doc (Position 27 4) -- addItem
+ -- liftIO $ length highlights `shouldBe` 4
+
+ -- describe "formatDoc" $
+ -- it "works" $ runSession serverExe fullCaps "test/data" $ do
+ -- doc <- openDoc "Format.hs" "haskell"
+ -- oldContents <- documentContents doc
+ -- formatDoc doc (FormattingOptions 4 True)
+ -- documentContents doc >>= liftIO . (`shouldNotBe` oldContents)
+
+ -- describe "formatRange" $
+ -- it "works" $ runSession serverExe fullCaps "test/data" $ do
+ -- doc <- openDoc "Format.hs" "haskell"
+ -- oldContents <- documentContents doc
+ -- formatRange doc (FormattingOptions 4 True) (Range (Position 1 10) (Position 2 10))
+ -- documentContents doc >>= liftIO . (`shouldNotBe` oldContents)
+
+ describe "closeDoc" $
+ it "works" $
+ let sesh =
+ runSession serverExe fullCaps "test/data" $ do
+ doc <- openDoc "Format.hs" "haskell"
+ closeDoc doc
+ -- need to evaluate to throw
+ documentContents doc >>= liftIO . print
+ in sesh `shouldThrow` anyException
+
+ describe "satisfy" $
+ it "works" $ runSession serverExe fullCaps "test/data" $ do
+ openDoc "Format.hs" "haskell"
+ let pred (NotLogMessage _) = True
+ pred _ = False
+ void $ satisfy pred
+
+ describe "ignoreLogNotifications" $
+ it "works" $
+ runSessionWithConfig (defaultConfig { ignoreLogNotifications = True }) serverExe fullCaps "test/data" $ do
+ openDoc "Format.hs" "haskell"
+ void publishDiagnosticsNotification
+
+mkRange sl sc el ec = Range (Position sl sc) (Position el ec)
+
+didChangeCaps :: ClientCapabilities
+didChangeCaps = def { _workspace = Just workspaceCaps }
+ where
+ workspaceCaps = def { _didChangeConfiguration = Just configCaps }
+ configCaps = DidChangeConfigurationClientCapabilities (Just True)
+
+docChangesCaps :: ClientCapabilities
+docChangesCaps = def { _workspace = Just workspaceCaps }
+ where
+ workspaceCaps = def { _workspaceEdit = Just editCaps }
+ editCaps = WorkspaceEditClientCapabilities (Just True)
+
+
+findExeRecursive :: FilePath -> FilePath -> IO (Maybe FilePath)
+findExeRecursive exe dir = do
+ me <- listToMaybe <$> findExecutablesInDirectories [dir] exe
+ case me of
+ Just e -> return (Just e)
+ Nothing -> do
+ subdirs <- (fmap (dir </>)) <$> listDirectory dir >>= filterM doesDirectoryExist
+ foldM (\acc subdir -> case acc of
+ Just y -> pure $ Just y
+ Nothing -> findExeRecursive exe subdir)
+ Nothing
+ subdirs
+
+-- | So we can find the dummy-server with cabal run
+-- since it doesnt put build tools on the path (only cabal test)
+findServer = do
+ let serverName = "dummy-server"
+ e <- findExecutable serverName
+ e' <- findExeRecursive serverName "dist-newstyle"
+ pure $ fromJust $ e <|> e'
\ No newline at end of file