{
    "Selected_candidate": {
        "pr_number": 3295,
        "pr_title": "implemented --last-failed-no-failures",
        "pr_body": "Fixes #3139",
        "issue_id": 3139,
        "issue_title": "pytest cache is empty inspite of that \"--lf\" option execute all the cases",
        "issue_body": "Use Case: \r\n1. I have a huge Web automation suite(and yes with flaky test cases).70k test case execution per week.\r\n2. There are some random failures and I want to rerun them and Voila we have a wonderful feature of --lf\r\n3. Now My all test case got passed in third rerun but note I have 4th rerun also with --lf option.\r\n4. 4th Rerun picks all the test case back again. Driving me crazy.\r\n",
        "issue_closed_at": "2018-03-20T22:17:32Z",
        "base_commit": "d6ddeb395bbf788a708c90f6e3003fb57cdc3b7e",
        "changes": [
            {
                "file": "_pytest/cacheprovider.py",
                "type": "function",
                "name": "__init__",
                "class_name": "NFPlugin",
                "code": "def __init__(self, config):\n        self.config = config\n        self.active = config.option.newfirst\n        self.cached_nodeids = config.cache.get(\"cache/nodeids\", [])"
            },
            {
                "file": "_pytest/cacheprovider.py",
                "type": "function",
                "name": "pytest_collectreport",
                "class_name": "LFPlugin",
                "code": "def pytest_collectreport(self, report):\n        passed = report.outcome in ('passed', 'skipped')\n        if passed:\n            if report.nodeid in self.lastfailed:\n                self.lastfailed.pop(report.nodeid)\n                self.lastfailed.update(\n                    (item.nodeid, True)\n                    for item in report.result)\n        else:\n            self.lastfailed[report.nodeid] = True"
            },
            {
                "file": "_pytest/cacheprovider.py",
                "type": "function",
                "name": "pytest_addoption",
                "class_name": null,
                "code": "def pytest_addoption(parser):\n    group = parser.getgroup(\"general\")\n    group.addoption(\n        '--lf', '--last-failed', action='store_true', dest=\"lf\",\n        help=\"rerun only the tests that failed \"\n             \"at the last run (or all if none failed)\")\n    group.addoption(\n        '--ff', '--failed-first', action='store_true', dest=\"failedfirst\",\n        help=\"run all tests but run the last failures first.  \"\n             \"This may re-order tests and thus lead to \"\n             \"repeated fixture setup/teardown\")\n    group.addoption(\n        '--nf', '--new-first', action='store_true', dest=\"newfirst\",\n        help=\"run tests from new files first, then the rest of the tests \"\n             \"sorted by file mtime\")\n    group.addoption(\n        '--cache-show', action='store_true', dest=\"cacheshow\",\n        help=\"show cache contents, don't perform collection or tests\")\n    group.addoption(\n        '--cache-clear', action='store_true', dest=\"cacheclear\",\n        help=\"remove all cache contents at start of test run.\")\n    parser.addini(\n        \"cache_dir\", default='.pytest_cache',\n        help=\"cache directory path.\")"
            }
        ]
    },
    "Justification": "Candidate D's bug report addresses caching behavior in pytest, which is directly relevant to the CURRENT bug concerning incorrect caching of the skipif/xfail evaluation. Both bugs involve how pytest processes caching and condition evaluation during test execution, and the suggested fix for Candidate D modifying how last-failed tests are handled could provide valuable insights into fixing the CURRENT bug. The shared focus on pytest's execution model makes D the most useful report to consult for debugging the CURRENT issue."
}