mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-09-21 12:38:41 +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;
|
||||
};
|
||||
|
||||
lomiri = {
|
||||
members = [
|
||||
OPNA2608
|
||||
];
|
||||
scope = "Maintain Lomiri desktop environment and related packages.";
|
||||
shortName = "Lomiri";
|
||||
enableFeatureFreezePing = true;
|
||||
};
|
||||
|
||||
lumiguide = {
|
||||
# Verify additions by approval of an already existing member of the team.
|
||||
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 { };
|
||||
|
||||
dbus-test-runner = callPackage ../development/tools/dbus-test-runner { };
|
||||
|
||||
phpunit = callPackage ../development/tools/misc/phpunit { };
|
||||
|
||||
teller = callPackage ../development/tools/teller { };
|
||||
@ -22507,6 +22509,14 @@ with pkgs;
|
||||
|
||||
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 { };
|
||||
|
||||
libredwg = callPackage ../development/libraries/libredwg { };
|
||||
@ -37954,6 +37964,8 @@ with pkgs;
|
||||
|
||||
gnustep = recurseIntoAttrs (callPackage ../desktops/gnustep { });
|
||||
|
||||
lomiri = recurseIntoAttrs (callPackage ../desktops/lomiri { });
|
||||
|
||||
lumina = recurseIntoAttrs (callPackage ../desktops/lumina { });
|
||||
|
||||
### DESKTOPS/LXDE
|
||||
|
Loading…
Reference in New Issue
Block a user