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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
# Copyright 2017 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
from portage.tests import TestCase
from portage.tests.resolver.ResolverPlayground import (
ResolverPlayground,
ResolverPlaygroundTestCase,
)
class OrDowngradeInstalledTestCase(TestCase):
def testOrDowngradeInstalled(self):
ebuilds = {
'net-misc/foo-1': {
'EAPI': '6',
'RDEPEND': '|| ( sys-libs/glibc[rpc(-)] net-libs/libtirpc )'
},
'net-libs/libtirpc-1': {
'EAPI': '6',
},
'sys-libs/glibc-2.26': {
'EAPI': '6',
'IUSE': ''
},
'sys-libs/glibc-2.24': {
'EAPI': '6',
'IUSE': '+rpc'
},
}
installed = {
'sys-libs/glibc-2.26': {
'EAPI': '6',
'IUSE': ''
},
}
world = ['sys-libs/glibc']
test_cases = (
# Test bug 635540, where we need to install libtirpc
# rather than downgrade glibc.
ResolverPlaygroundTestCase(
['net-misc/foo'],
success=True,
mergelist=[
'net-libs/libtirpc-1',
'net-misc/foo-1',
],
),
)
playground = ResolverPlayground(debug=False,
ebuilds=ebuilds, installed=installed, world=world)
try:
for test_case in test_cases:
playground.run_TestCase(test_case)
self.assertEqual(test_case.test_success, True,
test_case.fail_msg)
finally:
playground.debug = False
playground.cleanup()
# In some cases it's necessary to downgrade due to
# the installed package being masked (glibc is a
# not an ideal example because it's usually not
# practical to downgrade it).
user_config = {
"package.mask" : (
">=sys-libs/glibc-2.26",
),
}
test_cases = (
ResolverPlaygroundTestCase(
['net-misc/foo'],
success=True,
mergelist=[
'sys-libs/glibc-2.24',
'net-misc/foo-1',
],
),
)
playground = ResolverPlayground(debug=False,
ebuilds=ebuilds, installed=installed, world=world,
user_config=user_config)
try:
for test_case in test_cases:
playground.run_TestCase(test_case)
self.assertEqual(test_case.test_success, True,
test_case.fail_msg)
finally:
playground.debug = False
playground.cleanup()
|