Skip to content

Commit 8ae1bd6

Browse files
authored
Merge pull request #9065 from pradyunsg/add-debugging-reporter
Add a debugging reporter for pip's resolver
2 parents 8daece5 + 9f318de commit 8ae1bd6

File tree

2 files changed

+43
-4
lines changed

2 files changed

+43
-4
lines changed

src/pip/_internal/resolution/resolvelib/reporter.py

+34-2
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,9 @@
66
from pip._internal.utils.typing import MYPY_CHECK_RUNNING
77

88
if MYPY_CHECK_RUNNING:
9-
from typing import DefaultDict
9+
from typing import Any, DefaultDict
1010

11-
from .base import Candidate
11+
from .base import Candidate, Requirement
1212

1313

1414
logger = getLogger(__name__)
@@ -50,3 +50,35 @@ def backtracking(self, candidate):
5050

5151
message = self._messages_at_backtrack[count]
5252
logger.info("INFO: %s", message)
53+
54+
55+
class PipDebuggingReporter(BaseReporter):
56+
"""A reporter that does an info log for every event it sees."""
57+
58+
def starting(self):
59+
# type: () -> None
60+
logger.info("Reporter.starting()")
61+
62+
def starting_round(self, index):
63+
# type: (int) -> None
64+
logger.info("Reporter.starting_round(%r)", index)
65+
66+
def ending_round(self, index, state):
67+
# type: (int, Any) -> None
68+
logger.info("Reporter.ending_round(%r, state)", index)
69+
70+
def ending(self, state):
71+
# type: (Any) -> None
72+
logger.info("Reporter.ending(%r)", state)
73+
74+
def adding_requirement(self, requirement, parent):
75+
# type: (Requirement, Candidate) -> None
76+
logger.info("Reporter.adding_requirement(%r, %r)", requirement, parent)
77+
78+
def backtracking(self, candidate):
79+
# type: (Candidate) -> None
80+
logger.info("Reporter.backtracking(%r)", candidate)
81+
82+
def pinning(self, candidate):
83+
# type: (Candidate) -> None
84+
logger.info("Reporter.pinning(%r)", candidate)

src/pip/_internal/resolution/resolvelib/resolver.py

+9-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
import functools
22
import logging
3+
import os
34

45
from pip._vendor import six
56
from pip._vendor.packaging.utils import canonicalize_name
@@ -11,7 +12,10 @@
1112
from pip._internal.req.req_set import RequirementSet
1213
from pip._internal.resolution.base import BaseResolver
1314
from pip._internal.resolution.resolvelib.provider import PipProvider
14-
from pip._internal.resolution.resolvelib.reporter import PipReporter
15+
from pip._internal.resolution.resolvelib.reporter import (
16+
PipDebuggingReporter,
17+
PipReporter,
18+
)
1519
from pip._internal.utils.misc import dist_is_editable
1620
from pip._internal.utils.typing import MYPY_CHECK_RUNNING
1721

@@ -104,7 +108,10 @@ def resolve(self, root_reqs, check_supported_wheels):
104108
upgrade_strategy=self.upgrade_strategy,
105109
user_requested=user_requested,
106110
)
107-
reporter = PipReporter()
111+
if "PIP_RESOLVER_DEBUG" in os.environ:
112+
reporter = PipDebuggingReporter()
113+
else:
114+
reporter = PipReporter()
108115
resolver = RLResolver(provider, reporter)
109116

110117
try:

0 commit comments

Comments
 (0)