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
169 lines
4.3 KiB
Python
169 lines
4.3 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 init_logger
|
|
|
|
import dbus.service
|
|
import dbus
|
|
import tempfile
|
|
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.Clipboard"
|
|
VERSION = 1
|
|
|
|
|
|
logger = init_logger(__name__)
|
|
|
|
|
|
@dataclass
|
|
class ClipboardParameters:
|
|
delay: int
|
|
response: int
|
|
expect_close: bool
|
|
|
|
|
|
def load(mock, parameters={}):
|
|
logger.debug(f"Loading parameters: {parameters}")
|
|
|
|
assert not hasattr(mock, "clipboard_params")
|
|
mock.clipboard_params = ClipboardParameters(
|
|
delay=parameters.get("delay", 200),
|
|
response=parameters.get("response", 0),
|
|
expect_close=parameters.get("expect-close", False),
|
|
)
|
|
|
|
mock.AddProperties(
|
|
MAIN_IFACE,
|
|
dbus.Dictionary(
|
|
{
|
|
"version": dbus.UInt32(parameters.get("version", VERSION)),
|
|
}
|
|
),
|
|
)
|
|
|
|
|
|
@dbus.service.method(
|
|
MAIN_IFACE,
|
|
in_signature="oa{sv}",
|
|
out_signature="",
|
|
async_callbacks=("cb_success", "cb_error"),
|
|
)
|
|
def RequestClipboard(self, session_handle, options, cb_success, cb_error):
|
|
try:
|
|
logger.debug(f"RequestClipboard({session_handle}, {options})")
|
|
params = self.clipboard_params
|
|
|
|
if params.expect_close:
|
|
cb_success()
|
|
else:
|
|
logger.debug(f"scheduling delay of {params.delay}")
|
|
GLib.timeout_add(params.delay, cb_success)
|
|
except Exception as e:
|
|
logger.critical(e)
|
|
cb_error(e)
|
|
|
|
|
|
@dbus.service.method(
|
|
MAIN_IFACE,
|
|
in_signature="oa{sv}",
|
|
out_signature="",
|
|
async_callbacks=("cb_success", "cb_error"),
|
|
)
|
|
def SetSelection(self, session_handle, options, cb_success, cb_error):
|
|
try:
|
|
logger.debug(f"SetSelection({session_handle}, {options})")
|
|
params = self.clipboard_params
|
|
|
|
if params.expect_close:
|
|
cb_success()
|
|
else:
|
|
logger.debug(f"scheduling delay of {params.delay}")
|
|
GLib.timeout_add(params.delay, cb_success)
|
|
except Exception as e:
|
|
logger.critical(e)
|
|
cb_error(e)
|
|
|
|
|
|
@dbus.service.method(
|
|
MAIN_IFACE,
|
|
in_signature="ou",
|
|
out_signature="h",
|
|
async_callbacks=("cb_success", "cb_error"),
|
|
)
|
|
def SelectionWrite(self, session_handle, serial, cb_success, cb_error):
|
|
try:
|
|
logger.debug(f"SelectionWrite({session_handle}, {serial})")
|
|
params = self.clipboard_params
|
|
|
|
temp_file = tempfile.TemporaryFile()
|
|
fd = dbus.types.UnixFd(temp_file.fileno())
|
|
|
|
if params.expect_close:
|
|
cb_success(fd)
|
|
else:
|
|
|
|
def reply():
|
|
cb_success(fd)
|
|
|
|
logger.debug(f"scheduling delay of {params.delay}")
|
|
GLib.timeout_add(params.delay, reply)
|
|
except Exception as e:
|
|
logger.critical(e)
|
|
cb_error(e)
|
|
|
|
|
|
@dbus.service.method(
|
|
MAIN_IFACE,
|
|
in_signature="oub",
|
|
out_signature="",
|
|
async_callbacks=("cb_success", "cb_error"),
|
|
)
|
|
def SelectionWriteDone(self, session_handle, serial, success, cb_success, cb_error):
|
|
try:
|
|
logger.debug(f"SelectionWriteDone({session_handle}, {serial}, {success})")
|
|
params = self.clipboard_params
|
|
|
|
if params.expect_close:
|
|
cb_success()
|
|
else:
|
|
logger.debug(f"scheduling delay of {params.delay}")
|
|
GLib.timeout_add(params.delay, cb_success)
|
|
except Exception as e:
|
|
logger.critical(e)
|
|
cb_error(e)
|
|
|
|
|
|
@dbus.service.method(
|
|
MAIN_IFACE,
|
|
in_signature="os",
|
|
out_signature="h",
|
|
async_callbacks=("cb_success", "cb_error"),
|
|
)
|
|
def SelectionRead(self, session_handle, mime_type, cb_success, cb_error):
|
|
try:
|
|
logger.debug(f"SelectionRead({session_handle}, {mime_type})")
|
|
params = self.clipboard_params
|
|
|
|
temp_file = tempfile.TemporaryFile()
|
|
fd = dbus.types.UnixFd(temp_file.fileno())
|
|
|
|
if params.expect_close:
|
|
cb_success(fd)
|
|
else:
|
|
|
|
def reply():
|
|
cb_success(fd)
|
|
|
|
logger.debug(f"scheduling delay of {params.delay}")
|
|
GLib.timeout_add(params.delay, reply)
|
|
except Exception as e:
|
|
logger.critical(e)
|
|
cb_error(e)
|