summaryrefslogtreecommitdiffstats
path: root/t/superuser--ordering-scriptlets.t
diff options
context:
space:
mode:
authorPascal Rigaux <pixel@mandriva.com>2007-04-24 19:34:32 +0000
committerPascal Rigaux <pixel@mandriva.com>2007-04-24 19:34:32 +0000
commit4df7583caa71a35d6d68c373fc0c62d1be6d955b (patch)
treebddf36169b314d82ff20036dea7e47fa4fec5bcd /t/superuser--ordering-scriptlets.t
parent7a606ec3537b2f465f8e06e99b445c756bfcca8f (diff)
downloadurpmi-4df7583caa71a35d6d68c373fc0c62d1be6d955b.tar
urpmi-4df7583caa71a35d6d68c373fc0c62d1be6d955b.tar.gz
urpmi-4df7583caa71a35d6d68c373fc0c62d1be6d955b.tar.bz2
urpmi-4df7583caa71a35d6d68c373fc0c62d1be6d955b.tar.xz
urpmi-4df7583caa71a35d6d68c373fc0c62d1be6d955b.zip
re-sync after the big svn loss
Diffstat (limited to 't/superuser--ordering-scriptlets.t')
-rw-r--r--t/superuser--ordering-scriptlets.t79
1 files changed, 79 insertions, 0 deletions
diff --git a/t/superuser--ordering-scriptlets.t b/t/superuser--ordering-scriptlets.t
new file mode 100644
index 00000000..53e3c7cc
--- /dev/null
+++ b/t/superuser--ordering-scriptlets.t
@@ -0,0 +1,79 @@
+#!/usr/bin/perl
+
+use strict;
+use lib '.', 't';
+use helper;
+use Test::More 'no_plan';
+
+my $medium_name = 'ordering-scriptlets';
+
+need_root_and_prepare();
+
+my $ash_1 = "media/$medium_name/ordering_ash-1-*.rpm";
+my $ash_2 = "media/$medium_name/ordering_ash-2-*.rpm";
+
+test_install_remove_rpm("requires_$_") foreach qw(pre post preun postun);
+test_install_upgrade_rpm("requires_$_") foreach qw(preun postun);
+
+test_install_remove_urpmi("requires_$_", '') foreach qw(pre post preun postun);
+test_install_upgrade_urpmi("requires_$_", '') foreach qw(preun postun);
+
+test_install_remove_urpmi("requires_$_", '--split-level 1') foreach qw(pre post preun postun);
+test_install_upgrade_urpmi("requires_$_", '--split-level 1') foreach qw(preun postun);
+
+sub test_install_remove_rpm {
+ my ($name) = @_;
+
+ system_("rpm --root $::pwd/root -i $ash_1 media/$medium_name/$name-1-*.rpm");
+ check_installed_and_remove('ordering_ash', $name);
+
+ system_("rpm --root $::pwd/root -i media/$medium_name/$name-1-*.rpm $ash_1");
+ check_installed_and_remove($name, 'ordering_ash');
+}
+
+sub test_install_upgrade_rpm {
+ my ($name) = @_;
+
+ system_("rpm --root $::pwd/root -i $ash_1 media/$medium_name/$name-1-*.rpm");
+ system_("rpm --root $::pwd/root -U media/$medium_name/$name-2-*.rpm $ash_2");
+ check_installed_and_remove('ordering_ash', $name);
+
+
+ system_("rpm --root $::pwd/root -i media/$medium_name/$name-1-*.rpm $ash_1");
+ system_("rpm --root $::pwd/root -U $ash_2 media/$medium_name/$name-2-*.rpm");
+ check_installed_and_remove($name, 'ordering_ash');
+}
+
+sub test_install_remove_urpmi {
+ my ($name, $urpmi_option) = @_;
+ my @names = ('ordering_ash', $name);
+ my @names_rev = reverse @names;
+
+ urpmi_addmedia("$medium_name $::pwd/media/$medium_name");
+
+ urpmi(join(' ', $urpmi_option, @names));
+ check_installed_and_urpme(@names);
+
+ urpmi(join(' ', $urpmi_option, @names_rev));
+ check_installed_and_urpme(@names_rev);
+
+ urpmi_removemedia('-a');
+}
+
+sub test_install_upgrade_urpmi {
+ my ($name, $urpmi_option) = @_;
+ my @names = ('ordering_ash', $name);
+ my @names_rev = reverse @names;
+
+ urpmi_addmedia("$medium_name $::pwd/media/$medium_name");
+
+ system_("rpm --root $::pwd/root -i $ash_1 media/$medium_name/$name-1-*.rpm");
+ urpmi(join(' ', $urpmi_option, @names));
+ check_installed_and_urpme(@names);
+
+ system_("rpm --root $::pwd/root -i $ash_1 media/$medium_name/$name-1-*.rpm");
+ urpmi(join(' ', $urpmi_option, @names_rev));
+ check_installed_and_urpme(@names_rev);
+
+ urpmi_removemedia('-a');
+}