upower: Add installed tests
This commit is contained in:
parent
b9c867fdad
commit
d08e84b3be
@ -107,5 +107,6 @@ in
|
|||||||
malcontent = callInstalledTest ./malcontent.nix {};
|
malcontent = callInstalledTest ./malcontent.nix {};
|
||||||
ostree = callInstalledTest ./ostree.nix {};
|
ostree = callInstalledTest ./ostree.nix {};
|
||||||
pipewire = callInstalledTest ./pipewire.nix {};
|
pipewire = callInstalledTest ./pipewire.nix {};
|
||||||
|
upower = callInstalledTest ./upower.nix {};
|
||||||
xdg-desktop-portal = callInstalledTest ./xdg-desktop-portal.nix {};
|
xdg-desktop-portal = callInstalledTest ./xdg-desktop-portal.nix {};
|
||||||
}
|
}
|
||||||
|
9
nixos/tests/installed-tests/upower.nix
Normal file
9
nixos/tests/installed-tests/upower.nix
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{ pkgs, makeInstalledTest, ... }:
|
||||||
|
|
||||||
|
makeInstalledTest {
|
||||||
|
tested = pkgs.upower;
|
||||||
|
|
||||||
|
testConfig = {
|
||||||
|
services.upower.enable = true;
|
||||||
|
};
|
||||||
|
}
|
@ -2,6 +2,7 @@
|
|||||||
, stdenv
|
, stdenv
|
||||||
, fetchFromGitLab
|
, fetchFromGitLab
|
||||||
, fetchpatch
|
, fetchpatch
|
||||||
|
, makeWrapper
|
||||||
, pkg-config
|
, pkg-config
|
||||||
, rsync
|
, rsync
|
||||||
, libxslt
|
, libxslt
|
||||||
@ -23,13 +24,14 @@
|
|||||||
, useIMobileDevice ? true
|
, useIMobileDevice ? true
|
||||||
, libimobiledevice
|
, libimobiledevice
|
||||||
, withDocs ? (stdenv.buildPlatform == stdenv.hostPlatform)
|
, withDocs ? (stdenv.buildPlatform == stdenv.hostPlatform)
|
||||||
|
, nixosTests
|
||||||
}:
|
}:
|
||||||
|
|
||||||
stdenv.mkDerivation (finalAttrs: {
|
stdenv.mkDerivation (finalAttrs: {
|
||||||
pname = "upower";
|
pname = "upower";
|
||||||
version = "1.90.2";
|
version = "1.90.2";
|
||||||
|
|
||||||
outputs = [ "out" "dev" ]
|
outputs = [ "out" "dev" "installedTests" ]
|
||||||
++ lib.optionals withDocs [ "devdoc" ];
|
++ lib.optionals withDocs [ "devdoc" ];
|
||||||
|
|
||||||
src = fetchFromGitLab {
|
src = fetchFromGitLab {
|
||||||
@ -44,6 +46,8 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
# Remove when this is fixed upstream:
|
# Remove when this is fixed upstream:
|
||||||
# https://gitlab.freedesktop.org/upower/upower/-/issues/214
|
# https://gitlab.freedesktop.org/upower/upower/-/issues/214
|
||||||
./i686-test-remove-battery-check.patch
|
./i686-test-remove-battery-check.patch
|
||||||
|
] ++ [
|
||||||
|
./installed-tests-path.patch
|
||||||
];
|
];
|
||||||
|
|
||||||
strictDeps = true;
|
strictDeps = true;
|
||||||
@ -61,6 +65,7 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
gettext
|
gettext
|
||||||
gobject-introspection
|
gobject-introspection
|
||||||
libxslt
|
libxslt
|
||||||
|
makeWrapper
|
||||||
pkg-config
|
pkg-config
|
||||||
rsync
|
rsync
|
||||||
];
|
];
|
||||||
@ -72,6 +77,14 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
systemd
|
systemd
|
||||||
# Duplicate from nativeCheckInputs until https://github.com/NixOS/nixpkgs/issues/161570 is solved
|
# Duplicate from nativeCheckInputs until https://github.com/NixOS/nixpkgs/issues/161570 is solved
|
||||||
umockdev
|
umockdev
|
||||||
|
|
||||||
|
# For installed tests.
|
||||||
|
(python3.withPackages (pp: [
|
||||||
|
pp.dbus-python
|
||||||
|
pp.python-dbusmock
|
||||||
|
pp.pygobject3
|
||||||
|
pp.packaging
|
||||||
|
]))
|
||||||
] ++ lib.optionals useIMobileDevice [
|
] ++ lib.optionals useIMobileDevice [
|
||||||
libimobiledevice
|
libimobiledevice
|
||||||
];
|
];
|
||||||
@ -99,6 +112,7 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
"-Dudevhwdbdir=${placeholder "out"}/lib/udev/hwdb.d"
|
"-Dudevhwdbdir=${placeholder "out"}/lib/udev/hwdb.d"
|
||||||
"-Dintrospection=${if (stdenv.buildPlatform == stdenv.hostPlatform) then "auto" else "disabled"}"
|
"-Dintrospection=${if (stdenv.buildPlatform == stdenv.hostPlatform) then "auto" else "disabled"}"
|
||||||
"-Dgtk-doc=${lib.boolToString withDocs}"
|
"-Dgtk-doc=${lib.boolToString withDocs}"
|
||||||
|
"-Dinstalled_test_prefix=${placeholder "installedTests"}"
|
||||||
];
|
];
|
||||||
|
|
||||||
doCheck = true;
|
doCheck = true;
|
||||||
@ -106,6 +120,9 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
postPatch = ''
|
postPatch = ''
|
||||||
patchShebangs src/linux/integration-test.py
|
patchShebangs src/linux/integration-test.py
|
||||||
patchShebangs src/linux/unittest_inspector.py
|
patchShebangs src/linux/unittest_inspector.py
|
||||||
|
|
||||||
|
substituteInPlace src/linux/integration-test.py \
|
||||||
|
--replace "/usr/share/dbus-1" "$out/share/dbus-1"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
preCheck = ''
|
preCheck = ''
|
||||||
@ -127,6 +144,14 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
runHook postCheck
|
runHook postCheck
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
postCheck = ''
|
||||||
|
# Undo patchShebangs from postPatch so that it can be replaced with runtime shebang
|
||||||
|
# unittest_inspector.py intentionally not reverted because it would trigger
|
||||||
|
# meson rebuild during install and it is not used at runtime anyway.
|
||||||
|
sed -Ei 's~#!.+/bin/python3~#!/usr/bin/python3~' \
|
||||||
|
../src/linux/integration-test.py
|
||||||
|
'';
|
||||||
|
|
||||||
postInstall = ''
|
postInstall = ''
|
||||||
# Move stuff from DESTDIR to proper location.
|
# Move stuff from DESTDIR to proper location.
|
||||||
# We use rsync to merge the directories.
|
# We use rsync to merge the directories.
|
||||||
@ -134,7 +159,7 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
rsync --archive "$DESTDIR/$dir" "$out"
|
rsync --archive "$DESTDIR/$dir" "$out"
|
||||||
rm --recursive "$DESTDIR/$dir"
|
rm --recursive "$DESTDIR/$dir"
|
||||||
done
|
done
|
||||||
for o in out dev; do
|
for o in out dev installedTests; do
|
||||||
rsync --archive "$DESTDIR/''${!o}" "$(dirname "''${!o}")"
|
rsync --archive "$DESTDIR/''${!o}" "$(dirname "''${!o}")"
|
||||||
rm --recursive "$DESTDIR/''${!o}"
|
rm --recursive "$DESTDIR/''${!o}"
|
||||||
done
|
done
|
||||||
@ -142,6 +167,17 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
rmdir "$DESTDIR/nix/store" "$DESTDIR/nix" "$DESTDIR"
|
rmdir "$DESTDIR/nix/store" "$DESTDIR/nix" "$DESTDIR"
|
||||||
'';
|
'';
|
||||||
|
|
||||||
|
postFixup = ''
|
||||||
|
wrapProgram "$installedTests/libexec/upower/integration-test.py" \
|
||||||
|
--prefix GI_TYPELIB_PATH : "${lib.makeSearchPath "lib/girepository-1.0" [
|
||||||
|
"$out"
|
||||||
|
umockdev.out
|
||||||
|
]}" \
|
||||||
|
--prefix PATH : "${lib.makeBinPath [
|
||||||
|
umockdev
|
||||||
|
]}"
|
||||||
|
'';
|
||||||
|
|
||||||
env = {
|
env = {
|
||||||
# HACK: We want to install configuration files to $out/etc
|
# HACK: We want to install configuration files to $out/etc
|
||||||
# but upower should read them from /etc on a NixOS system.
|
# but upower should read them from /etc on a NixOS system.
|
||||||
@ -152,6 +188,12 @@ stdenv.mkDerivation (finalAttrs: {
|
|||||||
DESTDIR = "${placeholder "out"}/dest";
|
DESTDIR = "${placeholder "out"}/dest";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
tests = {
|
||||||
|
installedTests = nixosTests.installed-tests.upower;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
homepage = "https://upower.freedesktop.org/";
|
homepage = "https://upower.freedesktop.org/";
|
||||||
changelog = "https://gitlab.freedesktop.org/upower/upower/-/blob/v${finalAttrs.version}/NEWS";
|
changelog = "https://gitlab.freedesktop.org/upower/upower/-/blob/v${finalAttrs.version}/NEWS";
|
||||||
|
56
pkgs/os-specific/linux/upower/installed-tests-path.patch
Normal file
56
pkgs/os-specific/linux/upower/installed-tests-path.patch
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
diff --git a/meson_options.txt b/meson_options.txt
|
||||||
|
index eec3659..f064a1b 100644
|
||||||
|
--- a/meson_options.txt
|
||||||
|
+++ b/meson_options.txt
|
||||||
|
@@ -6,6 +6,10 @@ option('gtk-doc',
|
||||||
|
type : 'boolean',
|
||||||
|
value : 'true',
|
||||||
|
description : 'Build developer documentation')
|
||||||
|
+option('installed_test_prefix',
|
||||||
|
+ type: 'string',
|
||||||
|
+ value: '',
|
||||||
|
+ description: 'Prefix for installed tests')
|
||||||
|
option('introspection',
|
||||||
|
type : 'feature',
|
||||||
|
value : 'auto',
|
||||||
|
diff --git a/src/meson.build b/src/meson.build
|
||||||
|
index a2352ac..c1f25ac 100644
|
||||||
|
--- a/src/meson.build
|
||||||
|
+++ b/src/meson.build
|
||||||
|
@@ -85,6 +85,7 @@ install_subdir('does-not-exist', install_dir: historydir, strip_directory : true
|
||||||
|
|
||||||
|
cdata = configuration_data()
|
||||||
|
cdata.set('libexecdir', get_option('prefix') / get_option('libexecdir'))
|
||||||
|
+cdata.set('installed_test_bindir', get_option('installed_test_prefix') / 'libexec' / 'upower')
|
||||||
|
cdata.set('historydir', historydir)
|
||||||
|
|
||||||
|
configure_file(
|
||||||
|
@@ -147,16 +148,16 @@ if os_backend == 'linux' and gobject_introspection.found()
|
||||||
|
'linux/integration-test.py',
|
||||||
|
'linux/output_checker.py',
|
||||||
|
],
|
||||||
|
- install_dir: get_option('prefix') / get_option('libexecdir') / 'upower'
|
||||||
|
+ install_dir: get_option('installed_test_prefix') / 'libexec' / 'upower'
|
||||||
|
)
|
||||||
|
install_subdir('linux/tests/',
|
||||||
|
- install_dir: get_option('prefix') / get_option('libexecdir') / 'upower'
|
||||||
|
+ install_dir: get_option('installed_test_prefix') / 'libexec' / 'upower'
|
||||||
|
)
|
||||||
|
|
||||||
|
configure_file(
|
||||||
|
input: 'upower-integration.test.in',
|
||||||
|
output: 'upower-integration.test',
|
||||||
|
- install_dir: get_option('datadir') / 'installed-tests' / 'upower',
|
||||||
|
+ install_dir: get_option('installed_test_prefix') / 'share' / 'installed-tests' / 'upower',
|
||||||
|
configuration: cdata
|
||||||
|
)
|
||||||
|
endif
|
||||||
|
diff --git a/src/upower-integration.test.in b/src/upower-integration.test.in
|
||||||
|
index 151ded0..b0a9bec 100644
|
||||||
|
--- a/src/upower-integration.test.in
|
||||||
|
+++ b/src/upower-integration.test.in
|
||||||
|
@@ -1,3 +1,3 @@
|
||||||
|
[Test]
|
||||||
|
Type=session
|
||||||
|
-Exec=@libexecdir@/upower/integration-test.py
|
||||||
|
+Exec=@installed_test_bindir@/integration-test.py
|
Loading…
Reference in New Issue
Block a user