test_session.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import asyncio
  2. import os
  3. import pytest
  4. from ..schema import SERVERS_RESPONSE
  5. async def assert_status_set(handler, expected_statuses, language_server=None):
  6. await handler.get()
  7. payload = handler._payload
  8. errors = list(SERVERS_RESPONSE.iter_errors(payload))
  9. assert not errors
  10. statuses = {
  11. session["status"]
  12. for session_server, session in payload["sessions"].items()
  13. if language_server is None or language_server == session_server
  14. }
  15. assert statuses == expected_statuses, payload
  16. @pytest.mark.asyncio
  17. async def test_start_known(known_server, handlers, jsonrpc_init_msg):
  18. """will a process start for a known server if a handler starts?"""
  19. handler, ws_handler = handlers
  20. manager = handler.manager
  21. manager.initialize()
  22. await assert_status_set(handler, {"not_started"})
  23. await ws_handler.open(known_server)
  24. session = manager.sessions[ws_handler.language_server]
  25. assert session.process is not None
  26. await assert_status_set(handler, {"started"}, known_server)
  27. await ws_handler.on_message(jsonrpc_init_msg)
  28. try:
  29. await asyncio.wait_for(
  30. ws_handler._messages_wrote.get(),
  31. 120 if known_server == "julia-language-server" else 20,
  32. )
  33. ws_handler._messages_wrote.task_done()
  34. finally:
  35. ws_handler.on_close()
  36. assert not session.handlers
  37. assert not session.process
  38. await assert_status_set(handler, {"stopped"}, known_server)
  39. await assert_status_set(handler, {"stopped", "not_started"})
  40. @pytest.mark.asyncio
  41. async def test_start_unknown(known_unknown_server, handlers, jsonrpc_init_msg):
  42. """will a process not start for an unknown server if a handler starts?"""
  43. handler, ws_handler = handlers
  44. manager = handler.manager
  45. manager.initialize()
  46. await assert_status_set(handler, {"not_started"})
  47. await ws_handler.open(known_unknown_server)
  48. await assert_status_set(handler, {"not_started"})
  49. await ws_handler.on_message(jsonrpc_init_msg)
  50. await assert_status_set(handler, {"not_started"})
  51. ws_handler.on_close()
  52. assert not manager.sessions.get(ws_handler.language_server)
  53. await assert_status_set(handler, {"not_started"})
  54. @pytest.mark.asyncio
  55. async def test_ping(handlers):
  56. """see https://github.com/jupyter-lsp/jupyterlab-lsp/issues/458"""
  57. a_server = "pylsp"
  58. handler, ws_handler = handlers
  59. manager = handler.manager
  60. manager.initialize()
  61. assert ws_handler.ping_interval > 0
  62. # the default ping interval is 30 seconds, too long for a test
  63. ws_handler.settings["ws_ping_interval"] = 0.1
  64. assert ws_handler.ping_interval == 0.1
  65. assert ws_handler._ping_sent is False
  66. await ws_handler.open(a_server)
  67. assert ws_handler.ping_callback is not None and ws_handler.ping_callback.is_running
  68. await asyncio.sleep(ws_handler.ping_interval * 3)
  69. assert ws_handler._ping_sent is True
  70. ws_handler.on_close()
  71. @pytest.mark.asyncio
  72. async def test_substitute_env(handlers):
  73. """should not leak environment variables"""
  74. a_server = "pylsp"
  75. handler, ws_handler = handlers
  76. manager = handler.manager
  77. manager.initialize()
  78. await assert_status_set(handler, {"not_started"})
  79. await ws_handler.open(a_server)
  80. session = manager.sessions[ws_handler.language_server]
  81. new_env = session.substitute_env({"test-variable": "value"}, os.environ)
  82. assert "test-variable" in new_env
  83. assert "test-variable" not in os.environ
  84. ws_handler.on_close()