mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-11-11 04:02:55 +03:00
Merge pull request #236282 from OPNA2608/init/dbus-testers
This commit is contained in:
commit
b0e1167d1f
@ -477,6 +477,15 @@ with lib.maintainers; {
|
|||||||
enableFeatureFreezePing = true;
|
enableFeatureFreezePing = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
lomiri = {
|
||||||
|
members = [
|
||||||
|
OPNA2608
|
||||||
|
];
|
||||||
|
scope = "Maintain Lomiri desktop environment and related packages.";
|
||||||
|
shortName = "Lomiri";
|
||||||
|
enableFeatureFreezePing = true;
|
||||||
|
};
|
||||||
|
|
||||||
lumiguide = {
|
lumiguide = {
|
||||||
# Verify additions by approval of an already existing member of the team.
|
# Verify additions by approval of an already existing member of the team.
|
||||||
members = [
|
members = [
|
||||||
|
16
pkgs/desktops/lomiri/default.nix
Normal file
16
pkgs/desktops/lomiri/default.nix
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
{ lib
|
||||||
|
, pkgs
|
||||||
|
, libsForQt5
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
packages = self: let
|
||||||
|
inherit (self) callPackage;
|
||||||
|
in {
|
||||||
|
#### Development tools / libraries
|
||||||
|
cmake-extras = callPackage ./development/cmake-extras { };
|
||||||
|
gmenuharness = callPackage ./development/gmenuharness { };
|
||||||
|
lomiri-api = callPackage ./development/lomiri-api { };
|
||||||
|
};
|
||||||
|
in
|
||||||
|
lib.makeScope libsForQt5.newScope packages
|
49
pkgs/desktops/lomiri/development/cmake-extras/default.nix
Normal file
49
pkgs/desktops/lomiri/development/cmake-extras/default.nix
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
{ stdenvNoCC
|
||||||
|
, lib
|
||||||
|
, fetchFromGitLab
|
||||||
|
, cmake
|
||||||
|
, qtbase
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenvNoCC.mkDerivation {
|
||||||
|
pname = "cmake-extras";
|
||||||
|
version = "unstable-2022-11-21";
|
||||||
|
|
||||||
|
src = fetchFromGitLab {
|
||||||
|
owner = "ubports";
|
||||||
|
repo = "development/core/cmake-extras";
|
||||||
|
rev = "99aab4514ee182cb7a94821b4b51e4d8cb9a82ef";
|
||||||
|
hash = "sha256-axj5QxgDrHy0HiZkfrbm22hVvSCKkWFoQC8MdQMm9tg=";
|
||||||
|
};
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
# We have nothing to build here, no need to depend on a C compiler
|
||||||
|
substituteInPlace CMakeLists.txt \
|
||||||
|
--replace 'project(cmake-extras)' 'project(cmake-extras NONE)'
|
||||||
|
|
||||||
|
# This is in a function that reverse dependencies use to determine where to install their files to
|
||||||
|
substituteInPlace src/QmlPlugins/QmlPluginsConfig.cmake \
|
||||||
|
--replace "\''${CMAKE_INSTALL_LIBDIR}/qt5/qml" "\''${CMAKE_INSTALL_PREFIX}/${qtbase.qtQmlPrefix}"
|
||||||
|
'';
|
||||||
|
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
# Produces no binaries
|
||||||
|
dontWrapQtApps = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
cmake
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
qtbase
|
||||||
|
];
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "A collection of add-ons for the CMake build tool";
|
||||||
|
homepage = "https://gitlab.com/ubports/development/core/cmake-extras/";
|
||||||
|
license = licenses.gpl3Only;
|
||||||
|
maintainers = teams.lomiri.members;
|
||||||
|
platforms = platforms.all;
|
||||||
|
};
|
||||||
|
}
|
96
pkgs/desktops/lomiri/development/gmenuharness/default.nix
Normal file
96
pkgs/desktops/lomiri/development/gmenuharness/default.nix
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
{ stdenv
|
||||||
|
, lib
|
||||||
|
, fetchFromGitLab
|
||||||
|
, fetchpatch
|
||||||
|
, gitUpdater
|
||||||
|
, testers
|
||||||
|
, cmake
|
||||||
|
, cmake-extras
|
||||||
|
, dbus
|
||||||
|
, dbus-test-runner
|
||||||
|
, glib
|
||||||
|
, gtest
|
||||||
|
, libqtdbustest
|
||||||
|
, lomiri-api
|
||||||
|
, pkg-config
|
||||||
|
, qtbase
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
|
pname = "gmenuharness";
|
||||||
|
version = "0.1.4";
|
||||||
|
|
||||||
|
src = fetchFromGitLab {
|
||||||
|
owner = "ubports";
|
||||||
|
repo = "development/core/gmenuharness";
|
||||||
|
rev = finalAttrs.version;
|
||||||
|
hash = "sha256-MswB8cQvz3JvcJL2zj7szUOBzKRjxzJO7/x+87m7E7c=";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# Remove when version > 0.1.4
|
||||||
|
(fetchpatch {
|
||||||
|
name = "0001-gmenuharness-Rename-type-attribute-from-x-canonical-type-to-x-lomiri-type.patch";
|
||||||
|
url = "https://gitlab.com/ubports/development/core/gmenuharness/-/commit/70e9ed85792a6ac1950faaf26391ce91e69486ab.patch";
|
||||||
|
hash = "sha256-jeue0qrl2JZCt/Yfj4jT210wsF/E+MlbtNT/yFTcw5I=";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
cmake
|
||||||
|
pkg-config
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
cmake-extras
|
||||||
|
glib
|
||||||
|
lomiri-api
|
||||||
|
qtbase
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeCheckInputs = [
|
||||||
|
dbus
|
||||||
|
dbus-test-runner
|
||||||
|
];
|
||||||
|
|
||||||
|
checkInputs = [
|
||||||
|
gtest
|
||||||
|
libqtdbustest
|
||||||
|
];
|
||||||
|
|
||||||
|
cmakeFlags = [
|
||||||
|
"-Denable_tests=${lib.boolToString finalAttrs.doCheck}"
|
||||||
|
];
|
||||||
|
|
||||||
|
dontWrapQtApps = true;
|
||||||
|
|
||||||
|
doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform;
|
||||||
|
|
||||||
|
enableParallelChecking = false;
|
||||||
|
|
||||||
|
checkPhase = ''
|
||||||
|
runHook preCheck
|
||||||
|
|
||||||
|
dbus-test-runner -t make -p test -p "''${enableParallelChecking:+-j $NIX_BUILD_CORES}"
|
||||||
|
|
||||||
|
runHook postCheck
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage;
|
||||||
|
updateScript = gitUpdater { };
|
||||||
|
};
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Library to test GMenuModel structures";
|
||||||
|
homepage = "https://gitlab.com/ubports/development/core/gmenuharness";
|
||||||
|
license = licenses.gpl3Only;
|
||||||
|
maintainers = teams.lomiri.members;
|
||||||
|
platforms = platforms.unix;
|
||||||
|
pkgConfigModules = [
|
||||||
|
"libgmenuharness"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
})
|
106
pkgs/desktops/lomiri/development/lomiri-api/default.nix
Normal file
106
pkgs/desktops/lomiri/development/lomiri-api/default.nix
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
{ stdenv
|
||||||
|
, lib
|
||||||
|
, fetchFromGitLab
|
||||||
|
, gitUpdater
|
||||||
|
, makeFontsConf
|
||||||
|
, testers
|
||||||
|
, cmake
|
||||||
|
, cmake-extras
|
||||||
|
, dbus
|
||||||
|
, doxygen
|
||||||
|
, glib
|
||||||
|
, graphviz
|
||||||
|
, gtest
|
||||||
|
, libqtdbustest
|
||||||
|
, pkg-config
|
||||||
|
, python3
|
||||||
|
, qtbase
|
||||||
|
, qtdeclarative
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
|
pname = "lomiri-api";
|
||||||
|
version = "0.2.1";
|
||||||
|
|
||||||
|
src = fetchFromGitLab {
|
||||||
|
owner = "ubports";
|
||||||
|
repo = "development/core/lomiri-api";
|
||||||
|
rev = finalAttrs.version;
|
||||||
|
hash = "sha256-UTl0vObSlEvHuLmDt7vS3yEqZWGklJ9tVwlUAtRSTlU=";
|
||||||
|
};
|
||||||
|
|
||||||
|
outputs = [ "out" "dev" "doc" ];
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
patchShebangs $(find test -name '*.py')
|
||||||
|
|
||||||
|
substituteInPlace data/*.pc.in \
|
||||||
|
--replace "\''${prefix}/@CMAKE_INSTALL_LIBDIR@" "\''${prefix}/lib"
|
||||||
|
|
||||||
|
# Variable is queried via pkg-config by reverse dependencies
|
||||||
|
# TODO This is likely not supposed to be the regular Qt QML import prefix
|
||||||
|
# but otherwise i.e. lomiri-notifications cannot be found in lomiri
|
||||||
|
substituteInPlace CMakeLists.txt \
|
||||||
|
--replace 'SHELL_PLUGINDIR ''${CMAKE_INSTALL_LIBDIR}/lomiri/qml' 'SHELL_PLUGINDIR ${qtbase.qtQmlPrefix}'
|
||||||
|
'';
|
||||||
|
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
cmake
|
||||||
|
doxygen
|
||||||
|
graphviz
|
||||||
|
pkg-config
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
cmake-extras
|
||||||
|
glib
|
||||||
|
gtest
|
||||||
|
libqtdbustest
|
||||||
|
qtbase
|
||||||
|
qtdeclarative
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeCheckInputs = [
|
||||||
|
dbus
|
||||||
|
python3
|
||||||
|
];
|
||||||
|
|
||||||
|
dontWrapQtApps = true;
|
||||||
|
|
||||||
|
FONTCONFIG_FILE = makeFontsConf { fontDirectories = [ ]; };
|
||||||
|
|
||||||
|
preBuild = ''
|
||||||
|
# Makes fontconfig produce less noise in logs
|
||||||
|
export HOME=$TMPDIR
|
||||||
|
'';
|
||||||
|
|
||||||
|
doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform;
|
||||||
|
|
||||||
|
preCheck = ''
|
||||||
|
# needs minimal plugin and QtTest QML
|
||||||
|
export QT_PLUGIN_PATH=${lib.getBin qtbase}/${qtbase.qtPluginPrefix}
|
||||||
|
export QML2_IMPORT_PATH=${lib.getBin qtdeclarative}/${qtbase.qtQmlPrefix}
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage;
|
||||||
|
updateScript = gitUpdater { };
|
||||||
|
};
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Lomiri API Library for integrating with the Lomiri shell";
|
||||||
|
homepage = "https://gitlab.com/ubports/development/core/lomiri-api";
|
||||||
|
license = with licenses; [ lgpl3Only gpl3Only ];
|
||||||
|
maintainers = teams.lomiri.members;
|
||||||
|
platforms = platforms.linux;
|
||||||
|
pkgConfigModules = [
|
||||||
|
"liblomiri-api"
|
||||||
|
"lomiri-shell-api"
|
||||||
|
"lomiri-shell-application"
|
||||||
|
"lomiri-shell-launcher"
|
||||||
|
"lomiri-shell-notifications"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
})
|
93
pkgs/development/libraries/libqtdbusmock/default.nix
Normal file
93
pkgs/development/libraries/libqtdbusmock/default.nix
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
{ stdenv
|
||||||
|
, lib
|
||||||
|
, fetchbzr
|
||||||
|
, testers
|
||||||
|
, cmake
|
||||||
|
, cmake-extras
|
||||||
|
, dbus
|
||||||
|
, dbus-test-runner
|
||||||
|
, gtest
|
||||||
|
, libqtdbustest
|
||||||
|
, networkmanager
|
||||||
|
, pkg-config
|
||||||
|
, procps
|
||||||
|
, python3
|
||||||
|
, qtbase
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
|
pname = "libqtdbusmock";
|
||||||
|
version = "unstable-2017-03-16";
|
||||||
|
|
||||||
|
src = fetchbzr {
|
||||||
|
url = "lp:libqtdbusmock";
|
||||||
|
rev = "49";
|
||||||
|
sha256 = "sha256-q3jL8yGLgcNxXHPh9M9cTVtUvonrBUPNxuPJIvu7Q/s=";
|
||||||
|
};
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
# Look for the new(?) name
|
||||||
|
substituteInPlace CMakeLists.txt \
|
||||||
|
--replace 'NetworkManager' 'libnm'
|
||||||
|
|
||||||
|
# Workaround for "error: expected unqualified-id before 'public'" on "**signals"
|
||||||
|
sed -i -e '/add_definitions/a -DQT_NO_KEYWORDS' CMakeLists.txt
|
||||||
|
'' + lib.optionalString (!finalAttrs.doCheck) ''
|
||||||
|
# Don't build tests when we're not running them
|
||||||
|
sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt
|
||||||
|
'';
|
||||||
|
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
cmake
|
||||||
|
pkg-config
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
cmake-extras
|
||||||
|
libqtdbustest
|
||||||
|
networkmanager
|
||||||
|
qtbase
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeCheckInputs = [
|
||||||
|
dbus
|
||||||
|
dbus-test-runner
|
||||||
|
procps
|
||||||
|
(python3.withPackages (ps: with ps; [
|
||||||
|
python-dbusmock
|
||||||
|
]))
|
||||||
|
];
|
||||||
|
|
||||||
|
checkInputs = [
|
||||||
|
gtest
|
||||||
|
];
|
||||||
|
|
||||||
|
dontWrapQtApps = true;
|
||||||
|
|
||||||
|
doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform;
|
||||||
|
|
||||||
|
enableParallelChecking = false;
|
||||||
|
|
||||||
|
checkPhase = ''
|
||||||
|
runHook preCheck
|
||||||
|
|
||||||
|
dbus-test-runner -t make -p test -p "''${enableParallelChecking:+-j $NIX_BUILD_CORES}"
|
||||||
|
|
||||||
|
runHook postCheck
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage;
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Library for mocking DBus interactions using Qt";
|
||||||
|
homepage = "https://launchpad.net/libqtdbusmock";
|
||||||
|
license = licenses.lgpl3Only;
|
||||||
|
platforms = platforms.unix;
|
||||||
|
maintainers = teams.lomiri.members;
|
||||||
|
pkgConfigModules = [
|
||||||
|
"libqtdbusmock-1"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
})
|
102
pkgs/development/libraries/libqtdbustest/default.nix
Normal file
102
pkgs/development/libraries/libqtdbustest/default.nix
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
{ stdenv
|
||||||
|
, lib
|
||||||
|
, fetchbzr
|
||||||
|
, fetchpatch
|
||||||
|
, testers
|
||||||
|
, cmake
|
||||||
|
, cmake-extras
|
||||||
|
, dbus
|
||||||
|
, dbus-test-runner
|
||||||
|
, gtest
|
||||||
|
, pkg-config
|
||||||
|
, procps
|
||||||
|
, python3
|
||||||
|
, qtbase
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
|
pname = "libqtdbustest";
|
||||||
|
version = "unstable-2017-01-06";
|
||||||
|
|
||||||
|
src = fetchbzr {
|
||||||
|
url = "lp:libqtdbustest";
|
||||||
|
rev = "42";
|
||||||
|
sha256 = "sha256-5MQdGGtEVE/pM9u0B0xFXyITiRln9p+8/MLtrrCZqi8=";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# Tests are overly pedantic when looking for launched process names in `ps`, break on python wrapper vs real python
|
||||||
|
# Just check if basename + arguments match, like libqtdbusmock does
|
||||||
|
./less-pedantic-process-finding.patch
|
||||||
|
|
||||||
|
# Disable QProcess start timeout
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://salsa.debian.org/debian-ayatana-team/libqtdbustest/-/raw/0788df10bc6f2aa47c2b73fc1df944686a9ace1e/debian/patches/1003_no-QProcess-waitForstarted-timeout.patch";
|
||||||
|
hash = "sha256-ThDbn6URvkj5ARDMj+xO0fb1Qh2YQRzVy24O03KglHI=";
|
||||||
|
})
|
||||||
|
|
||||||
|
# More robust dbus address reading
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://salsa.debian.org/debian-ayatana-team/libqtdbustest/-/raw/7e55c79cd032c702b30d834c1fb0b65661fc6eeb/debian/patches/1004_make-reading-address-from-dbus-daemon-more-robust.patch";
|
||||||
|
hash = "sha256-hq8pdducp/udxoGWGt1dgL/7VHcbJO/oT1dOY1zew8M=";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
postPatch = lib.optionalString (!finalAttrs.doCheck) ''
|
||||||
|
# Don't build tests when we're not running them
|
||||||
|
sed -i -e '/add_subdirectory(tests)/d' CMakeLists.txt
|
||||||
|
'';
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
cmake
|
||||||
|
pkg-config
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
cmake-extras
|
||||||
|
qtbase
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeCheckInputs = [
|
||||||
|
dbus
|
||||||
|
dbus-test-runner
|
||||||
|
procps
|
||||||
|
(python3.withPackages (ps: with ps; [
|
||||||
|
python-dbusmock
|
||||||
|
]))
|
||||||
|
];
|
||||||
|
|
||||||
|
checkInputs = [
|
||||||
|
gtest
|
||||||
|
];
|
||||||
|
|
||||||
|
dontWrapQtApps = true;
|
||||||
|
|
||||||
|
doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform;
|
||||||
|
|
||||||
|
enableParallelChecking = false;
|
||||||
|
|
||||||
|
checkPhase = ''
|
||||||
|
runHook preCheck
|
||||||
|
|
||||||
|
dbus-test-runner -t make -p test -p "''${enableParallelChecking:+-j $NIX_BUILD_CORES}"
|
||||||
|
|
||||||
|
runHook postCheck
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage;
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "Library for testing DBus interactions using Qt";
|
||||||
|
homepage = "https://launchpad.net/libqtdbustest";
|
||||||
|
license = licenses.lgpl3Only;
|
||||||
|
platforms = platforms.unix;
|
||||||
|
maintainers = teams.lomiri.members;
|
||||||
|
mainProgram = "qdbus-simple-test-runner";
|
||||||
|
pkgConfigModules = [
|
||||||
|
"libqtdbustest-1"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
})
|
@ -0,0 +1,86 @@
|
|||||||
|
diff '--color=auto' -ur '--color=never' a/tests/libqtdbustest/TestDBusTestRunner.cpp b/tests/libqtdbustest/TestDBusTestRunner.cpp
|
||||||
|
--- a/tests/libqtdbustest/TestDBusTestRunner.cpp 2023-01-20 21:36:16.948292559 +0100
|
||||||
|
+++ b/tests/libqtdbustest/TestDBusTestRunner.cpp 2023-01-20 21:55:40.554530221 +0100
|
||||||
|
@@ -44,7 +44,7 @@
|
||||||
|
TEST_F(TestDBusTestRunner, StartsSessionService) {
|
||||||
|
QSharedPointer<QProcessDBusService> process(
|
||||||
|
new QProcessDBusService("test.session.name",
|
||||||
|
- QDBusConnection::SessionBus, "/usr/bin/python3",
|
||||||
|
+ QDBusConnection::SessionBus, "python3",
|
||||||
|
QStringList() << "-m" << "dbusmock" << "test.session.name"
|
||||||
|
<< "/test/object" << "test.Interface"));
|
||||||
|
|
||||||
|
@@ -58,15 +58,14 @@
|
||||||
|
pgrep.waitForFinished();
|
||||||
|
pgrep.waitForReadyRead();
|
||||||
|
|
||||||
|
- EXPECT_EQ(
|
||||||
|
- "/usr/bin/python3 -m dbusmock test.session.name /test/object test.Interface",
|
||||||
|
- QString::fromUtf8(pgrep.readAll().trimmed()).toStdString());
|
||||||
|
+ EXPECT_TRUE(
|
||||||
|
+ pgrep.readAll().contains("python3 -m dbusmock test.session.name /test/object test.Interface"));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(TestDBusTestRunner, StartsSystemService) {
|
||||||
|
QSharedPointer<QProcessDBusService> process(
|
||||||
|
new QProcessDBusService("test.system.name",
|
||||||
|
- QDBusConnection::SystemBus, "/usr/bin/python3",
|
||||||
|
+ QDBusConnection::SystemBus, "python3",
|
||||||
|
QStringList() << "-m" << "dbusmock" << "-s"
|
||||||
|
<< "test.system.name" << "/test/object"
|
||||||
|
<< "test.Interface"));
|
||||||
|
@@ -81,9 +80,8 @@
|
||||||
|
pgrep.waitForFinished();
|
||||||
|
pgrep.waitForReadyRead();
|
||||||
|
|
||||||
|
- EXPECT_EQ(
|
||||||
|
- "/usr/bin/python3 -m dbusmock -s test.system.name /test/object test.Interface",
|
||||||
|
- QString::fromUtf8(pgrep.readAll().trimmed()).toStdString());
|
||||||
|
+ EXPECT_TRUE(
|
||||||
|
+ pgrep.readAll().contains("python3 -m dbusmock -s test.system.name /test/object test.Interface"));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(TestDBusTestRunner, SetsEnvironmentVariables) {
|
||||||
|
diff '--color=auto' -ur '--color=never' a/tests/libqtdbustest/TestQProcessDBusService.cpp b/tests/libqtdbustest/TestQProcessDBusService.cpp
|
||||||
|
--- a/tests/libqtdbustest/TestQProcessDBusService.cpp 2023-01-20 21:36:16.948292559 +0100
|
||||||
|
+++ b/tests/libqtdbustest/TestQProcessDBusService.cpp 2023-01-20 21:54:34.633384937 +0100
|
||||||
|
@@ -45,7 +45,7 @@
|
||||||
|
|
||||||
|
TEST_F(TestQProcessDBusService, WaitsForServiceAppeared) {
|
||||||
|
QProcessDBusService process("test.name", QDBusConnection::SessionBus,
|
||||||
|
- "/usr/bin/python3",
|
||||||
|
+ "python3",
|
||||||
|
QStringList() << "-m" << "dbusmock" << "test.name" << "/test/object"
|
||||||
|
<< "test.Interface");
|
||||||
|
|
||||||
|
@@ -58,14 +58,13 @@
|
||||||
|
pgrep.waitForFinished();
|
||||||
|
pgrep.waitForReadyRead();
|
||||||
|
|
||||||
|
- EXPECT_EQ(
|
||||||
|
- "/usr/bin/python3 -m dbusmock test.name /test/object test.Interface",
|
||||||
|
- QString::fromUtf8(pgrep.readAll().trimmed()).toStdString());
|
||||||
|
+ EXPECT_TRUE(
|
||||||
|
+ pgrep.readAll().contains("python3 -m dbusmock test.name /test/object test.Interface"));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_F(TestQProcessDBusService, ThrowsErrorForFailToStart) {
|
||||||
|
QProcessDBusService process("test.name", QDBusConnection::SessionBus,
|
||||||
|
- "/usr/bin/python3",
|
||||||
|
+ "python3",
|
||||||
|
QStringList() << "-m" << "dbusmock" << "not.test.name"
|
||||||
|
<< "/test/object" << "test.Interface");
|
||||||
|
|
||||||
|
diff '--color=auto' -ur '--color=never' a/tests/libqtdbustest/TestSuicidalProcess.cpp b/tests/libqtdbustest/TestSuicidalProcess.cpp
|
||||||
|
--- a/tests/libqtdbustest/TestSuicidalProcess.cpp 2023-01-20 21:36:16.948292559 +0100
|
||||||
|
+++ b/tests/libqtdbustest/TestSuicidalProcess.cpp 2023-01-20 21:55:07.219951081 +0100
|
||||||
|
@@ -51,8 +51,7 @@
|
||||||
|
pgrep.waitForFinished();
|
||||||
|
pgrep.waitForReadyRead();
|
||||||
|
|
||||||
|
- EXPECT_EQ("sleep 5",
|
||||||
|
- QString::fromUtf8(pgrep.readAll().trimmed()).toStdString());
|
||||||
|
+ EXPECT_TRUE(pgrep.readAll().contains("sleep 5"));
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
80
pkgs/development/tools/dbus-test-runner/default.nix
Normal file
80
pkgs/development/tools/dbus-test-runner/default.nix
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
{ stdenv
|
||||||
|
, lib
|
||||||
|
, fetchbzr
|
||||||
|
, testers
|
||||||
|
, autoreconfHook
|
||||||
|
, bash
|
||||||
|
, coreutils
|
||||||
|
, dbus
|
||||||
|
, dbus-glib
|
||||||
|
, glib
|
||||||
|
, intltool
|
||||||
|
, pkg-config
|
||||||
|
, python3
|
||||||
|
, xvfb-run
|
||||||
|
}:
|
||||||
|
|
||||||
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
|
pname = "dbus-test-runner";
|
||||||
|
version = "unstable-2019-10-02";
|
||||||
|
|
||||||
|
src = fetchbzr {
|
||||||
|
url = "lp:dbus-test-runner";
|
||||||
|
rev = "109";
|
||||||
|
sha256 = "sha256-4yH19X98SVqpviCBIWzIX6FYHWxCbREpuKCNjQuTFDk=";
|
||||||
|
};
|
||||||
|
|
||||||
|
postPatch = ''
|
||||||
|
patchShebangs tests/test-wait-outputer
|
||||||
|
|
||||||
|
# Tests `cat` together build shell scripts
|
||||||
|
# true is a PATHable call, bash a shebang
|
||||||
|
substituteInPlace tests/Makefile.am \
|
||||||
|
--replace '/bin/true' 'true' \
|
||||||
|
--replace '/bin/bash' '${lib.getExe bash}'
|
||||||
|
'';
|
||||||
|
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
autoreconfHook
|
||||||
|
glib # for autoconf macro, gtester, gdbus
|
||||||
|
intltool
|
||||||
|
pkg-config
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
dbus-glib
|
||||||
|
glib
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeCheckInputs = [
|
||||||
|
bash
|
||||||
|
dbus
|
||||||
|
(python3.withPackages (ps: with ps; [
|
||||||
|
python-dbusmock
|
||||||
|
]))
|
||||||
|
xvfb-run
|
||||||
|
];
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
doCheck = stdenv.buildPlatform.canExecute stdenv.hostPlatform;
|
||||||
|
|
||||||
|
checkFlags = [
|
||||||
|
"XVFB_RUN=${lib.getExe xvfb-run}"
|
||||||
|
];
|
||||||
|
|
||||||
|
passthru.tests.pkg-config = testers.testMetaPkgConfig finalAttrs.finalPackage;
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "A small little utility to run a couple of executables under a new DBus session for testing";
|
||||||
|
homepage = "https://launchpad.net/dbus-test-runner";
|
||||||
|
license = licenses.gpl3Only;
|
||||||
|
platforms = platforms.unix;
|
||||||
|
maintainers = teams.lomiri.members;
|
||||||
|
pkgConfigModules = [
|
||||||
|
"dbustest-1"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
})
|
@ -17970,6 +17970,8 @@ with pkgs;
|
|||||||
|
|
||||||
ansible-doctor = callPackage ../tools/admin/ansible/doctor.nix { };
|
ansible-doctor = callPackage ../tools/admin/ansible/doctor.nix { };
|
||||||
|
|
||||||
|
dbus-test-runner = callPackage ../development/tools/dbus-test-runner { };
|
||||||
|
|
||||||
phpunit = callPackage ../development/tools/misc/phpunit { };
|
phpunit = callPackage ../development/tools/misc/phpunit { };
|
||||||
|
|
||||||
teller = callPackage ../development/tools/teller { };
|
teller = callPackage ../development/tools/teller { };
|
||||||
@ -22507,6 +22509,14 @@ with pkgs;
|
|||||||
|
|
||||||
libplist = callPackage ../development/libraries/libplist { };
|
libplist = callPackage ../development/libraries/libplist { };
|
||||||
|
|
||||||
|
libqtdbusmock = libsForQt5.callPackage ../development/libraries/libqtdbusmock {
|
||||||
|
inherit (lomiri) cmake-extras;
|
||||||
|
};
|
||||||
|
|
||||||
|
libqtdbustest = libsForQt5.callPackage ../development/libraries/libqtdbustest {
|
||||||
|
inherit (lomiri) cmake-extras;
|
||||||
|
};
|
||||||
|
|
||||||
libre = callPackage ../development/libraries/libre { };
|
libre = callPackage ../development/libraries/libre { };
|
||||||
|
|
||||||
libredwg = callPackage ../development/libraries/libredwg { };
|
libredwg = callPackage ../development/libraries/libredwg { };
|
||||||
@ -37954,6 +37964,8 @@ with pkgs;
|
|||||||
|
|
||||||
gnustep = recurseIntoAttrs (callPackage ../desktops/gnustep { });
|
gnustep = recurseIntoAttrs (callPackage ../desktops/gnustep { });
|
||||||
|
|
||||||
|
lomiri = recurseIntoAttrs (callPackage ../desktops/lomiri { });
|
||||||
|
|
||||||
lumina = recurseIntoAttrs (callPackage ../desktops/lumina { });
|
lumina = recurseIntoAttrs (callPackage ../desktops/lumina { });
|
||||||
|
|
||||||
### DESKTOPS/LXDE
|
### DESKTOPS/LXDE
|
||||||
|
Loading…
Reference in New Issue
Block a user