@ -1945,7 +1945,8 @@ class Britney(object):
"""
"""
undo = { ' binaries ' : { } , ' sources ' : { } , ' virtual ' : { } , ' nvirtual ' : [ ] }
undo = { ' binaries ' : { } , ' sources ' : { } , ' virtual ' : { } , ' nvirtual ' : [ ] }
affected = set ( )
affected_pos = set ( )
affected_remain = set ( )
# local copies for better performance
# local copies for better performance
sources = self . sources
sources = self . sources
@ -1993,8 +1994,8 @@ class Britney(object):
if pkey not in eqv_set :
if pkey not in eqv_set :
# all the reverse dependencies are affected by
# all the reverse dependencies are affected by
# the change
# the change
affected . update ( inst_tester . reverse_dependencies_of ( rm_pkg_id ) )
affected _pos . update ( inst_tester . reverse_dependencies_of ( rm_pkg_id ) )
affected . update ( inst_tester . negative_dependencies_of ( rm_pkg_id ) )
affected _remain . update ( inst_tester . negative_dependencies_of ( rm_pkg_id ) )
# remove the provided virtual packages
# remove the provided virtual packages
for j , prov_version , _ in pkg_data . provides :
for j , prov_version , _ in pkg_data . provides :
@ -2022,7 +2023,7 @@ class Britney(object):
version = binaries_t_a [ item . package ] . version
version = binaries_t_a [ item . package ] . version
pkg_id = ( item . package , version , item . architecture )
pkg_id = ( item . package , version , item . architecture )
undo [ ' binaries ' ] [ ( item . package , item . architecture ) ] = pkg_id
undo [ ' binaries ' ] [ ( item . package , item . architecture ) ] = pkg_id
affected . update ( inst_tester . reverse_dependencies_of ( pkg_id ) )
affected _pos . update ( inst_tester . reverse_dependencies_of ( pkg_id ) )
del binaries_t_a [ item . package ]
del binaries_t_a [ item . package ]
inst_tester . remove_testing_binary ( pkg_id )
inst_tester . remove_testing_binary ( pkg_id )
@ -2037,8 +2038,8 @@ class Britney(object):
equivalent_replacement = key in eqv_set
equivalent_replacement = key in eqv_set
# obviously, added/modified packages are affected
# obviously, added/modified packages are affected
if not equivalent_replacement and updated_pkg_id not in affected :
if not equivalent_replacement :
affected . add ( updated_pkg_id )
affected _pos . add ( updated_pkg_id )
# if the binary already exists in testing, it is currently
# if the binary already exists in testing, it is currently
# built by another source package. we therefore remove the
# built by another source package. we therefore remove the
# version built by the other source package, after marking
# version built by the other source package, after marking
@ -2051,8 +2052,8 @@ class Britney(object):
undo [ ' binaries ' ] [ key ] = old_pkg_id
undo [ ' binaries ' ] [ key ] = old_pkg_id
if not equivalent_replacement :
if not equivalent_replacement :
# all the reverse conflicts
# all the reverse conflicts
affected . update ( inst_tester . reverse_dependencies_of ( old_pkg_id ) )
affected _pos . update ( inst_tester . reverse_dependencies_of ( old_pkg_id ) )
affected . update ( inst_tester . negative_dependencies_of ( old_pkg_id ) )
affected _remain . update ( inst_tester . negative_dependencies_of ( old_pkg_id ) )
inst_tester . remove_testing_binary ( old_pkg_id )
inst_tester . remove_testing_binary ( old_pkg_id )
elif hint_undo :
elif hint_undo :
# the binary isn't in testing, but it may have been at
# the binary isn't in testing, but it may have been at
@ -2068,7 +2069,7 @@ class Britney(object):
for ( tundo , tpkg ) in hint_undo :
for ( tundo , tpkg ) in hint_undo :
if key in tundo [ ' binaries ' ] :
if key in tundo [ ' binaries ' ] :
tpkg_id = tundo [ ' binaries ' ] [ key ]
tpkg_id = tundo [ ' binaries ' ] [ key ]
affected . update ( inst_tester . reverse_dependencies_of ( tpkg_id ) )
affected _pos . update ( inst_tester . reverse_dependencies_of ( tpkg_id ) )
# add/update the binary package from the source suite
# add/update the binary package from the source suite
new_pkg_data = packages_s [ parch ] [ 0 ] [ binary ]
new_pkg_data = packages_s [ parch ] [ 0 ] [ binary ]
@ -2085,17 +2086,18 @@ class Britney(object):
provides_t_a [ j ] . add ( ( binary , prov_version ) )
provides_t_a [ j ] . add ( ( binary , prov_version ) )
if not equivalent_replacement :
if not equivalent_replacement :
# all the reverse dependencies are affected by the change
# all the reverse dependencies are affected by the change
affected . add ( updated_pkg_id )
affected _pos . add ( updated_pkg_id )
affected . update ( inst_tester . negative_dependencies_of ( updated_pkg_id ) )
affected _remain . update ( inst_tester . negative_dependencies_of ( updated_pkg_id ) )
# add/update the source package
# add/update the source package
if item . architecture == ' source ' :
if item . architecture == ' source ' :
sources [ ' testing ' ] [ item . package ] = sources [ item . suite ] [ item . package ]
sources [ ' testing ' ] [ item . package ] = sources [ item . suite ] [ item . package ]
# Also include the transitive rdeps of the packages found so far
# Also include the transitive rdeps of the packages found so far
compute_reverse_tree ( inst_tester , affected )
compute_reverse_tree ( inst_tester , affected_pos )
compute_reverse_tree ( inst_tester , affected_remain )
# return the package name, the suite, the list of affected packages and the undo dictionary
# return the package name, the suite, the list of affected packages and the undo dictionary
return ( affected , undo )
return ( affected _pos, affected_remain , undo )
def try_migration ( self , actions , nuninst_now , lundo = None , automatic_revert = True ) :
def try_migration ( self , actions , nuninst_now , lundo = None , automatic_revert = True ) :
is_accepted = True
is_accepted = True
@ -2111,7 +2113,7 @@ class Britney(object):
if len ( actions ) == 1 :
if len ( actions ) == 1 :
item = actions [ 0 ]
item = actions [ 0 ]
# apply the changes
# apply the changes
affected , undo = self . doop_source ( item , hint_undo = lundo )
affected _pos, affected_remain , undo = self . doop_source ( item , hint_undo = lundo )
undo_list = [ ( undo , item ) ]
undo_list = [ ( undo , item ) ]
if item . architecture == ' source ' :
if item . architecture == ' source ' :
affected_architectures = set ( self . options . architectures )
affected_architectures = set ( self . options . architectures )
@ -2120,7 +2122,8 @@ class Britney(object):
else :
else :
undo_list = [ ]
undo_list = [ ]
removals = set ( )
removals = set ( )
affected = set ( )
affected_pos = set ( )
affected_remain = set ( )
for item in actions :
for item in actions :
_ , rms , _ = self . _compute_groups ( item . package , item . suite ,
_ , rms , _ = self . _compute_groups ( item . package , item . suite ,
item . architecture ,
item . architecture ,
@ -2133,12 +2136,23 @@ class Britney(object):
affected_architectures = set ( self . options . architectures )
affected_architectures = set ( self . options . architectures )
for item in actions :
for item in actions :
item_affected , undo = self . doop_source ( item ,
item_affected _pos, item_affected_remain , undo = self . doop_source ( item ,
hint_undo = lundo ,
hint_undo = lundo ,
removals = removals )
removals = removals )
affected . update ( item_affected )
affected_pos . update ( item_affected_pos )
affected_remain . update ( item_affected_remain )
undo_list . append ( ( undo , item ) )
undo_list . append ( ( undo , item ) )
# Optimise the test if we may revert directly.
# - The automatic-revert is needed since some callers (notably via hints) may
# accept the outcome of this migration and expect nuninst to be updated.
# (e.g. "force-hint" or "hint")
if automatic_revert :
affected_remain - = affected_pos
else :
affected_remain | = affected_pos
affected_pos = set ( )
# Copy nuninst_comp - we have to deep clone affected
# Copy nuninst_comp - we have to deep clone affected
# architectures.
# architectures.
@ -2152,7 +2166,8 @@ class Britney(object):
for arch in affected_architectures :
for arch in affected_architectures :
check_archall = arch in nobreakall_arches
check_archall = arch in nobreakall_arches
check_installability ( self . _inst_tester , packages_t , arch , affected , check_archall , nuninst_after )
check_installability ( self . _inst_tester , packages_t , arch , affected_pos , affected_remain ,
check_archall , nuninst_after )
# if the uninstallability counter is worse than before, break the loop
# if the uninstallability counter is worse than before, break the loop
if automatic_revert and len ( nuninst_after [ arch ] ) > len ( nuninst_now [ arch ] ) :
if automatic_revert and len ( nuninst_after [ arch ] ) > len ( nuninst_now [ arch ] ) :