Files
allhaileris afb81b8278
Some checks failed
Docker. / Ubuntu (push) Has been cancelled
User-agent updater. / User-agent (push) Failing after 15s
Lock Threads / lock (push) Failing after 10s
Waiting for answer. / waiting-for-answer (push) Failing after 22s
Needs user action. / needs-user-action (push) Failing after 8s
Can't reproduce. / cant-reproduce (push) Failing after 8s
Close stale issues and PRs / stale (push) Has been cancelled
init
2026-02-16 15:50:16 +03:00

186 lines
4.8 KiB
Python

# SPDX-License-Identifier: LGPL-2.1-or-later
#
# This file is formatted with Python Black
# mypy: disable-error-code="misc"
from tests.templates import Response, init_logger, ImplRequest, ImplSession
from dbusmock import MOCK_IFACE
import dbus
import dbus.service
import socket
from gi.repository import GLib
from dataclasses import dataclass
BUS_NAME = "org.freedesktop.impl.portal.Test"
MAIN_OBJ = "/org/freedesktop/portal/desktop"
SYSTEM_BUS = False
MAIN_IFACE = "org.freedesktop.impl.portal.RemoteDesktop"
VERSION = 2
logger = init_logger(__name__)
@dataclass
class RemotedesktopParameters:
delay: int
response: int
expect_close: bool
force_close: int
force_clipoboard_enabled: bool
fail_connect_to_eis: bool
def load(mock, parameters={}):
logger.debug(f"Loading parameters: {parameters}")
assert not hasattr(mock, "remotedesktop_params")
mock.remotedesktop_params = RemotedesktopParameters(
delay=parameters.get("delay", 200),
response=parameters.get("response", 0),
expect_close=parameters.get("expect-close", False),
force_close=parameters.get("force-close", 0),
force_clipoboard_enabled=parameters.get("force-clipboard-enabled", False),
fail_connect_to_eis=parameters.get("fail-connect-to-eis", False),
)
mock.AddProperties(
MAIN_IFACE,
dbus.Dictionary(
{
"version": dbus.UInt32(parameters.get("version", VERSION)),
}
),
)
mock.sessions: dict[str, ImplSession] = {}
@dbus.service.method(
MAIN_IFACE,
in_signature="oosa{sv}",
out_signature="ua{sv}",
async_callbacks=("cb_success", "cb_error"),
)
def CreateSession(self, handle, session_handle, app_id, options, cb_success, cb_error):
logger.debug(f"CreateSession({handle}, {session_handle}, {app_id}, {options})")
params = self.remotedesktop_params
session = ImplSession(self, BUS_NAME, session_handle, app_id).export()
self.sessions[session_handle] = session
request = ImplRequest(
self,
BUS_NAME,
handle,
logger,
cb_success,
cb_error,
)
if params.expect_close:
request.wait_for_close()
else:
request.respond(
Response(params.response, {"session_handle": session.handle}),
delay=params.delay,
)
if params.force_close > 0:
GLib.timeout_add(params.force_close, session.close)
@dbus.service.method(
MAIN_IFACE,
in_signature="oosa{sv}",
out_signature="ua{sv}",
async_callbacks=("cb_success", "cb_error"),
)
def SelectDevices(self, handle, session_handle, app_id, options, cb_success, cb_error):
logger.debug(f"SelectDevices({handle}, {session_handle}, {app_id}, {options})")
params = self.remotedesktop_params
assert session_handle in self.sessions
request = ImplRequest(
self,
BUS_NAME,
handle,
logger,
cb_success,
cb_error,
)
if params.expect_close:
request.wait_for_close()
else:
request.respond(Response(params.response, {}), delay=params.delay)
@dbus.service.method(
MAIN_IFACE,
in_signature="oossa{sv}",
out_signature="ua{sv}",
async_callbacks=("cb_success", "cb_error"),
)
def Start(
self, handle, session_handle, app_id, parent_window, options, cb_success, cb_error
):
logger.debug(
f"Start({handle}, {session_handle}, {parent_window}, {app_id}, {options})"
)
params = self.remotedesktop_params
assert session_handle in self.sessions
request = ImplRequest(
self,
BUS_NAME,
handle,
logger,
cb_success,
cb_error,
)
response = Response(params.response, {})
if params.force_clipoboard_enabled:
response.results["clipboard_enabled"] = True
if params.expect_close:
request.wait_for_close()
else:
request.respond(response, delay=params.delay)
@dbus.service.method(
MAIN_IFACE,
in_signature="osa{sv}",
out_signature="h",
)
def ConnectToEIS(self, session_handle, app_id, options):
try:
logger.debug(f"ConnectToEIS({session_handle}, {app_id}, {options})")
params = self.remotedesktop_params
assert session_handle in self.sessions
if params.fail_connect_to_eis:
raise dbus.exceptions.DBusException("Purposely failing ConnectToEIS")
sockets = socket.socketpair()
self.eis_socket = sockets[0]
assert self.eis_socket.send(b"HELLO") == 5
return dbus.types.UnixFd(sockets[1])
except Exception as e:
logger.critical(e)
raise e
@dbus.service.method(MOCK_IFACE, in_signature="s", out_signature="s")
def GetSessionAppId(self, session_handle):
logger.debug(f"GetSessionAppId({session_handle})")
assert session_handle in self.sessions
return self.sessions[session_handle].app_id