diff options
author | Pascal Rigaux <pixel@mandriva.com> | 2008-07-07 20:46:40 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 2008-07-07 20:46:40 +0000 |
commit | c617573f7ca65da803615991419db926420f22b1 (patch) | |
tree | bb3d7d440cbeec7fee53d0751c5232f31a4c8548 /t/superuser--orphans.t | |
parent | c54d9828bb2eb4a38197b8d656aefd52c9c9ea36 (diff) | |
download | urpmi-c617573f7ca65da803615991419db926420f22b1.tar urpmi-c617573f7ca65da803615991419db926420f22b1.tar.gz urpmi-c617573f7ca65da803615991419db926420f22b1.tar.bz2 urpmi-c617573f7ca65da803615991419db926420f22b1.tar.xz urpmi-c617573f7ca65da803615991419db926420f22b1.zip |
o handle "unrequested orphans" (similar to "deborphan")
Diffstat (limited to 't/superuser--orphans.t')
-rw-r--r-- | t/superuser--orphans.t | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/t/superuser--orphans.t b/t/superuser--orphans.t new file mode 100644 index 00000000..d9369a36 --- /dev/null +++ b/t/superuser--orphans.t @@ -0,0 +1,99 @@ +#!/usr/bin/perl + +# a-1 upgrades to a-2 +# b-1 upgrades to bb-2 (via obsoletes) +# c-1 (requires cc) upgrades to c-2 (requires cc) +# d-1 (requires dd) upgrades to d-2 +# e-1 (requires ee1) upgrades to e-2 (requires ee2) +# f-1 (requires ff1) upgrades to f-2 (requires ff2), ff2 conflicts with ff1 +# g-1 (requires gg = 1) upgrades to g-2 (requires gg = 2) +# h-1 (suggests hh) upgrades to h-2 +# +# l-1 upgrades to l-2, l requires ll and ll requires l +# m-1 (requires mm = 1) upgrades to m-2 (requires mm = 2), mm requires m (circular dep) +# n-1 (requires nn = 1) upgrades to n-2 (requires nn = 2), nn-1 requires n-1, nn-2 requires n-2 (circular dep) +# o-1 (requires oo1) upgrades to o-2 (requires oo2), oo1 requires o = 1, oo2 requires o = 2 (circular dep) +# +# r-1 (requires rr) upgrades to r-2, rr1 provides rr, rr2 provides rr +# s-1 (requires ss1 and ss2) upgrades to s-2 (requires ss), ss1-2 provides ss, ss2-2 provides ss +# t-1 (requires tt >= 1) upgrades to t-2 (requires tt >= 2), tt1-1 provides tt = 1, tt1-2 provides tt = 2 +# +# req-a requires a, req-b requires b... +# +use strict; +use lib '.', 't'; +use helper; +use urpm::util; +use Test::More 'no_plan'; + +need_root_and_prepare(); + + +my $name = 'orphans'; +urpmi_addmedia("$name-1 $::pwd/media/$name-1"); +urpmi_addmedia("$name-2 $::pwd/media/$name-2"); + +# we want urpmi --auto-select to always check orphans (when not using --auto-orphans) +set_urpmi_cfg_global_options({ 'nb-of-new-unrequested-pkgs-between-auto-select-orphans-check' => 0 }); + + +test_auto_select_both('a', 'a', 'a-2'); +test_auto_select_both('b', 'b', 'bb-2'); +test_auto_select_both('c', 'c cc', 'c-2 cc-1'); +test_auto_select_both('d', 'd dd', 'd-2', 'dd-1'); +test_auto_select_both('e', 'e ee1', 'e-2 ee2-2', 'ee1-1'); +test_auto_select_both('f', 'f ff1', 'f-2 ff2-2'); +test_auto_select_both('g', 'g gg', 'g-2 gg-2'); +test_auto_select_both('h', 'h hh', 'h-2', 'hh-1'); +test_auto_select_both('l', 'l ll', 'l-2 ll-1'); +test_auto_select_both('m', 'm mm', 'm-2 mm-2'); +test_auto_select_both('n', 'n nn', 'n-2 nn-2'); +test_auto_select_both('o', 'o oo1', 'o-2 oo2-2'); +test_auto_select_both('r', 'r rr2', 'r-2', 'rr2-1'); +test_auto_select_both('s', 's ss1 ss2', 's-2 ss1-1 ss2-1'); +test_auto_select_both('t', 't tt1', 't-2 tt2-2', 'tt1-1'); + +test_auto_select(['r', 'rr1'], 'r rr1 rr2', 'r-2 rr1-1', 'rr2-1'); +#test_auto_select(['s ss1'], 's ss1 ss2', 's-2 ss1-1', 'ss2-1'); # this fails, but that's ok + +sub add_version1 { map { "$_-1-1" } split(' ', $_[0] || '') } +sub add_version2 { map { "$_-2-1" } split(' ', $_[0] || '') } +sub add_release { map { "$_-1" } split(' ', $_[0] || '') } +sub add_version1_s { join(' ', add_version1(@_)) } +sub add_version2_s { join(' ', add_version2(@_)) } +sub add_release_s { join(' ', add_release(@_)) } + +sub test_auto_select_both { + my ($pkg, $wanted_v1, $wanted_v2, $orphans_v2) = @_; + + $orphans_v2 ||= ''; + test_auto_select([$pkg], $wanted_v1, $wanted_v2, $orphans_v2); + test_auto_select(["req-$pkg"], "req-$pkg $wanted_v1", "req-$pkg-2", "$wanted_v2 $orphans_v2"); +} + +sub test_auto_select { + my ($req_v1, $wanted_v1, $wanted_v2, $orphans_v2) = @_; + test_auto_select_raw_urpmq_urpme ($req_v1, add_version1_s($wanted_v1), add_release_s($wanted_v2), add_release_s($orphans_v2)); + test_auto_select_raw_auto_orphans($req_v1, add_version1_s($wanted_v1), add_release_s($wanted_v2)); +} + +sub test_auto_select_raw_urpmq_urpme { + my ($req_v1, $wanted_v1, $wanted_v2, $orphans_v2) = @_; + print "# test_auto_select_raw_urpmq_urpme(@$req_v1, $wanted_v1, $wanted_v2)\n"; + urpmi("--media $name-1 --auto $_") foreach @$req_v1; + check_installed_fullnames(split ' ', $wanted_v1); + urpmi("--media $name-2 --auto --auto-select"); + check_installed_fullnames(split ' ', "$wanted_v2 $orphans_v2"); + is(run_urpm_cmd('urpmq -r --auto-orphans'), join('', sort map { "$_\n" } split ' ', $orphans_v2)); + urpme("--auto --auto-orphans"); + check_installed_fullnames_and_remove(split ' ', $wanted_v2); +} + +sub test_auto_select_raw_auto_orphans { + my ($req_v1, $wanted_v1, $wanted_v2) = @_; + print "# test_auto_select_raw_auto_orphans(@$req_v1, $wanted_v1, $wanted_v2)\n"; + urpmi("--media $name-1 --auto $_") foreach @$req_v1; + check_installed_fullnames(split ' ', $wanted_v1); + urpmi("--media $name-2 --auto --auto-select --auto-orphans"); + check_installed_fullnames_and_remove(split ' ', $wanted_v2); +} |