+ describe "satisfy" $
+ it "works" $ runSession serverExe fullCaps "test/data" $ do
+ openDoc "Format.hs" "haskell"
+ let pred (FromServerMess SWindowLogMessage _) = 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
+
+ describe "dynamic capabilities" $ do
+
+ it "keeps track" $ runSession serverExe fullCaps "test/data" $ do
+ loggingNotification -- initialized log message
+
+ createDoc ".register" "haskell" ""
+ message SClientRegisterCapability
+
+ doc <- createDoc "Foo.watch" "haskell" ""
+ msg <- message SWindowLogMessage
+ liftIO $ msg ^. params . LSP.message `shouldBe` "got workspace/didChangeWatchedFiles"
+
+ [SomeRegistration (Registration _ regMethod regOpts)] <- getRegisteredCapabilities
+ liftIO $ do
+ case regMethod `mEqClient` SWorkspaceDidChangeWatchedFiles of
+ Just HRefl ->
+ regOpts `shouldBe` (DidChangeWatchedFilesRegistrationOptions $ List
+ [ FileSystemWatcher "*.watch" (Just (WatchKind True True True)) ])
+ Nothing -> expectationFailure "Registration wasn't on workspace/didChangeWatchedFiles"
+
+ -- now unregister it by sending a specific createDoc
+ createDoc ".unregister" "haskell" ""
+ message SClientUnregisterCapability
+
+ createDoc "Bar.watch" "haskell" ""
+ void $ sendRequest STextDocumentHover $ HoverParams doc (Position 0 0) Nothing
+ count 0 $ loggingNotification
+ void $ anyResponse
+
+ it "handles absolute patterns" $ runSession serverExe fullCaps "" $ do
+ curDir <- liftIO $ getCurrentDirectory
+
+ loggingNotification -- initialized log message
+
+ createDoc ".register.abs" "haskell" ""
+ message SClientRegisterCapability
+
+ doc <- createDoc (curDir </> "Foo.watch") "haskell" ""
+ msg <- message SWindowLogMessage
+ liftIO $ msg ^. params . LSP.message `shouldBe` "got workspace/didChangeWatchedFiles"
+
+ -- now unregister it by sending a specific createDoc
+ createDoc ".unregister.abs" "haskell" ""
+ message SClientUnregisterCapability
+
+ createDoc (curDir </> "Bar.watch") "haskell" ""
+ void $ sendRequest STextDocumentHover $ HoverParams doc (Position 0 0) Nothing
+ count 0 $ loggingNotification
+ void $ anyResponse
+