1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
#!/usr/bin/perl
# a1-1 upgrades to a1-2
# b-1 upgrades to b-2 which requires a2
# a2 conflicts with a1
#
# d1-1 upgrades to d1-2
# c-1 upgrades to c-2 which requires d2
# d2 conflicts with d1
#
# nb: d & c is similar to a & b
# (needed to ensure both ordering works)
#
use strict;
use lib '.', 't';
use helper;
use urpm::util;
use Test::More 'no_plan';
need_root_and_prepare();
my $name = 'handle-conflict-deps2';
urpmi_addmedia("$name $::pwd/media/$name");
# these test have two alternative results; both wanted pkgs can't be installed,
# so urpmi can arbitrarily drop one (after confirming with user, of course)
test(['d1-1', 'c-1'], ['c-2', 'd1-2'], ['c-1', 'd1-2'], ['c-2', 'd2-2']);
test(['a1-1', 'b-1'], ['b-2', 'a1-2'], ['a2-2', 'b-2'], ['a1-2', 'b-1']);
sub test {
my ($first, $wanted, $result1, $result2) = @_;
urpmi("--auto @$first");
check_installed_fullnames(map { "$_-1" } @$first);
# test for bug #52153
system_should_fail("echo n | " . urpmi_cmd() . " @$wanted");
check_installed_fullnames(map { "$_-1" } @$first);
urpmi_partial("--auto @$wanted");
if (system("rpm -q --quiet --root $::pwd/root ".@$result1[0]) == 0) {
check_installed_fullnames_and_remove(map { "$_-1" } @$result1);
} else {
check_installed_fullnames_and_remove(map { "$_-1" } @$result2);
}
}
|