Commit 5c36cd38 authored by Jason R. Coombs's avatar Jason R. Coombs

Extract method for testing marker evaluation

parent 19fd04ba
...@@ -804,17 +804,10 @@ class WorkingSet(object): ...@@ -804,17 +804,10 @@ class WorkingSet(object):
if req in processed: if req in processed:
# Ignore cyclic or redundant dependencies # Ignore cyclic or redundant dependencies
continue continue
# If the req has a marker, evaluate it -- skipping the req if
# it evaluates to False. if not self._markers_pass(req, extra_req_mapping):
if req.marker:
result = []
if req in extra_req_mapping:
for extra in extra_req_mapping[req] or ['']:
result.append(req.marker.evaluate({'extra': extra}))
else:
result.append(req.marker.evaluate())
if not any(result):
continue continue
dist = best.get(req.key) dist = best.get(req.key)
if dist is None: if dist is None:
# Find the best distribution and add it to the map # Find the best distribution and add it to the map
...@@ -854,6 +847,26 @@ class WorkingSet(object): ...@@ -854,6 +847,26 @@ class WorkingSet(object):
# return list of distros to activate # return list of distros to activate
return to_activate return to_activate
@staticmethod
def _markers_pass(req, extra_req_mapping):
"""
Return False if the req has a marker and fails
evaluation. Otherwise, return True.
extra_req_mapping is a map of requirements to
extras.
"""
if not req.marker:
return True
result = []
if req in extra_req_mapping:
for extra in extra_req_mapping[req] or ['']:
result.append(req.marker.evaluate({'extra': extra}))
else:
result.append(req.marker.evaluate())
return any(result)
def find_plugins(self, plugin_env, full_env=None, installer=None, def find_plugins(self, plugin_env, full_env=None, installer=None,
fallback=True): fallback=True):
"""Find all activatable distributions in `plugin_env` """Find all activatable distributions in `plugin_env`
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment