diff options
author | Pascal Rigaux <pixel@mandriva.com> | 2007-04-24 19:34:32 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 2007-04-24 19:34:32 +0000 |
commit | 4df7583caa71a35d6d68c373fc0c62d1be6d955b (patch) | |
tree | bddf36169b314d82ff20036dea7e47fa4fec5bcd /t/superuser--ordering-scriptlets.t | |
parent | 7a606ec3537b2f465f8e06e99b445c756bfcca8f (diff) | |
download | urpmi-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.t | 79 |
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'); +} |