blob: af5c62a8c4eb53894dc5dc558dc06d5e3f303a18 [file] [log] [blame]
"""
Test lldb-dap IO handling.
"""
import sys
from lldbsuite.test.decorators import *
import lldbdap_testcase
import dap_server
EXIT_FAILURE = 1
EXIT_SUCCESS = 0
class TestDAP_io(lldbdap_testcase.DAPTestCaseBase):
def launch(self):
log_file_path = self.getBuildArtifact("dap.txt")
process, _ = dap_server.DebugAdapterServer.launch(
executable=self.lldbDAPExec, log_file=log_file_path
)
def cleanup():
# If the process is still alive, terminate it.
if process.poll() is None:
process.terminate()
process.wait()
stdout_data = process.stdout.read().decode()
print("========= STDOUT =========", file=sys.stderr)
print(stdout_data, file=sys.stderr)
print("========= END =========", file=sys.stderr)
print("========= DEBUG ADAPTER PROTOCOL LOGS =========", file=sys.stderr)
with open(log_file_path, "r") as file:
print(file.read(), file=sys.stderr)
print("========= END =========", file=sys.stderr)
# Execute the cleanup function during test case tear down.
self.addTearDownHook(cleanup)
return process
def test_eof_immediately(self):
"""
lldb-dap handles EOF without any other input.
"""
process = self.launch()
process.stdin.close()
self.assertEqual(process.wait(timeout=5.0), EXIT_SUCCESS)
def test_invalid_header(self):
"""
lldb-dap returns a failure exit code when the input stream is closed
with a malformed request header.
"""
process = self.launch()
process.stdin.write(b"not the correct message header")
process.stdin.close()
self.assertEqual(process.wait(timeout=5.0), EXIT_FAILURE)
def test_partial_header(self):
"""
lldb-dap returns a failure exit code when the input stream is closed
with an incomplete message header is in the message buffer.
"""
process = self.launch()
process.stdin.write(b"Content-Length: ")
process.stdin.close()
self.assertEqual(process.wait(timeout=5.0), EXIT_FAILURE)
def test_incorrect_content_length(self):
"""
lldb-dap returns a failure exit code when reading malformed content
length headers.
"""
process = self.launch()
process.stdin.write(b"Content-Length: abc")
process.stdin.close()
self.assertEqual(process.wait(timeout=5.0), EXIT_FAILURE)
def test_partial_content_length(self):
"""
lldb-dap returns a failure exit code when the input stream is closed
with a partial message in the message buffer.
"""
process = self.launch()
process.stdin.write(b"Content-Length: 10\r\n\r\n{")
process.stdin.close()
self.assertEqual(process.wait(timeout=5.0), EXIT_FAILURE)