{
  "RepoName": "https://github.com/datadriventests/ddt.git",
  "CommitSHA": "5b4fec6152fd6be880c42f01213685a1a835720a",
  "Type": "logic error",
  "ErrorMessage": "======================================================================\nFAIL: test_file_data_json_dict_dict_1_positive_integer_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_1_positive_integer_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: 0 not greater than 1\n\n======================================================================\nFAIL: test_file_data_json_dict_dict_2_negative_integer_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_2_negative_integer_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: -2 not greater than -1\n\n======================================================================\nFAIL: test_file_data_json_dict_dict_3_positive_real_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_3_positive_real_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: 0.0 not greater than 0.5\n\n======================================================================\nFAIL: test_file_data_json_dict_dict_4_negative_real_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_4_negative_real_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: -1.0 not greater than -0.5\n\n======================================================================\nFAIL: test_greater_with_name_docstring_1_Test_case_1 (test_example.FooTestCase)\nTest docstring 1\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 79, in test_greater_with_name_docstring\n    self.assertIsNone(getattr(value, \"__name__\"))  \nAssertionError: \"Test_case_1\" is not None\n\n======================================================================\nFAIL: test_greater_with_name_docstring_2_Test_case_2 (test_example.FooTestCase)\nTest docstring 2\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 79, in test_greater_with_name_docstring\n    self.assertIsNone(getattr(value, \"__name__\"))  \nAssertionError: \"Test_case_2\" is not None\n\n======================================================================\nFAIL: test_iterable_argument_1__0__3_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 0 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_2__0__4_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 0 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_3__0__5_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 0 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_4__1__3_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 1 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_5__1__4_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 1 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_6__1__5_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 1 not greater than or equal to 2\n\n======================================================================\nFAIL: test_not_larger_than_two_1_1 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_not_larger_than_two_2__3 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_not_larger_than_two_3_2 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_not_larger_than_two_4_0 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_undecorated (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 53, in test_undecorated\n    self.assertFalse(larger_than_two(24))  \nAssertionError: True is not false\n\n======================================================================\nFAIL: test_dict_with_nontrivial_type_2_Fails (test_named_data.TestNamedData)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_named_data.py\", line 55, in test_dict_with_nontrivial_type\n    self.assertIsInstance(value, self.NonTrivialClass)\nAssertionError: 1 is not an instance of <class \"test_named_data.TestNamedData.NonTrivialClass\">\n\n======================================================================\nFAIL: test_seq_with_nontrivial_type_2_Fails (test_named_data.TestNamedData)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_named_data.py\", line 45, in test_seq_with_nontrivial_type\n    self.assertIsInstance(value, self.NonTrivialClass)\nAssertionError: 1 is not an instance of <class \"test_named_data.TestNamedData.NonTrivialClass\">\n\n======================================================================\nFAIL: test_single_named_value_1_Single (test_named_data.TestNamedData)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_named_data.py\", line 14, in test_single_named_value\n    self.assertGreater(value1, value2)\nAssertionError: 0 not greater than 1\n\n----------------------------------------------------------------------",
  "Issue": {
    "title": "Incorrect Assertions in Unit Tests for Functions",
    "description": "It has come to our attention that certain unit tests within the FooTestCase class are using incorrect assertions, which can lead to inaccurate test results and potentially false negatives. Specifically, there are tests where 'assertFalse' is used when 'assertTrue' should be used and vice versa. Additionally, there are cases where 'assertGreaterEqual' and 'assertGreater' are used incorrectly.\n\nIssues Identified:\n1. The test 'test_undecorated' incorrectly uses 'assertFalse' to check 'larger_than_two(24)' instead of 'assertTrue'.\n2. The test 'test_not_larger_than_two' incorrectly uses 'assertTrue' to check values not larger than two instead of 'assertFalse'.\n3. The test 'test_iterable_argument' incorrectly uses 'assertGreaterEqual' instead of 'assertLessEqual' for the 'first_value'.\n4. The test 'test_greater_with_name_docstring' incorrectly uses 'assertIsNone' for checking '__name__' attribute instead of 'assertIsNotNone'.\n5. The test 'test_file_data_json_dict_dict' incorrectly uses 'assertGreater' to compare 'start' and 'value' instead of comparing 'value' and 'start'.\n\nImpact:\nThese incorrect assertions can cause confusion and mislead developers when interpreting test results. Ensuring that unit tests are accurate is crucial for maintaining code integrity and reliability.\n\nPotential Solution:\nReview the mentioned test cases and correct the assertions to reflect the expected behavior accurately. Performing these corrections will improve the reliability of the test results and help maintain the overall quality of the codebase.",
    "explanation": "### Summary of the Issue\n\nThe issue revolves around incorrect assertions in unit tests within the `FooTestCase` class. These incorrect assertions can lead to inaccurate test results and potentially misleading developers with false negatives or positives. The specific problems identified are:\n\n1. Using `assertFalse` instead of `assertTrue` and vice versa.\n2. Misusing `assertGreaterEqual` and `assertGreater`.\n3. Incorrectly checking for `None` with `assertIsNone` instead of `assertIsNotNone`.\n\nThese issues need to be corrected to ensure that the unit tests accurately reflect the expected behavior of the functions they are testing.\n\n### Content of the Commit\n\nThe commit shows changes to the file `datadriventests_ddt/test/test_example.py`, and it addresses the misused assertions by making the following corrections:\n\n1. **`test_undecorated`**: Changes `assertFalse(larger_than_two(24))` to `assertTrue(larger_than_two(24))`.\n2. **`test_not_larger_than_two`**: Changes `assertTrue(larger_than_two(value))` to `assertFalse(larger_than_two(value))`.\n3. **`test_iterable_argument`**: Changes `assertGreaterEqual(first_value, 2)` to `assertLessEqual(first_value, 2)`.\n4. **`test_greater_with_name_docstring`**: Changes `assertIsNone(getattr(value, \"__name__\"))` to `assertIsNotNone(getattr(value, \"__name__\"))`.\n5. **`test_file_data_json_dict_dict`**: Changes `assertGreater(start, value)` to `assertGreater(value, start)`.\n\n### Explanation of the Issue\n\nThe root cause of the issue is the misuse of assertion methods which results in tests that do not accurately verify the behavior of the functions they are meant to test. Specifically:\n\n1. **Assertion Method Mismatch**: Using `assertFalse` when the condition should be `True` and using `assertTrue` when the condition should be `False`. This incorrect usage can cause a test to pass or fail incorrectly, leading to inaccurate results.\n2. **Comparison Method Misuse**: Using `assertGreaterEqual` when `assertLessEqual` is appropriate and vice versa. This can lead to logical errors in the tests, where the conditions being tested for are not accurately represented.\n3. **Mischecking for Attributes**: Using `assertIsNone` to check for the existence of an attribute where `assertIsNotNone` is appropriate. This can cause misunderstanding about the presence or absence of attributes in objects being tested.\n\n### Explanation of the Solution\n\nThe commit resolves the above issues by correcting the misuse of assertions and ensuring that the tests accurately reflect the expected conditions. Here’s how the commit addresses each issue:\n\n1. **Correction of `test_undecorated`**: The test was incorrectly checking that `larger_than_two(24)` is `False`. By changing it to `assertTrue(larger_than_two(24))`, the test now correctly checks that 24 is indeed greater than two.\n2. **Correction of `test_not_larger_than_two`**: The test was incorrectly using `assertTrue` to check values not larger than two. By changing it to `assertFalse`, it accurately asserts that the values are not greater than two.\n3. **Correction of `test_iterable_argument`**: The test was incorrectly using `assertGreaterEqual` for `first_value` which should have been `assertLessEqual`. This now correctly asserts that the first value is less than or equal to two.\n4. **Correction of `test_greater_with_name_docstring`**: The test was incorrectly checking that the `__name__` attribute is `None` with `assertIsNone`. By changing it to `assertIsNotNone`, it accurately checks that the attribute exists.\n5. **Correction of `test_file_data_json_dict_dict`**: The test incorrectly used `assertGreater` with `start` and `value` in the wrong order. By reversing the order, it now correctly asserts that `value` is greater than `start`.\n\n### Conclusion\n\nThe corrections made in the commit ensure that the unit tests now accurately test the conditions they are supposed to check. By addressing the incorrect assertions and aligning them with the expected behavior, the tests will provide reliable results, thereby maintaining the integrity and reliability of the codebase. This reduces the risk of false negatives or positives and helps developers confidently interpret test outcomes."
  },
  "Explain": "### Summary of the Issue\n\nThe issue revolves around incorrect assertions in unit tests within the `FooTestCase` class. These incorrect assertions can lead to inaccurate test results and potentially misleading developers with false negatives or positives. The specific problems identified are:\n\n1. Using `assertFalse` instead of `assertTrue` and vice versa.\n2. Misusing `assertGreaterEqual` and `assertGreater`.\n3. Incorrectly checking for `None` with `assertIsNone` instead of `assertIsNotNone`.\n\nThese issues need to be corrected to ensure that the unit tests accurately reflect the expected behavior of the functions they are testing.\n\n### Content of the Commit\n\nThe commit shows changes to the file `datadriventests_ddt/test/test_example.py`, and it addresses the misused assertions by making the following corrections:\n\n1. **`test_undecorated`**: Changes `assertFalse(larger_than_two(24))` to `assertTrue(larger_than_two(24))`.\n2. **`test_not_larger_than_two`**: Changes `assertTrue(larger_than_two(value))` to `assertFalse(larger_than_two(value))`.\n3. **`test_iterable_argument`**: Changes `assertGreaterEqual(first_value, 2)` to `assertLessEqual(first_value, 2)`.\n4. **`test_greater_with_name_docstring`**: Changes `assertIsNone(getattr(value, \"__name__\"))` to `assertIsNotNone(getattr(value, \"__name__\"))`.\n5. **`test_file_data_json_dict_dict`**: Changes `assertGreater(start, value)` to `assertGreater(value, start)`.\n\n### Explanation of the Issue\n\nThe root cause of the issue is the misuse of assertion methods which results in tests that do not accurately verify the behavior of the functions they are meant to test. Specifically:\n\n1. **Assertion Method Mismatch**: Using `assertFalse` when the condition should be `True` and using `assertTrue` when the condition should be `False`. This incorrect usage can cause a test to pass or fail incorrectly, leading to inaccurate results.\n2. **Comparison Method Misuse**: Using `assertGreaterEqual` when `assertLessEqual` is appropriate and vice versa. This can lead to logical errors in the tests, where the conditions being tested for are not accurately represented.\n3. **Mischecking for Attributes**: Using `assertIsNone` to check for the existence of an attribute where `assertIsNotNone` is appropriate. This can cause misunderstanding about the presence or absence of attributes in objects being tested.\n\n### Explanation of the Solution\n\nThe commit resolves the above issues by correcting the misuse of assertions and ensuring that the tests accurately reflect the expected conditions. Here’s how the commit addresses each issue:\n\n1. **Correction of `test_undecorated`**: The test was incorrectly checking that `larger_than_two(24)` is `False`. By changing it to `assertTrue(larger_than_two(24))`, the test now correctly checks that 24 is indeed greater than two.\n2. **Correction of `test_not_larger_than_two`**: The test was incorrectly using `assertTrue` to check values not larger than two. By changing it to `assertFalse`, it accurately asserts that the values are not greater than two.\n3. **Correction of `test_iterable_argument`**: The test was incorrectly using `assertGreaterEqual` for `first_value` which should have been `assertLessEqual`. This now correctly asserts that the first value is less than or equal to two.\n4. **Correction of `test_greater_with_name_docstring`**: The test was incorrectly checking that the `__name__` attribute is `None` with `assertIsNone`. By changing it to `assertIsNotNone`, it accurately checks that the attribute exists.\n5. **Correction of `test_file_data_json_dict_dict`**: The test incorrectly used `assertGreater` with `start` and `value` in the wrong order. By reversing the order, it now correctly asserts that `value` is greater than `start`.\n\n### Conclusion\n\nThe corrections made in the commit ensure that the unit tests now accurately test the conditions they are supposed to check. By addressing the incorrect assertions and aligning them with the expected behavior, the tests will provide reliable results, thereby maintaining the integrity and reliability of the codebase. This reduces the risk of false negatives or positives and helps developers confidently interpret test outcomes.",
  "Time": "2024-02-26",
  "Difficulty": "Simple",
  "OriginCode": [
    {
      "path": "datadriventests_ddt/CONTRIBUTING.md",
      "content": "# Contributing to DDT\n\n## Guidelines\n\nWe'll be happy if you want to contribute to the improvement of `ddt`.\n\nCode contributions will take the form of pull requests to\n[the github repo](https://github.com/datadriventests/ddt).\n\nYour PRs are more likely to be merged quickly if:\n\n - They adhere to coding conventions in the repo (PEP8)\n - They include tests\n\n## Building\n\nPRs to `ddt` are always built by Travis-CI on Python 2 and 3.\n\nIf you want to build `ddt` locally, the simplest way is to use `tox`:\n\n```\npip install tox\ntox\n```\n\nThis will run tests on various releases of python (2 and 3, as long as they\nare installed in your computer), run `flake8` and build the Sphinx\ndocumentation.\n\nAlternatively, if you only want to run tests on your active version of python,\nI recommend you make yourself a virtual environment and:\n\n```\npip install -r requirements/build.txt\n./build.sh\n```\n"
    },
    {
      "path": "datadriventests_ddt/LICENSE.md",
      "content": "Copyright © 2015 Carles Barrobés and additional contributors.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of\nthis software and associated documentation files (the “Software”), to deal in\nthe Software without restriction, including without limitation the rights to\nuse, copy, modify, merge, publish, distribute, sublicense, and/or sell copies\nof the Software, and to permit persons to whom the Software is furnished to do\nso, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n([MIT License](http://mit-license.org/))\n"
    },
    {
      "path": "datadriventests_ddt/MANIFEST.in",
      "content": "include *.md\nrecursive-include test *.py *.json *.yaml\ninclude MANIFEST.in\ninclude LICENSE.md\ninclude tox.ini\nglobal-exclude *.py[cod] __pycache__\n"
    },
    {
      "path": "datadriventests_ddt/README.md",
      "content": "![Run Tests](https://github.com/datadriventests/ddt/workflows/Run%20Tests/badge.svg?branch=master)\n[![codecov.io](https://codecov.io/github/datadriventests/ddt/coverage.svg?branch=master)](https://codecov.io/github/datadriventests/ddt)\n<br />\n[![Version](https://img.shields.io/pypi/v/ddt.svg)](https://pypi.python.org/pypi/ddt)\n[![Downloads](https://img.shields.io/pypi/dm/ddt.svg)](https://pypi.python.org/pypi/ddt)\n\nDDT (Data-Driven Tests) allows you to multiply one test case\nby running it with different test data, and make it appear as\nmultiple test cases.\n\n# Installation\n\n\n```pip install ddt```\n\nCheck out [the documentation](http://ddt.readthedocs.org/) for more details.\n\nSee [Contributing](CONTRIBUTING.md) if you plan to contribute to `ddt`,\nand [License](LICENSE.md) if you plan to use it.\n"
    },
    {
      "path": "datadriventests_ddt/build.sh",
      "content": "#!/bin/bash\npytest --cov=ddt --cov-report html\nflake8 ddt.py test || echo \"Flake8 errors\"\n(cd docs; make html)\n"
    },
    {
      "path": "datadriventests_ddt/ddt.py",
      "content": "# -*- coding: utf-8 -*-\n# This file is a part of DDT (https://github.com/datadriventests/ddt)\n# Copyright 2012-2015 Carles Barrobés and DDT contributors\n# For the exact contribution history, see the git revision log.\n# DDT is licensed under the MIT License, included in\n# https://github.com/datadriventests/ddt/blob/master/LICENSE.md\n\nimport codecs\nimport inspect\nimport json\nimport os\nimport re\nfrom enum import Enum, unique\nfrom functools import wraps\n\ntry:\n    import yaml\nexcept ImportError:  # pragma: no cover\n    _have_yaml = False\nelse:\n    _have_yaml = True\n\nfrom collections.abc import Sequence\n\n\n__version__ = '1.7.2'\n\n# These attributes will not conflict with any real python attribute\n# They are added to the decorated test method and processed later\n# by the `ddt` class decorator.\n\nDATA_ATTR = '%values'              # store the data the test must run with\nFILE_ATTR = '%file_path'           # store the path to JSON file\nYAML_LOADER_ATTR = '%yaml_loader'  # store custom yaml loader for serialization\nUNPACK_ATTR = '%unpack'            # remember that we have to unpack values\nINDEX_LEN = '%index_len'           # store the index length of the data\n\n\n# These are helper classes for @named_data that allow ddt tests to have meaningful names.\nclass _NamedDataList(list):\n    def __init__(self, name, *args):\n        super(_NamedDataList, self).__init__(args)\n        self.name = name\n\n    def __str__(self):\n        return str(self.name)\n\n\nclass _NamedDataDict(dict):\n    def __init__(self, **kwargs):\n        if \"name\" not in kwargs.keys():\n            raise KeyError(\"@named_data expects a dictionary with a 'name' key.\")\n        self.name = kwargs.pop('name')\n        super(_NamedDataDict, self).__init__(kwargs)\n\n    def __str__(self):\n        return str(self.name)\n\n\ntrivial_types = (type(None), bool, int, float, _NamedDataList, _NamedDataDict)\ntry:\n    trivial_types += (basestring, )\nexcept NameError:\n    trivial_types += (str, )\n\n\n@unique\nclass TestNameFormat(Enum):\n    \"\"\"\n    An enum to configure how ``mk_test_name()`` to compose a test name.  Given\n    the following example:\n\n    .. code-block:: python\n\n        @data(\"a\", \"b\")\n        def testSomething(self, value):\n            ...\n\n    if using just ``@ddt`` or together with ``DEFAULT``:\n\n    * ``testSomething_1_a``\n    * ``testSomething_2_b``\n\n    if using ``INDEX_ONLY``:\n\n    * ``testSomething_1``\n    * ``testSomething_2``\n\n    \"\"\"\n    DEFAULT = 0\n    INDEX_ONLY = 1\n\n\ndef is_trivial(value):\n    if isinstance(value, trivial_types):\n        return True\n    elif isinstance(value, (list, tuple)):\n        return all(map(is_trivial, value))\n    return False\n\n\ndef unpack(func):\n    \"\"\"\n    Method decorator to add unpack feature.\n\n    \"\"\"\n    setattr(func, UNPACK_ATTR, True)\n    return func\n\n\ndef data(*values):\n    \"\"\"\n    Method decorator to add to your test methods.\n\n    Should be added to methods of instances of ``unittest.TestCase``.\n\n    \"\"\"\n    return idata(values)\n\n\ndef idata(iterable, index_len=None):\n    \"\"\"\n    Method decorator to add to your test methods.\n\n    Should be added to methods of instances of ``unittest.TestCase``.\n\n    :param iterable: iterable of the values to provide to the test function.\n    :param index_len: an optional integer specifying the width to zero-pad the\n        test identifier indices to.  If not provided, this will add the fewest\n        zeros necessary to make all identifiers the same length.\n    \"\"\"\n    if index_len is None:\n        # Avoid consuming a one-time-use generator.\n        iterable = tuple(iterable)\n        index_len = len(str(len(iterable)))\n\n    def wrapper(func):\n        setattr(func, DATA_ATTR, iterable)\n        setattr(func, INDEX_LEN, index_len)\n        return func\n\n    return wrapper\n\n\ndef file_data(value, yaml_loader=None):\n    \"\"\"\n    Method decorator to add to your test methods.\n\n    Should be added to methods of instances of ``unittest.TestCase``.\n\n    ``value`` should be a path relative to the directory of the file\n    containing the decorated ``unittest.TestCase``. The file\n    should contain JSON encoded data, that can either be a list or a\n    dict.\n\n    In case of a list, each value in the list will correspond to one\n    test case, and the value will be concatenated to the test method\n    name.\n\n    In case of a dict, keys will be used as suffixes to the name of the\n    test case, and values will be fed as test data.\n\n    ``yaml_loader`` can be used to customize yaml deserialization.\n    The default is ``None``, which results in using the ``yaml.safe_load``\n    method.\n    \"\"\"\n    def wrapper(func):\n        setattr(func, FILE_ATTR, value)\n        if yaml_loader:\n            setattr(func, YAML_LOADER_ATTR, yaml_loader)\n        return func\n    return wrapper\n\n\ndef mk_test_name(name, value, index=0, index_len=5, name_fmt=TestNameFormat.DEFAULT):\n    \"\"\"\n    Generate a new name for a test case.\n\n    It will take the original test name and append an ordinal index and a\n    string representation of the value, and convert the result into a valid\n    python identifier by replacing extraneous characters with ``_``.\n\n    We avoid doing str(value) if dealing with non-trivial values.\n    The problem is possible different names with different runs, e.g.\n    different order of dictionary keys (see PYTHONHASHSEED) or dealing\n    with mock objects.\n    Trivial scalar values are passed as is.\n\n    A \"trivial\" value is a plain scalar, or a tuple or list consisting\n    only of trivial values.\n\n    The test name format is controlled by enum ``TestNameFormat`` as well. See\n    the enum documentation for further details.\n    \"\"\"\n\n    # Add zeros before index to keep order\n    index = \"{0:0{1}}\".format(index + 1, index_len)\n    if name_fmt is TestNameFormat.INDEX_ONLY or not is_trivial(value):\n        return \"{0}_{1}\".format(name, index)\n    try:\n        value = str(value)\n    except UnicodeEncodeError:\n        # fallback for python2\n        value = value.encode('ascii', 'backslashreplace')\n    test_name = \"{0}_{1}_{2}\".format(name, index, value)\n    return re.sub(r'\\W|^(?=\\d)', '_', test_name)\n\n\ndef feed_data(func, new_name, test_data_docstring, *args, **kwargs):\n    \"\"\"\n    This internal method decorator feeds the test data item to the test.\n\n    \"\"\"\n    if inspect.iscoroutinefunction(func):\n        @wraps(func)\n        async def wrapper(self):\n            return await func(self, *args, **kwargs)\n    else:\n        @wraps(func)\n        def wrapper(self):\n            return func(self, *args, **kwargs)\n\n    wrapper.__name__ = new_name\n    wrapper.__wrapped__ = func\n    # set docstring if exists\n    if test_data_docstring is not None:\n        wrapper.__doc__ = test_data_docstring\n    else:\n        # Try to call format on the docstring\n        if func.__doc__:\n            try:\n                wrapper.__doc__ = func.__doc__.format(*args, **kwargs)\n            except (IndexError, KeyError):\n                # Maybe the user has added some of the formating strings\n                # unintentionally in the docstring. Do not raise an exception\n                # as it could be that user is not aware of the\n                # formating feature.\n                pass\n    return wrapper\n\n\ndef add_test(cls, test_name, test_docstring, func, *args, **kwargs):\n    \"\"\"\n    Add a test case to this class.\n\n    The test will be based on an existing function but will give it a new\n    name.\n\n    \"\"\"\n    setattr(cls, test_name, feed_data(func, test_name, test_docstring,\n            *args, **kwargs))\n\n\ndef process_file_data(cls, name, func, file_attr):\n    \"\"\"\n    Process the parameter in the `file_data` decorator.\n    \"\"\"\n    cls_path = os.path.abspath(inspect.getsourcefile(cls))\n    data_file_path = os.path.join(os.path.dirname(cls_path), file_attr)\n\n    def create_error_func(message):  # pylint: disable-msg=W0613\n        def func(*args):\n            raise ValueError(message % file_attr)\n        return func\n\n    # If file does not exist, provide an error function instead\n    if not os.path.exists(data_file_path):\n        test_name = mk_test_name(name, \"error\")\n        test_docstring = \"\"\"Error!\"\"\"\n        add_test(cls, test_name, test_docstring,\n                 create_error_func(\"%s does not exist\"), None)\n        return\n\n    _is_yaml_file = data_file_path.endswith((\".yml\", \".yaml\"))\n\n    # Don't have YAML but want to use YAML file.\n    if _is_yaml_file and not _have_yaml:\n        test_name = mk_test_name(name, \"error\")\n        test_docstring = \"\"\"Error!\"\"\"\n        add_test(\n            cls,\n            test_name,\n            test_docstring,\n            create_error_func(\"%s is a YAML file, please install PyYAML\"),\n            None\n        )\n        return\n\n    with codecs.open(data_file_path, 'r', 'utf-8') as f:\n        # Load the data from YAML or JSON\n        if _is_yaml_file:\n            if hasattr(func, YAML_LOADER_ATTR):\n                yaml_loader = getattr(func, YAML_LOADER_ATTR)\n                data = yaml.load(f, Loader=yaml_loader)\n            else:\n                data = yaml.safe_load(f)\n        else:\n            data = json.load(f)\n\n    _add_tests_from_data(cls, name, func, data)\n\n\ndef _add_tests_from_data(cls, name, func, data):\n    \"\"\"\n    Add tests from data loaded from the data file into the class\n    \"\"\"\n    index_len = len(str(len(data)))\n    for i, elem in enumerate(data):\n        if isinstance(data, dict):\n            key, value = elem, data[elem]\n            test_name = mk_test_name(name, key, i, index_len)\n        elif isinstance(data, list):\n            value = elem\n            test_name = mk_test_name(name, value, i, index_len)\n        if isinstance(value, dict):\n            add_test(cls, test_name, test_name, func, **value)\n        else:\n            add_test(cls, test_name, test_name, func, value)\n\n\ndef _is_primitive(obj):\n    \"\"\"Finds out if the obj is a \"primitive\". It is somewhat hacky but it works.\n    \"\"\"\n    return not hasattr(obj, '__dict__')\n\n\ndef _get_test_data_docstring(func, value):\n    \"\"\"Returns a docstring based on the following resolution strategy:\n    1. Passed value is not a \"primitive\" and has a docstring, then use it.\n    2. In all other cases return None, i.e the test name is used.\n    \"\"\"\n    if not _is_primitive(value) and value.__doc__:\n        return value.__doc__\n    else:\n        return None\n\n\ndef ddt(arg=None, **kwargs):\n    \"\"\"\n    Class decorator for subclasses of ``unittest.TestCase``.\n\n    Apply this decorator to the test case class, and then\n    decorate test methods with ``@data``.\n\n    For each method decorated with ``@data``, this will effectively create as\n    many methods as data items are passed as parameters to ``@data``.\n\n    The names of the test methods follow the pattern\n    ``original_test_name_{ordinal}_{data}``. ``ordinal`` is the position of the\n    data argument, starting with 1.\n\n    For data we use a string representation of the data value converted into a\n    valid python identifier.  If ``data.__name__`` exists, we use that instead.\n\n    For each method decorated with ``@file_data('test_data.json')``, the\n    decorator will try to load the test_data.json file located relative\n    to the python file containing the method that is decorated. It will,\n    for each ``test_name`` key create as many methods in the list of values\n    from the ``data`` key.\n\n    Decorating with the keyword argument ``testNameFormat`` can control the\n    format of the generated test names.  For example:\n\n    - ``@ddt(testNameFormat=TestNameFormat.DEFAULT)`` will be index and values.\n\n    - ``@ddt(testNameFormat=TestNameFormat.INDEX_ONLY)`` will be index only.\n\n    - ``@ddt`` is the same as DEFAULT.\n\n    \"\"\"\n    fmt_test_name = kwargs.get(\"testNameFormat\", TestNameFormat.DEFAULT)\n\n    def wrapper(cls):\n        for name, func in list(cls.__dict__.items()):\n            if hasattr(func, DATA_ATTR):\n                index_len = getattr(func, INDEX_LEN)\n                for i, v in enumerate(getattr(func, DATA_ATTR)):\n                    test_name = mk_test_name(\n                        name,\n                        getattr(v, \"__name__\", v),\n                        i,\n                        index_len,\n                        fmt_test_name\n                    )\n                    test_data_docstring = _get_test_data_docstring(func, v)\n                    if hasattr(func, UNPACK_ATTR):\n                        if isinstance(v, tuple) or isinstance(v, list):\n                            add_test(\n                                cls,\n                                test_name,\n                                test_data_docstring,\n                                func,\n                                *v\n                            )\n                        else:\n                            # unpack dictionary\n                            add_test(\n                                cls,\n                                test_name,\n                                test_data_docstring,\n                                func,\n                                **v\n                            )\n                    else:\n                        add_test(cls, test_name, test_data_docstring, func, v)\n                delattr(cls, name)\n            elif hasattr(func, FILE_ATTR):\n                file_attr = getattr(func, FILE_ATTR)\n                process_file_data(cls, name, func, file_attr)\n                delattr(cls, name)\n        return cls\n\n    # ``arg`` is the unittest's test class when decorating with ``@ddt`` while\n    # it is ``None`` when decorating a test class with ``@ddt(k=v)``.\n    return wrapper(arg) if inspect.isclass(arg) else wrapper\n\n\ndef named_data(*named_values):\n    \"\"\"\n    This decorator is to allow for meaningful names to be given to tests that would otherwise use @ddt.data and\n    @ddt.unpack.\n\n    Example of original ddt usage:\n        @ddt.ddt\n        class TestExample(TemplateTest):\n            @ddt.data(\n                [0, 1],\n                [10, 11]\n            )\n            @ddt.unpack\n            def test_values(self, value1, value2):\n                ...\n\n    Example of new usage:\n        @ddt.ddt\n        class TestExample(TemplateTest):\n            @named_data(\n                ['LabelA', 0, 1],\n                ['LabelB', 10, 11],\n            )\n            def test_values(self, value1, value2):\n                ...\n\n    Note that @unpack is not used.\n\n    :param Sequence[Any] | dict[Any,Any] named_values: Each named_value should be a Sequence (e.g. list or tuple) with\n        the name as the first element, or a dictionary with 'name' as one of the keys. The name will be coerced to a\n        string and all other values will be passed unchanged to the test.\n    \"\"\"\n    values = []\n    for named_value in named_values:\n        if not isinstance(named_value, (Sequence, dict)):\n            raise TypeError(\n                \"@named_data expects a Sequence (list, tuple) or dictionary, and not '{}'.\".format(type(named_value))\n            )\n\n        value = _NamedDataDict(**named_value) if isinstance(named_value, dict) \\\n            else _NamedDataList(named_value[0], *named_value[1:])\n\n        # Remove the __doc__ attribute so @ddt.data doesn't add the NamedData class docstrings to the test name.\n        value.__doc__ = None\n\n        values.append(value)\n\n    def wrapper(func):\n        data(*values)(unpack(func))\n        return func\n\n    return wrapper\n"
    },
    {
      "path": "datadriventests_ddt/release.sh",
      "content": "#!/bin/bash\npython setup.py sdist bdist_wheel upload\n"
    },
    {
      "path": "datadriventests_ddt/rtdocs.sh",
      "content": "curl --data '' http://readthedocs.org/build/ddt\n"
    },
    {
      "path": "datadriventests_ddt/setup.cfg",
      "content": "[bdist_wheel]\nuniversal = 1\n"
    },
    {
      "path": "datadriventests_ddt/setup.py",
      "content": "#!/usr/bin/env python\n# # coding: utf-8\n\nfrom setuptools import setup\nfrom ddt import __version__\n\nsetup(\n    name='ddt',\n    description='Data-Driven/Decorated Tests',\n    long_description='A library to multiply test cases',\n    version=__version__,\n    author='Carles Barrobés',\n    author_email='carles@barrobes.com',\n    url='https://github.com/datadriventests/ddt',\n    py_modules=['ddt'],\n    classifiers=[\n        'Development Status :: 4 - Beta',\n        'Intended Audience :: Developers',\n        'License :: OSI Approved :: MIT License',\n        'Operating System :: OS Independent',\n        'Programming Language :: Python',\n        'Programming Language :: Python :: 3',\n        'Programming Language :: Python :: 3.6',\n        'Programming Language :: Python :: 3.7',\n        'Programming Language :: Python :: 3.8',\n        'Programming Language :: Python :: 3.9',\n        'Programming Language :: Python :: 3.10',\n        'Topic :: Software Development :: Testing',\n    ],\n)\n"
    },
    {
      "path": "datadriventests_ddt/tox.ini",
      "content": "[tox]\nenvlist = py36,py37,py38,py39,py310\n\n[testenv]\ndeps = \n    pytest\n    pytest-cov\n    coverage\n    aiounittest\n    flake8\n    six>=1.4.0\n    PyYAML\ncommands = \n    pytest --cov=ddt --cov-report html\n    flake8 ddt.py test\n\n[flake8]\nmax-line-length = 127\nexclude = .git,__pycache__,docs/source/conf.py,old,build,dist,.tox,.venv\nmax-complexity = 10\n\n[gh-actions]\npython = \n  3.8: py38\n  3.6: py36\n  3.7: py37\n  3.8: py38\n  3.9: py39\n  3.10: py310\n"
    },
    {
      "path": "datadriventests_ddt/docs/Makefile",
      "content": "# Makefile for Sphinx documentation\n#\n\n# You can set these variables from the command line.\nSPHINXOPTS    =\nSPHINXBUILD   = sphinx-build\nPAPER         =\nBUILDDIR      = _build\n\n# Internal variables.\nPAPEROPT_a4     = -D latex_paper_size=a4\nPAPEROPT_letter = -D latex_paper_size=letter\nALLSPHINXOPTS   = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .\n# the i18n builder cannot share the environment and doctrees with the others\nI18NSPHINXOPTS  = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .\n\n.PHONY: help clean html dirhtml singlehtml pickle json htmlhelp qthelp devhelp epub latex latexpdf text man changes linkcheck doctest gettext\n\nhelp:\n\t@echo \"Please use \\`make <target>' where <target> is one of\"\n\t@echo \"  html       to make standalone HTML files\"\n\t@echo \"  dirhtml    to make HTML files named index.html in directories\"\n\t@echo \"  singlehtml to make a single large HTML file\"\n\t@echo \"  pickle     to make pickle files\"\n\t@echo \"  json       to make JSON files\"\n\t@echo \"  htmlhelp   to make HTML files and a HTML help project\"\n\t@echo \"  qthelp     to make HTML files and a qthelp project\"\n\t@echo \"  devhelp    to make HTML files and a Devhelp project\"\n\t@echo \"  epub       to make an epub\"\n\t@echo \"  latex      to make LaTeX files, you can set PAPER=a4 or PAPER=letter\"\n\t@echo \"  latexpdf   to make LaTeX files and run them through pdflatex\"\n\t@echo \"  text       to make text files\"\n\t@echo \"  man        to make manual pages\"\n\t@echo \"  texinfo    to make Texinfo files\"\n\t@echo \"  info       to make Texinfo files and run them through makeinfo\"\n\t@echo \"  gettext    to make PO message catalogs\"\n\t@echo \"  changes    to make an overview of all changed/added/deprecated items\"\n\t@echo \"  linkcheck  to check all external links for integrity\"\n\t@echo \"  doctest    to run all doctests embedded in the documentation (if enabled)\"\n\nclean:\n\t-rm -rf $(BUILDDIR)/*\n\nhtml:\n\t$(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html\n\t@echo\n\t@echo \"Build finished. The HTML pages are in $(BUILDDIR)/html.\"\n\ndirhtml:\n\t$(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml\n\t@echo\n\t@echo \"Build finished. The HTML pages are in $(BUILDDIR)/dirhtml.\"\n\nsinglehtml:\n\t$(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml\n\t@echo\n\t@echo \"Build finished. The HTML page is in $(BUILDDIR)/singlehtml.\"\n\npickle:\n\t$(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle\n\t@echo\n\t@echo \"Build finished; now you can process the pickle files.\"\n\njson:\n\t$(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json\n\t@echo\n\t@echo \"Build finished; now you can process the JSON files.\"\n\nhtmlhelp:\n\t$(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp\n\t@echo\n\t@echo \"Build finished; now you can run HTML Help Workshop with the\" \\\n\t      \".hhp project file in $(BUILDDIR)/htmlhelp.\"\n\nqthelp:\n\t$(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp\n\t@echo\n\t@echo \"Build finished; now you can run \"qcollectiongenerator\" with the\" \\\n\t      \".qhcp project file in $(BUILDDIR)/qthelp, like this:\"\n\t@echo \"# qcollectiongenerator $(BUILDDIR)/qthelp/DDT.qhcp\"\n\t@echo \"To view the help file:\"\n\t@echo \"# assistant -collectionFile $(BUILDDIR)/qthelp/DDT.qhc\"\n\ndevhelp:\n\t$(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp\n\t@echo\n\t@echo \"Build finished.\"\n\t@echo \"To view the help file:\"\n\t@echo \"# mkdir -p $$HOME/.local/share/devhelp/DDT\"\n\t@echo \"# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/DDT\"\n\t@echo \"# devhelp\"\n\nepub:\n\t$(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub\n\t@echo\n\t@echo \"Build finished. The epub file is in $(BUILDDIR)/epub.\"\n\nlatex:\n\t$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex\n\t@echo\n\t@echo \"Build finished; the LaTeX files are in $(BUILDDIR)/latex.\"\n\t@echo \"Run \\`make' in that directory to run these through (pdf)latex\" \\\n\t      \"(use \\`make latexpdf' here to do that automatically).\"\n\nlatexpdf:\n\t$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex\n\t@echo \"Running LaTeX files through pdflatex...\"\n\t$(MAKE) -C $(BUILDDIR)/latex all-pdf\n\t@echo \"pdflatex finished; the PDF files are in $(BUILDDIR)/latex.\"\n\ntext:\n\t$(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text\n\t@echo\n\t@echo \"Build finished. The text files are in $(BUILDDIR)/text.\"\n\nman:\n\t$(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man\n\t@echo\n\t@echo \"Build finished. The manual pages are in $(BUILDDIR)/man.\"\n\ntexinfo:\n\t$(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo\n\t@echo\n\t@echo \"Build finished. The Texinfo files are in $(BUILDDIR)/texinfo.\"\n\t@echo \"Run \\`make' in that directory to run these through makeinfo\" \\\n\t      \"(use \\`make info' here to do that automatically).\"\n\ninfo:\n\t$(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo\n\t@echo \"Running Texinfo files through makeinfo...\"\n\tmake -C $(BUILDDIR)/texinfo info\n\t@echo \"makeinfo finished; the Info files are in $(BUILDDIR)/texinfo.\"\n\ngettext:\n\t$(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale\n\t@echo\n\t@echo \"Build finished. The message catalogs are in $(BUILDDIR)/locale.\"\n\nchanges:\n\t$(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes\n\t@echo\n\t@echo \"The overview file is in $(BUILDDIR)/changes.\"\n\nlinkcheck:\n\t$(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck\n\t@echo\n\t@echo \"Link check complete; look for any errors in the above output \" \\\n\t      \"or in $(BUILDDIR)/linkcheck/output.txt.\"\n\ndoctest:\n\t$(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest\n\t@echo \"Testing of doctests in the sources finished, look at the \" \\\n\t      \"results in $(BUILDDIR)/doctest/output.txt.\"\n"
    },
    {
      "path": "datadriventests_ddt/docs/api.rst",
      "content": "API\n===\n\n.. automodule:: ddt\n    :members:\n\n.. automodule:: named_data\n    :members:"
    },
    {
      "path": "datadriventests_ddt/docs/conf.py",
      "content": "# -*- coding: utf-8 -*-\n#\n# DDT documentation build configuration file, created by\n# sphinx-quickstart on Tue Feb 21 23:00:01 2012.\n#\n# This file is execfile()d with the current directory set to its containing dir.\n#\n# Note that not all possible configuration values are present in this\n# autogenerated file.\n#\n# All configuration values have a default; values that are commented out\n# serve to show the default.\n\nimport sys, os\n\n# Specific for readthedocs.org\non_rtd = os.environ.get('READTHEDOCS', None) == 'True'\n\n# If extensions (or modules to document with autodoc) are in another directory,\n# add these directories to sys.path here. If the directory is relative to the\n# documentation root, use os.path.abspath to make it absolute, like shown here.\n#sys.path.insert(0, os.path.abspath('.'))\ndocs_root = os.path.dirname(__file__)\nsys.path.insert(0, os.path.split(docs_root)[0])\n\n# -- General configuration -----------------------------------------------------\n\n# If your documentation needs a minimal Sphinx version, state it here.\n#needs_sphinx = '1.0'\n\n# Add any Sphinx extension module names here, as strings. They can be extensions\n# coming with Sphinx (named 'sphinx.ext.*') or your custom ones.\nextensions = ['sphinx.ext.autodoc']\nif not on_rtd:\n    extensions.append('sphinxcontrib.programoutput')\n\n# Add any paths that contain templates here, relative to this directory.\ntemplates_path = ['_templates']\n\n# The suffix of source filenames.\nsource_suffix = '.rst'\n\n# The encoding of source files.\n#source_encoding = 'utf-8-sig'\n\n# The master toctree document.\nmaster_doc = 'index'\n\n# General information about the project.\nproject = u'DDT'\n# pylint: disable-msg=W0622\n# - copyright is a builtin\ncopyright = u'2012, Carles Barrobés'\n\n# The version info for the project you're documenting, acts as replacement for\n# |version| and |release|, also used in various other places throughout the\n# built documents.\n\nfrom ddt import __version__\n# The short X.Y version.\nversion = __version__\n# The full version, including alpha/beta/rc tags.\nrelease = __version__\n\n# The language for content autogenerated by Sphinx. Refer to documentation\n# for a list of supported languages.\n#language = None\n\n# There are two options for replacing |today|: either, you set today to some\n# non-false value, then it is used:\n#today = ''\n# Else, today_fmt is used as the format for a strftime call.\n#today_fmt = '%B %d, %Y'\n\n# List of patterns, relative to source directory, that match files and\n# directories to ignore when looking for source files.\nexclude_patterns = ['_build']\n\n# The reST default role (used for this markup: `text`) to use for all documents.\n#default_role = None\n\n# If true, '()' will be appended to :func: etc. cross-reference text.\n#add_function_parentheses = True\n\n# If true, the current module name will be prepended to all description\n# unit titles (such as .. function::).\n#add_module_names = True\n\n# If true, sectionauthor and moduleauthor directives will be shown in the\n# output. They are ignored by default.\n#show_authors = False\n\n# The name of the Pygments (syntax highlighting) style to use.\npygments_style = 'sphinx'\n\n# A list of ignored prefixes for module index sorting.\n#modindex_common_prefix = []\n\n\n# -- Options for HTML output ---------------------------------------------------\n\n# The theme to use for HTML and HTML Help pages.  See the documentation for\n# a list of builtin themes.\nif on_rtd:\n    html_theme = 'default'\nelse:\n    html_theme = 'sphinxdoc'\n\n# Theme options are theme-specific and customize the look and feel of a theme\n# further.  For a list of options available for each theme, see the\n# documentation.\n#html_theme_options = {}\n\n# Add any paths that contain custom themes here, relative to this directory.\n#html_theme_path = []\n\n# The name for this set of Sphinx documents.  If None, it defaults to\n# \"<project> v<release> documentation\".\n#html_title = None\n\n# A shorter title for the navigation bar.  Default is the same as html_title.\n#html_short_title = None\n\n# The name of an image file (relative to this directory) to place at the top\n# of the sidebar.\n#html_logo = None\n\n# The name of an image file (within the static path) to use as favicon of the\n# docs.  This file should be a Windows icon file (.ico) being 16x16 or 32x32\n# pixels large.\n#html_favicon = None\n\n# Add any paths that contain custom static files (such as style sheets) here,\n# relative to this directory. They are copied after the builtin static files,\n# so a file named \"default.css\" will overwrite the builtin \"default.css\".\nhtml_static_path = ['_static']\n\n# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,\n# using the given strftime format.\n#html_last_updated_fmt = '%b %d, %Y'\n\n# If true, SmartyPants will be used to convert quotes and dashes to\n# typographically correct entities.\n#html_use_smartypants = True\n\n# Custom sidebar templates, maps document names to template names.\n#html_sidebars = {}\n\n# Additional templates that should be rendered to pages, maps page names to\n# template names.\n#html_additional_pages = {}\n\n# If false, no module index is generated.\n#html_domain_indices = True\n\n# If false, no index is generated.\n#html_use_index = True\n\n# If true, the index is split into individual pages for each letter.\n#html_split_index = False\n\n# If true, links to the reST sources are added to the pages.\n#html_show_sourcelink = True\n\n# If true, \"Created using Sphinx\" is shown in the HTML footer. Default is True.\n#html_show_sphinx = True\n\n# If true, \"(C) Copyright ...\" is shown in the HTML footer. Default is True.\n#html_show_copyright = True\n\n# If true, an OpenSearch description file will be output, and all pages will\n# contain a <link> tag referring to it.  The value of this option must be the\n# base URL from which the finished HTML is served.\n#html_use_opensearch = ''\n\n# This is the file name suffix for HTML files (e.g. \".xhtml\").\n#html_file_suffix = None\n\n# Output file base name for HTML help builder.\nhtmlhelp_basename = 'DDTdoc'\n\n\n# -- Options for LaTeX output --------------------------------------------------\n\nlatex_elements = {\n# The paper size ('letterpaper' or 'a4paper').\n#'papersize': 'letterpaper',\n\n# The font size ('10pt', '11pt' or '12pt').\n#'pointsize': '10pt',\n\n# Additional stuff for the LaTeX preamble.\n#'preamble': '',\n}\n\n# Grouping the document tree into LaTeX files. List of tuples\n# (source start file, target name, title, author, documentclass [howto/manual]).\nlatex_documents = [\n  ('index', 'DDT.tex', u'DDT Documentation',\n   u'Carles Barrobés', 'manual'),\n]\n\n# The name of an image file (relative to this directory) to place at the top of\n# the title page.\n#latex_logo = None\n\n# For \"manual\" documents, if this is true, then toplevel headings are parts,\n# not chapters.\n#latex_use_parts = False\n\n# If true, show page references after internal links.\n#latex_show_pagerefs = False\n\n# If true, show URL addresses after external links.\n#latex_show_urls = False\n\n# Documents to append as an appendix to all manuals.\n#latex_appendices = []\n\n# If false, no module index is generated.\n#latex_domain_indices = True\n\n\n# -- Options for manual page output --------------------------------------------\n\n# One entry per manual page. List of tuples\n# (source start file, name, description, authors, manual section).\nman_pages = [\n    ('index', 'ddt', u'DDT Documentation',\n     [u'Carles Barrobés'], 1)\n]\n\n# If true, show URL addresses after external links.\n#man_show_urls = False\n\n\n# -- Options for Texinfo output ------------------------------------------------\n\n# Grouping the document tree into Texinfo files. List of tuples\n# (source start file, target name, title, author,\n#  dir menu entry, description, category)\ntexinfo_documents = [\n  ('index', 'DDT', u'DDT Documentation',\n   u'Carles Barrobés', 'DDT', 'One line description of project.',\n   'Miscellaneous'),\n]\n\n# Documents to append as an appendix to all manuals.\n#texinfo_appendices = []\n\n# If false, no module index is generated.\n#texinfo_domain_indices = True\n\n# How to display URL addresses: 'footnote', 'no', or 'inline'.\n#texinfo_show_urls = 'footnote'\n"
    },
    {
      "path": "datadriventests_ddt/docs/example.rst",
      "content": "Example usage\n=============\n\nDDT consists of a class decorator ``ddt`` (for your ``TestCase`` subclass)\nand two method decorators (for your tests that want to be multiplied):\n\n* ``data``: contains as many arguments as values you want to feed to the test.\n* ``file_data``: will load test data from a JSON or YAML file.\n\n.. note::\n\n   Only files ending with \".yml\" and \".yaml\" are loaded as YAML files. All\n   other files are loaded as JSON files.\n\nNormally each value within ``data`` will be passed as a single argument to\nyour test method. If these values are e.g. tuples, you will have to unpack them\ninside your test. Alternatively, you can use an additional decorator,\n``unpack``, that will automatically unpack tuples and lists into multiple\narguments, and dictionaries into multiple keyword arguments. See examples\nbelow.\n\nThis allows you to write your tests as:\n\n.. literalinclude:: ../test/test_example.py\n   :language: python\n\nWhere ``test_data_dict_dict.json``:\n\n.. literalinclude:: ../test/data/test_data_dict_dict.json\n   :language: javascript\n\nand ``test_data_dict_dict.yaml``:\n\n.. literalinclude:: ../test/data/test_data_dict_dict.yaml\n   :language: yaml\n\nand ``test_data_dict.json``:\n\n.. literalinclude:: ../test/data/test_data_dict.json\n   :language: javascript\n\nand ``test_data_dict.yaml``:\n\n.. literalinclude:: ../test/data/test_data_dict.yaml\n   :language: yaml\n\nand ``test_data_list.json``:\n\n.. literalinclude:: ../test/data/test_data_list.json\n   :language: javascript\n\nand ``test_data_list.yaml``:\n\n.. literalinclude:: ../test/data/test_data_list.yaml\n   :language: yaml\n\nAnd then run them with your favourite test runner, e.g. if you use pytest::\n\n    $ pytest test/test_example.py\n\n..\n   program-output:: pytest ../test/test_example.py\n\nThe number of test cases actually run and reported separately has been\nmultiplied.\n\n\nDDT will try to give the new test cases meaningful names by converting the\ndata values to valid python identifiers.\n\n\n.. note::\n\n   Python 2.7.3 introduced *hash randomization* which is by default\n   enabled on Python 3.3 and later. DDT's default mechanism to\n   generate meaningful test names will **not** use the test data value\n   as part of the name for complex types if hash randomization is\n   enabled.\n\n   You can disable hash randomization by setting the\n   ``PYTHONHASHSEED`` environment variable to a fixed value before\n   running tests (``export PYTHONHASHSEED=1`` for example).\n"
    },
    {
      "path": "datadriventests_ddt/docs/faq.rst",
      "content": "Known Issues and FAQ\n====================\n\nDocstring Handling\n------------------\n\nIf one of the passed data objects has a docstring, the resulting testcase borrows it.\n\n.. code-block:: python\n\n    d1 = Dataobj()\n    d1.__doc__ = \"\"\"This is a new docstring\"\"\"\n\n    d2 = Dataobj()\n\n    @data(d1, d2)\n    def test_something(self, value):\n        \"\"\"This is an old docstring\"\"\"\n        return value\n\n\nThe first of the resulting test cases will have ``\"\"\"This is a new docstring\"\"\"`` as its docstring and the second will\nkeep its old one (``\"\"\"This is an old docstring\"\"\"``).\n"
    },
    {
      "path": "datadriventests_ddt/docs/index.rst",
      "content": "Welcome to DDT's documentation!\n===============================\n\nDDT (Data-Driven Tests) allows you to multiply one test case\nby running it with different test data, and make it appear as\nmultiple test cases.\n\nYou can find (and fork) the project on Github_.\n\nDDT should work on Python2 and Python3, but we only officially test it for\nversions 2.7 and 3.5-3.8.\n\nContents:\n\n.. toctree::\n   :maxdepth: 2\n\n   example\n   faq\n   api\n\nIndices and tables\n==================\n\n* :ref:`genindex`\n* :ref:`modindex`\n* :ref:`search`\n\n\n.. _Github: https://github.com/datadriventests/ddt\n"
    },
    {
      "path": "datadriventests_ddt/requirements/build.txt",
      "content": "-r test.txt\nSphinx\nsphinxcontrib-programoutput\nenum34; python_version < '3'\n"
    },
    {
      "path": "datadriventests_ddt/requirements/release.txt",
      "content": "wheel\nsetuptools\ntwine\npytest\nenum34; python_version < '3'\n"
    },
    {
      "path": "datadriventests_ddt/requirements/test.txt",
      "content": "aiounittest\ncodecov\ncoverage\nflake8\npytest\npytest-cov\nsix>=1.4.0\nPyYAML\nmock; python_version < '3.3'\n"
    },
    {
      "path": "datadriventests_ddt/test/__init__.py",
      "content": ""
    },
    {
      "path": "datadriventests_ddt/test/mycode.py",
      "content": "\"\"\"\nSome simple functions that we will use in our tests.\n\"\"\"\n\n\ndef larger_than_two(value):\n    return value > 2\n\n\ndef has_three_elements(value):\n    return len(value) == 3\n\n\ndef is_a_greeting(value):\n    return value in ['Hello', 'Goodbye']\n"
    },
    {
      "path": "datadriventests_ddt/test/test_async.py",
      "content": "import aiounittest\n\nfrom ddt import ddt, data\nfrom test.mycode import larger_than_two\n\n\n@ddt\nclass TestAsync(aiounittest.AsyncTestCase):\n    @data(3, 4, 12, 23)\n    async def test_larger_than_two(self, value):\n        self.assertTrue(larger_than_two(value))\n"
    },
    {
      "path": "datadriventests_ddt/test/test_example.py",
      "content": "import itertools\nimport unittest\n\nfrom ddt import ddt, data, file_data, idata, unpack\nfrom test.mycode import larger_than_two, has_three_elements, is_a_greeting\n\ntry:\n    import yaml\nexcept ImportError:  # pragma: no cover\n    have_yaml_support = False\nelse:\n    have_yaml_support = True\n\n# A good-looking decorator\nneeds_yaml = unittest.skipUnless(\n    have_yaml_support, \"Need YAML to run this test\"\n)\n\n\nclass Mylist(list):\n    pass\n\n\nclass MyClass:\n    def __init__(self, **kwargs):\n        for field, value in kwargs.items():\n            setattr(self, field, value)\n\n    def __eq__(self, other):\n        return isinstance(other, dict) and vars(self) == other or \\\n               isinstance(other, MyClass) and vars(self) == vars(other)\n\n    def __str__(self):\n        return \"TestObject %s\" % vars(self)\n\n\ndef annotated(a, b):\n    r = Mylist([a, b])\n    setattr(r, \"__name__\", \"test_%d_greater_than_%d\" % (a, b))\n    return r\n\n\ndef annotated2(listIn, name, docstring):\n    r = Mylist(listIn)\n    setattr(r, \"__name__\", name)\n    setattr(r, \"__doc__\", docstring)\n    return r\n\n\n@ddt\nclass FooTestCase(unittest.TestCase):\n    def test_undecorated(self):\n        self.assertTrue(larger_than_two(24))\n\n    @data(3, 4, 12, 23)\n    def test_larger_than_two(self, value):\n        self.assertTrue(larger_than_two(value))\n\n    @data(1, -3, 2, 0)\n    def test_not_larger_than_two(self, value):\n        self.assertFalse(larger_than_two(value))\n\n    @data(annotated(2, 1), annotated(10, 5))\n    def test_greater(self, value):\n        a, b = value\n        self.assertGreater(a, b)\n\n    @idata(itertools.product([0, 1, 2], [3, 4, 5]))\n    def test_iterable_argument(self, value):\n        first_value, second_value = value\n        self.assertLessEqual(first_value, 2)\n        self.assertGreaterEqual(second_value, 3)\n\n    @data(annotated2([2, 1], 'Test_case_1', \"\"\"Test docstring 1\"\"\"),\n          annotated2([10, 5], 'Test_case_2', \"\"\"Test docstring 2\"\"\"))\n    def test_greater_with_name_docstring(self, value):\n        a, b = value\n        self.assertGreater(a, b)\n        self.assertIsNotNone(getattr(value, \"__name__\"))\n        self.assertIsNotNone(getattr(value, \"__doc__\"))\n\n    @file_data('data/test_data_dict_dict.json')\n    def test_file_data_json_dict_dict(self, start, end, value):\n        self.assertLess(start, end)\n        self.assertLess(value, end)\n        self.assertGreater(value, start)\n\n    @file_data('data/test_data_dict.json')\n    def test_file_data_json_dict(self, value):\n        self.assertTrue(has_three_elements(value))\n\n    @file_data('data/test_data_list.json')\n    def test_file_data_json_list(self, value):\n        self.assertTrue(is_a_greeting(value))\n\n    @needs_yaml\n    @file_data('data/test_data_dict_dict.yaml')\n    def test_file_data_yaml_dict_dict(self, start, end, value):\n        self.assertLess(start, end)\n        self.assertLess(value, end)\n        self.assertGreater(value, start)\n\n    @needs_yaml\n    @file_data('data/test_data_dict.yaml')\n    def test_file_data_yaml_dict(self, value):\n        self.assertTrue(has_three_elements(value))\n\n    @needs_yaml\n    @file_data('data/test_data_list.yaml')\n    def test_file_data_yaml_list(self, value):\n        self.assertTrue(is_a_greeting(value))\n\n    @data((3, 2), (4, 3), (5, 3))\n    @unpack\n    def test_tuples_extracted_into_arguments(self, first_value, second_value):\n        self.assertTrue(first_value > second_value)\n\n    @data([3, 2], [4, 3], [5, 3])\n    @unpack\n    def test_list_extracted_into_arguments(self, first_value, second_value):\n        self.assertTrue(first_value > second_value)\n\n    @unpack\n    @data({'first': 1, 'second': 3, 'third': 2},\n          {'first': 4, 'second': 6, 'third': 5})\n    def test_dicts_extracted_into_kwargs(self, first, second, third):\n        self.assertTrue(first < third < second)\n\n    @data(u'ascii', u'non-ascii-\\N{SNOWMAN}')\n    def test_unicode(self, value):\n        self.assertIn(value, (u'ascii', u'non-ascii-\\N{SNOWMAN}'))\n\n    @data(3, 4, 12, 23)\n    def test_larger_than_two_with_doc(self, value):\n        \"\"\"Larger than two with value {0}\"\"\"\n        self.assertTrue(larger_than_two(value))\n\n    @data(3, 4, 12, 23)\n    def test_doc_missing_args(self, value):\n        \"\"\"Missing args with value {0} and {1}\"\"\"\n        self.assertTrue(larger_than_two(value))\n\n    @data(3, 4, 12, 23)\n    def test_doc_missing_kargs(self, value):\n        \"\"\"Missing kargs with value {value} {value2}\"\"\"\n        self.assertTrue(larger_than_two(value))\n\n    @data([3, 2], [4, 3], [5, 3])\n    @unpack\n    def test_list_extracted_with_doc(self, first_value, second_value):\n        \"\"\"Extract into args with first value {} and second value {}\"\"\"\n        self.assertTrue(first_value > second_value)\n\n\nif have_yaml_support:\n    # This test will only succeed if the execution context is from the ddt\n    # directory. pyyaml cannot locate test.test_example.MyClass otherwise!\n\n    @ddt\n    class YamlOnlyTestCase(unittest.TestCase):\n        @file_data('data/test_custom_yaml_loader.yaml', yaml.UnsafeLoader)\n        def test_custom_yaml_loader(self, instance, expected):\n            \"\"\"Test with yaml tags to create specific classes to compare\"\"\"\n            self.assertEqual(expected, instance)\n"
    },
    {
      "path": "datadriventests_ddt/test/test_functional.py",
      "content": "import os\nimport json\nfrom sys import modules\nimport pytest\nimport six\n\ntry:\n    from unittest import mock\nexcept ImportError:\n    import mock\n\nfrom ddt import ddt, data, file_data, idata, TestNameFormat\n\nfrom test.mycode import has_three_elements\n\n\nclass CustomClass:\n    pass\n\n\n@ddt\nclass Dummy(object):\n    \"\"\"\n    Dummy class to test the data decorator on\n    \"\"\"\n\n    @data(1, 2, 3, 4)\n    def test_something(self, value):\n        return value\n\n\n@ddt(testNameFormat=TestNameFormat.DEFAULT)\nclass DummyTestNameFormatDefault(object):\n    \"\"\"\n    Dummy class to test the ddt decorator that generates test names using the\n    default format (index and values).\n    \"\"\"\n\n    @data(\"a\", \"b\", \"c\", \"d\")\n    def test_something(self, value):\n        return value\n\n\n@ddt(testNameFormat=TestNameFormat.INDEX_ONLY)\nclass DummyTestNameFormatIndexOnly(object):\n    \"\"\"\n    Dummy class to test the ddt decorator that generates test names using only\n    the index.\n    \"\"\"\n\n    @data(\"a\", \"b\", \"c\", \"d\")\n    def test_something(self, value):\n        return value\n\n\n@ddt\nclass DummyInvalidIdentifier():\n    \"\"\"\n    Dummy class to test the data decorator receiving values invalid characters\n    identifiers\n    \"\"\"\n\n    @data('32v2 g #Gmw845h$W b53wi.')\n    def test_data_with_invalid_identifier(self, value):\n        return value\n\n\n@ddt\nclass FileDataDummy(object):\n    \"\"\"\n    Dummy class to test the file_data decorator on\n    \"\"\"\n\n    @file_data(\"data/test_data_dict.json\")\n    def test_something_again(self, value):\n        return value\n\n\n@ddt\nclass JSONFileDataMissingDummy(object):\n    \"\"\"\n    Dummy class to test the file_data decorator on when\n    JSON file is missing\n    \"\"\"\n\n    @file_data(\"data/test_data_dict_missing.json\")\n    def test_something_again(self, value):\n        return value\n\n\n@ddt\nclass YAMLFileDataMissingDummy(object):\n    \"\"\"\n    Dummy class to test the file_data decorator on when\n    YAML file is missing\n    \"\"\"\n\n    @file_data(\"data/test_data_dict_missing.yaml\")\n    def test_something_again(self, value):\n        return value\n\n\ndef test_data_decorator():\n    \"\"\"\n    Test the ``data`` method decorator\n    \"\"\"\n\n    def hello():\n        pass\n\n    pre_size = len(hello.__dict__)\n    keys = set(hello.__dict__.keys())\n    data_hello = data(1, 2)(hello)\n    dh_keys = set(data_hello.__dict__.keys())\n    post_size = len(data_hello.__dict__)\n\n    assert post_size == pre_size + 2\n    extra_attrs = list(dh_keys - keys)\n    extra_attrs.sort()\n    assert len(extra_attrs) == 2\n    assert getattr(data_hello, extra_attrs[0]) == 1\n    assert getattr(data_hello, extra_attrs[1]) == (1, 2)\n\n\ndef test_file_data_decorator_with_dict():\n    \"\"\"\n    Test the ``file_data`` method decorator\n    \"\"\"\n\n    def hello():\n        pass\n\n    pre_size = len(hello.__dict__)\n    keys = set(hello.__dict__.keys())\n    data_hello = data(\"test_data_dict.json\")(hello)\n\n    dh_keys = set(data_hello.__dict__.keys())\n    post_size = len(data_hello.__dict__)\n    assert post_size == pre_size + 2\n\n    extra_attrs = list(dh_keys - keys)\n    extra_attrs.sort()\n    assert len(extra_attrs) == 2\n    assert getattr(data_hello, extra_attrs[0]) == 1\n    assert getattr(data_hello, extra_attrs[1]) == (\"test_data_dict.json\",)\n\n\ndef _is_test(x):\n    return x.startswith('test_')\n\n\ndef test_ddt():\n    \"\"\"\n    Test the ``ddt`` class decorator\n    \"\"\"\n    tests = len(list(filter(_is_test, Dummy.__dict__)))\n    assert tests == 4\n\n\ndef test_ddt_format_test_name_index_only():\n    \"\"\"\n    Test the ``ddt`` class decorator with ``INDEX_ONLY`` test name format\n    \"\"\"\n    tests = set(filter(_is_test, DummyTestNameFormatIndexOnly.__dict__))\n    assert len(tests) == 4\n\n    indexes = range(1, 5)\n    dataSets = [\"a\", \"b\", \"c\", \"d\"]  # @data from DummyTestNameFormatIndexOnly\n    for i, d in zip(indexes, dataSets):\n        assert (\"test_something_{}\".format(i) in tests)\n        assert not (\"test_something_{}_{}\".format(i, d) in tests)\n\n\ndef test_ddt_format_test_name_default():\n    \"\"\"\n    Test the ``ddt`` class decorator with ``DEFAULT`` test name format\n    \"\"\"\n    tests = set(filter(_is_test, DummyTestNameFormatDefault.__dict__))\n    assert len(tests) == 4\n\n    indexes = range(1, 5)\n    dataSets = [\"a\", \"b\", \"c\", \"d\"]  # @data from DummyTestNameFormatDefault\n    for i, d in zip(indexes, dataSets):\n        assert not (\"test_something_{}\".format(i) in tests)\n        assert (\"test_something_{}_{}\".format(i, d) in tests)\n\n\ndef test_idata_single_argument():\n    \"\"\"Test that the single-argument form of ``idata`` works.\"\"\"\n    payload = [5, 12, 13]\n\n    @ddt\n    class Dummy(object):\n        \"\"\"Dummy class to test that the ``idata(iterable)`` decorator works.\"\"\"\n        @idata(payload)\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n    assert len(tests) == len(payload)\n\n    expected_tests = [\n        \"test_something_{:1d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_idata_automatic_zero_padding():\n    \"\"\"\n    Test that the single-argument form of ``idata`` zero-pads its keys so the\n    lengths all match\n    \"\"\"\n    payload = range(15)\n\n    @ddt\n    class Dummy(object):\n        \"\"\"Dummy class to test that the ``idata(iterable)`` decorator works.\"\"\"\n        @idata(payload)\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n    assert len(tests) == len(payload)\n\n    expected_tests = [\n        \"test_something_{:02d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_idata_override_index_len():\n    \"\"\"\n    Test that overriding ``index_len`` in ``idata`` can allow additional\n    zero-padding to be added.\n    \"\"\"\n    payload = [4, 2, 1]\n\n    @ddt\n    class Dummy(object):\n        @idata(payload, index_len=2)\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n    assert len(tests) == len(payload)\n\n    expected_tests = [\n        \"test_something_{:02d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_idata_consumable_iterator():\n    \"\"\"\n    Test that using ``idata`` with a consumable iterator still generates the\n    expected tests.\n    \"\"\"\n    payload = [51, 78, 2]\n\n    def consumable_iterator():\n        # Not using `yield from` for Python 2.7.\n        for i in payload:\n            yield i\n\n    @ddt\n    class Dummy(object):\n        @idata(consumable_iterator())\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n\n    expected_tests = [\n        \"test_something_{:1d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_file_data_test_creation():\n    \"\"\"\n    Test that the ``file_data`` decorator creates two tests\n    \"\"\"\n\n    tests = len(list(filter(_is_test, FileDataDummy.__dict__)))\n    assert tests == 2\n\n\ndef test_file_data_test_names_dict():\n    \"\"\"\n    Test that ``file_data`` creates tests with the correct name\n\n    Name is the the function name plus the key in the JSON data,\n    when it is parsed as a dictionary.\n    \"\"\"\n\n    tests = set(filter(_is_test, FileDataDummy.__dict__))\n\n    tests_dir = os.path.dirname(__file__)\n    test_data_path = os.path.join(tests_dir, 'data/test_data_dict.json')\n    test_data = json.loads(open(test_data_path).read())\n    index_len = len(str(len(test_data)))\n    created_tests = set([\n        \"test_something_again_{0:0{2}}_{1}\".format(index + 1, name, index_len)\n        for index, name in enumerate(test_data.keys())\n    ])\n\n    assert tests == created_tests\n\n\ndef test_feed_data_data():\n    \"\"\"\n    Test that data is fed to the decorated tests\n    \"\"\"\n    tests = filter(_is_test, Dummy.__dict__)\n\n    values = []\n    obj = Dummy()\n    for test in tests:\n        method = getattr(obj, test)\n        values.append(method())\n\n    assert set(values) == set([1, 2, 3, 4])\n\n\ndef test_feed_data_file_data():\n    \"\"\"\n    Test that data is fed to the decorated tests from a file\n    \"\"\"\n    tests = filter(_is_test, FileDataDummy.__dict__)\n\n    values = []\n    obj = FileDataDummy()\n    for test in tests:\n        method = getattr(obj, test)\n        values.extend(method())\n\n    assert set(values) == set([10, 12, 15, 15, 12, 50])\n\n\ndef test_feed_data_file_data_missing_json():\n    \"\"\"\n    Test that a ValueError is raised when JSON file is missing\n    \"\"\"\n    tests = filter(_is_test, JSONFileDataMissingDummy.__dict__)\n\n    obj = JSONFileDataMissingDummy()\n    for test in tests:\n        method = getattr(obj, test)\n        with pytest.raises(ValueError):\n            method()\n\n\ndef test_feed_data_file_data_missing_yaml():\n    \"\"\"\n    Test that a ValueError is raised when YAML file is missing\n    \"\"\"\n    tests = filter(_is_test, YAMLFileDataMissingDummy.__dict__)\n\n    obj = YAMLFileDataMissingDummy()\n    for test in tests:\n        method = getattr(obj, test)\n        with pytest.raises(ValueError):\n            method()\n\n\ndef test_ddt_data_name_attribute():\n    \"\"\"\n    Test the ``__name__`` attribute handling of ``data`` items with ``ddt``\n    \"\"\"\n\n    def hello():\n        pass\n\n    class Myint(int):\n        pass\n\n    class Mytest(object):\n        pass\n\n    d1 = Myint(1)\n    d1.__name__ = 'data1'\n\n    d2 = Myint(2)\n\n    data_hello = data(d1, d2)(hello)\n    setattr(Mytest, 'test_hello', data_hello)\n\n    ddt_mytest = ddt(Mytest)\n    assert getattr(ddt_mytest, 'test_hello_1_data1')\n    assert getattr(ddt_mytest, 'test_hello_2_2')\n\n\ndef test_ddt_data_doc_attribute():\n    \"\"\"\n    Test the ``__doc__`` attribute handling of ``data`` items with ``ddt``\n    \"\"\"\n\n    def func_w_doc():\n        \"\"\"testFunctionDocstring {6}\n\n        :param: None\n        :return: None\n        \"\"\"\n        pass\n\n    def func_wo_doc():\n        pass\n\n    class Myint(int):\n        pass\n\n    class Mytest(object):\n        pass\n\n    d1 = Myint(1)\n    d1.__name__ = 'case1'\n    d1.__doc__ = \"\"\"docstring1\"\"\"\n\n    d2 = Myint(2)\n    d2.__name__ = 'case2'\n\n    data_hello = data(d1, d2, {'test': True})(func_w_doc)\n    data_hello2 = data(d1, d2, {'test': True})(func_wo_doc)\n\n    setattr(Mytest, 'first_test', data_hello)\n    setattr(Mytest, 'second_test', data_hello2)\n    ddt_mytest = ddt(Mytest)\n\n    assert getattr(\n        getattr(ddt_mytest, 'first_test_1_case1'), '__doc__'\n    ) == d1.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'first_test_2_case2'), '__doc__'\n    ) == func_w_doc.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'first_test_3'), '__doc__'\n    ) == func_w_doc.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'second_test_1_case1'), '__doc__'\n    ) == d1.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'second_test_2_case2'), '__doc__'\n    ) is None\n    assert getattr(getattr(ddt_mytest, 'second_test_3'), '__doc__') is None\n\n\ndef test_ddt_data_unicode():\n    \"\"\"\n    Test that unicode strings are converted to function names correctly\n    \"\"\"\n    # We test unicode support separately for python 2 and 3\n\n    if six.PY2:\n\n        @ddt\n        class Mytest(object):\n            @data(u'ascii', u'non-ascii-\\N{SNOWMAN}', {u'\\N{SNOWMAN}': 'data'})\n            def test_hello(self, val):\n                pass\n\n        assert getattr(Mytest, 'test_hello_1_ascii') is not None\n        assert getattr(Mytest, 'test_hello_2_non_ascii__u2603') is not None\n        assert getattr(Mytest, 'test_hello_3') is not None\n\n    elif six.PY3:\n\n        @ddt\n        class Mytest(object):\n            @data('ascii', 'non-ascii-\\N{SNOWMAN}', {'\\N{SNOWMAN}': 'data'})\n            def test_hello(self, val):\n                pass\n\n        assert getattr(Mytest, 'test_hello_1_ascii') is not None\n        assert getattr(Mytest, 'test_hello_2_non_ascii__') is not None\n        assert getattr(Mytest, 'test_hello_3') is not None\n\n\ndef test_ddt_data_object():\n    \"\"\"\n    Test not using value if non-trivial arguments\n    \"\"\"\n\n    @ddt\n    class Mytest(object):\n        @data(object())\n        def test_object(self, val):\n            pass\n    assert getattr(Mytest, 'test_object_1') is not None\n\n\ndef test_feed_data_with_invalid_identifier():\n    \"\"\"\n    Test that data is fed to the decorated tests\n    \"\"\"\n    tests = list(filter(_is_test, DummyInvalidIdentifier.__dict__))\n    assert len(tests) == 1\n\n    obj = DummyInvalidIdentifier()\n    method = getattr(obj, tests[0])\n    assert (\n        method.__name__ ==\n        'test_data_with_invalid_identifier_1_32v2_g__Gmw845h_W_b53wi_'\n    )\n    assert method() == '32v2 g #Gmw845h$W b53wi.'\n\n\n@mock.patch('ddt._have_yaml', False)\ndef test_load_yaml_without_yaml_support():\n    \"\"\"\n    Test that YAML files are not loaded if YAML is not installed.\n    \"\"\"\n\n    @ddt\n    class NoYAMLInstalledTest(object):\n\n        @file_data('data/test_data_dict.yaml')\n        def test_file_data_yaml_dict(self, value):\n            assert has_three_elements(value)\n\n    tests = filter(_is_test, NoYAMLInstalledTest.__dict__)\n\n    obj = NoYAMLInstalledTest()\n    for test in tests:\n        method = getattr(obj, test)\n        with pytest.raises(ValueError):\n            method()\n\n\ndef test_load_yaml_with_python_tag():\n    \"\"\"\n    Test that YAML files containing python tags throw no exception if an\n    loader allowing python tags is passed.\n    \"\"\"\n\n    from yaml import UnsafeLoader\n    from yaml.constructor import ConstructorError\n\n    def str_to_type(class_name):\n        return getattr(modules[__name__], class_name)\n\n    try:\n        @ddt\n        class YamlDefaultLoaderTest(object):\n            @file_data('data/test_functional_custom_tags.yaml')\n            def test_cls_is_instance(self, cls, expected):\n                assert isinstance(cls, str_to_type(expected))\n    except Exception as e:\n        if not isinstance(e, ConstructorError):\n            raise AssertionError()\n\n    @ddt\n    class YamlUnsafeLoaderTest(object):\n        @file_data('data/test_functional_custom_tags.yaml', UnsafeLoader)\n        def test_cls_is_instance(self, instance, expected):\n            assert isinstance(instance, str_to_type(expected))\n\n    tests = list(filter(_is_test, YamlUnsafeLoaderTest.__dict__))\n    obj = YamlUnsafeLoaderTest()\n\n    if not tests:\n        raise AssertionError('No tests have been found.')\n\n    for test in tests:\n        method = getattr(obj, test)\n        method()\n"
    },
    {
      "path": "datadriventests_ddt/test/test_named_data.py",
      "content": "import ddt\nimport unittest\n\n\n@ddt.ddt\nclass TestNamedData(unittest.TestCase):\n    class NonTrivialClass(object):\n        pass\n\n    @ddt.named_data(\n        ['Single', 0, 1]\n    )\n    def test_single_named_value(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        ['1st', 1, 2],\n        ('2nd', 3, 4)\n    )\n    def test_multiple_named_value_seqs(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        dict(name='1st', value2=1, value1=0),\n        {'name': '2nd', 'value2': 1, 'value1': 0}\n    )\n    def test_multiple_named_value_dicts(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        dict(name='1st', value2=1, value1=0),\n        ('2nd', 0, 1)\n    )\n    def test_multiple_named_value_mixed(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        ['Passes', NonTrivialClass(), True],\n        ('Fails', 1, False)\n    )\n    def test_seq_with_nontrivial_type(self, value, passes):\n        if passes:\n            self.assertIsInstance(value, self.NonTrivialClass)\n        else:\n            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n    @ddt.named_data(\n        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n        {'name': 'Fails', 'value': 1, 'passes': False}\n    )\n    def test_dict_with_nontrivial_type(self, value, passes):\n        if passes:\n            self.assertIsInstance(value, self.NonTrivialClass)\n        else:\n            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n    def test_missing_name_dict(self):\n        with self.assertRaises(KeyError):\n            @ddt.named_data(\n                {'not_a_name': 'oops', 'value': 1}\n            )\n            def _internal_test(value):\n                pass\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_custom_yaml_loader.yaml",
      "content": "bool:\n  instance: !!bool \"false\"\n  expected: false\n\nstr:\n  instance: !!str \"test\"\n  expected: test\n\nint:\n  instance: !!int \"32\"\n  expected: 32\n\nfloat:\n  instance: !!float \"3.123\"\n  expected: 3.123\n\npython_list:\n  instance: !!python/list [1,2,3,4]\n  expected:\n    - 1\n    - 2\n    - 3\n    - 4\n\npython_dict:\n  instance: !!python/dict\n    a: 1\n    b: asd\n    c: false\n  expected:\n    a: 1\n    b: asd\n    c: false\n\nmy_class:\n  instance: !!python/object:test.test_example.MyClass\n    a: 132\n    b: true\n    c:\n      - alpha\n      - beta\n    d:\n      _a: 1\n      _b: test\n  expected:\n    a: 132\n    b: true\n    c:\n      - alpha\n      - beta\n    d:\n      _a: 1\n      _b: test\n\npython_str:\n  instance: !!python/str \"test\"\n  expected: test\n\npython_int:\n  instance: !!python/int \"32\"\n  expected: 32\n\npython_float:\n  instance: !!python/float \"3.123\"\n  expected: 3.123\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict.json",
      "content": "{\n    \"unsorted_list\": [ 10, 12, 15 ],\n    \"sorted_list\": [ 15, 12, 50 ]\n}\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict.yaml",
      "content": "unsorted_list:\n  - 10\n  - 15\n  - 12\n\nsorted_list: [ 15, 12, 50 ]\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict_dict.json",
      "content": "{\n    \"positive_integer_range\": {\n        \"start\": 0,\n        \"end\": 2,\n        \"value\": 1\n    },\n    \"negative_integer_range\": {\n        \"start\": -2,\n        \"end\": 0,\n        \"value\": -1\n    },\n    \"positive_real_range\": {\n        \"start\": 0.0,\n        \"end\": 1.0,\n        \"value\": 0.5\n    },\n    \"negative_real_range\": {\n        \"start\": -1.0,\n        \"end\": 0.0,\n        \"value\": -0.5\n    }\n}\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict_dict.yaml",
      "content": "positive_integer_range:\n    start: 0\n    end: 2\n    value: 1\n\nnegative_integer_range:\n    start: -2\n    end: 0\n    value: -1\n\npositive_real_range:\n    start: 0.0\n    end: 1.0\n    value: 0.5\n\nnegative_real_range:\n    start: -1.0\n    end: 0.0\n    value: -0.5\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_list.json",
      "content": "[\n    \"Hello\",\n    \"Goodbye\"\n]\n\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_list.yaml",
      "content": "- \"Hello\"\n- \"Goodbye\"\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_functional_custom_tags.yaml",
      "content": "custom_class:\n  instance: !!python/object:test.test_functional.CustomClass {}\n  expected: CustomClass\n"
    }
  ],
  "BuggyCode": [
    {
      "path": "datadriventests_ddt/CONTRIBUTING.md",
      "content": "# Contributing to DDT\n\n## Guidelines\n\nWe'll be happy if you want to contribute to the improvement of `ddt`.\n\nCode contributions will take the form of pull requests to\n[the github repo](https://github.com/datadriventests/ddt).\n\nYour PRs are more likely to be merged quickly if:\n\n - They adhere to coding conventions in the repo (PEP8)\n - They include tests\n\n## Building\n\nPRs to `ddt` are always built by Travis-CI on Python 2 and 3.\n\nIf you want to build `ddt` locally, the simplest way is to use `tox`:\n\n```\npip install tox\ntox\n```\n\nThis will run tests on various releases of python (2 and 3, as long as they\nare installed in your computer), run `flake8` and build the Sphinx\ndocumentation.\n\nAlternatively, if you only want to run tests on your active version of python,\nI recommend you make yourself a virtual environment and:\n\n```\npip install -r requirements/build.txt\n./build.sh\n```\n"
    },
    {
      "path": "datadriventests_ddt/LICENSE.md",
      "content": "Copyright © 2015 Carles Barrobés and additional contributors.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of\nthis software and associated documentation files (the “Software”), to deal in\nthe Software without restriction, including without limitation the rights to\nuse, copy, modify, merge, publish, distribute, sublicense, and/or sell copies\nof the Software, and to permit persons to whom the Software is furnished to do\nso, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n([MIT License](http://mit-license.org/))\n"
    },
    {
      "path": "datadriventests_ddt/MANIFEST.in",
      "content": "include *.md\nrecursive-include test *.py *.json *.yaml\ninclude MANIFEST.in\ninclude LICENSE.md\ninclude tox.ini\nglobal-exclude *.py[cod] __pycache__\n"
    },
    {
      "path": "datadriventests_ddt/README.md",
      "content": "![Run Tests](https://github.com/datadriventests/ddt/workflows/Run%20Tests/badge.svg?branch=master)\n[![codecov.io](https://codecov.io/github/datadriventests/ddt/coverage.svg?branch=master)](https://codecov.io/github/datadriventests/ddt)\n<br />\n[![Version](https://img.shields.io/pypi/v/ddt.svg)](https://pypi.python.org/pypi/ddt)\n[![Downloads](https://img.shields.io/pypi/dm/ddt.svg)](https://pypi.python.org/pypi/ddt)\n\nDDT (Data-Driven Tests) allows you to multiply one test case\nby running it with different test data, and make it appear as\nmultiple test cases.\n\n# Installation\n\n\n```pip install ddt```\n\nCheck out [the documentation](http://ddt.readthedocs.org/) for more details.\n\nSee [Contributing](CONTRIBUTING.md) if you plan to contribute to `ddt`,\nand [License](LICENSE.md) if you plan to use it.\n"
    },
    {
      "path": "datadriventests_ddt/build.sh",
      "content": "#!/bin/bash\npytest --cov=ddt --cov-report html\nflake8 ddt.py test || echo \"Flake8 errors\"\n(cd docs; make html)\n"
    },
    {
      "path": "datadriventests_ddt/ddt.py",
      "content": "# -*- coding: utf-8 -*-\n# This file is a part of DDT (https://github.com/datadriventests/ddt)\n# Copyright 2012-2015 Carles Barrobés and DDT contributors\n# For the exact contribution history, see the git revision log.\n# DDT is licensed under the MIT License, included in\n# https://github.com/datadriventests/ddt/blob/master/LICENSE.md\n\nimport codecs\nimport inspect\nimport json\nimport os\nimport re\nfrom enum import Enum, unique\nfrom functools import wraps\n\ntry:\n    import yaml\nexcept ImportError:  # pragma: no cover\n    _have_yaml = False\nelse:\n    _have_yaml = True\n\nfrom collections.abc import Sequence\n\n\n__version__ = '1.7.2'\n\n# These attributes will not conflict with any real python attribute\n# They are added to the decorated test method and processed later\n# by the `ddt` class decorator.\n\nDATA_ATTR = '%values'              # store the data the test must run with\nFILE_ATTR = '%file_path'           # store the path to JSON file\nYAML_LOADER_ATTR = '%yaml_loader'  # store custom yaml loader for serialization\nUNPACK_ATTR = '%unpack'            # remember that we have to unpack values\nINDEX_LEN = '%index_len'           # store the index length of the data\n\n\n# These are helper classes for @named_data that allow ddt tests to have meaningful names.\nclass _NamedDataList(list):\n    def __init__(self, name, *args):\n        super(_NamedDataList, self).__init__(args)\n        self.name = name\n\n    def __str__(self):\n        return str(self.name)\n\n\nclass _NamedDataDict(dict):\n    def __init__(self, **kwargs):\n        if \"name\" not in kwargs.keys():\n            raise KeyError(\"@named_data expects a dictionary with a 'name' key.\")\n        self.name = kwargs.pop('name')\n        super(_NamedDataDict, self).__init__(kwargs)\n\n    def __str__(self):\n        return str(self.name)\n\n\ntrivial_types = (type(None), bool, int, float, _NamedDataList, _NamedDataDict)\ntry:\n    trivial_types += (basestring, )\nexcept NameError:\n    trivial_types += (str, )\n\n\n@unique\nclass TestNameFormat(Enum):\n    \"\"\"\n    An enum to configure how ``mk_test_name()`` to compose a test name.  Given\n    the following example:\n\n    .. code-block:: python\n\n        @data(\"a\", \"b\")\n        def testSomething(self, value):\n            ...\n\n    if using just ``@ddt`` or together with ``DEFAULT``:\n\n    * ``testSomething_1_a``\n    * ``testSomething_2_b``\n\n    if using ``INDEX_ONLY``:\n\n    * ``testSomething_1``\n    * ``testSomething_2``\n\n    \"\"\"\n    DEFAULT = 0\n    INDEX_ONLY = 1\n\n\ndef is_trivial(value):\n    if isinstance(value, trivial_types):\n        return True\n    elif isinstance(value, (list, tuple)):\n        return all(map(is_trivial, value))\n    return False\n\n\ndef unpack(func):\n    \"\"\"\n    Method decorator to add unpack feature.\n\n    \"\"\"\n    setattr(func, UNPACK_ATTR, True)\n    return func\n\n\ndef data(*values):\n    \"\"\"\n    Method decorator to add to your test methods.\n\n    Should be added to methods of instances of ``unittest.TestCase``.\n\n    \"\"\"\n    return idata(values)\n\n\ndef idata(iterable, index_len=None):\n    \"\"\"\n    Method decorator to add to your test methods.\n\n    Should be added to methods of instances of ``unittest.TestCase``.\n\n    :param iterable: iterable of the values to provide to the test function.\n    :param index_len: an optional integer specifying the width to zero-pad the\n        test identifier indices to.  If not provided, this will add the fewest\n        zeros necessary to make all identifiers the same length.\n    \"\"\"\n    if index_len is None:\n        # Avoid consuming a one-time-use generator.\n        iterable = tuple(iterable)\n        index_len = len(str(len(iterable)))\n\n    def wrapper(func):\n        setattr(func, DATA_ATTR, iterable)\n        setattr(func, INDEX_LEN, index_len)\n        return func\n\n    return wrapper\n\n\ndef file_data(value, yaml_loader=None):\n    \"\"\"\n    Method decorator to add to your test methods.\n\n    Should be added to methods of instances of ``unittest.TestCase``.\n\n    ``value`` should be a path relative to the directory of the file\n    containing the decorated ``unittest.TestCase``. The file\n    should contain JSON encoded data, that can either be a list or a\n    dict.\n\n    In case of a list, each value in the list will correspond to one\n    test case, and the value will be concatenated to the test method\n    name.\n\n    In case of a dict, keys will be used as suffixes to the name of the\n    test case, and values will be fed as test data.\n\n    ``yaml_loader`` can be used to customize yaml deserialization.\n    The default is ``None``, which results in using the ``yaml.safe_load``\n    method.\n    \"\"\"\n    def wrapper(func):\n        setattr(func, FILE_ATTR, value)\n        if yaml_loader:\n            setattr(func, YAML_LOADER_ATTR, yaml_loader)\n        return func\n    return wrapper\n\n\ndef mk_test_name(name, value, index=0, index_len=5, name_fmt=TestNameFormat.DEFAULT):\n    \"\"\"\n    Generate a new name for a test case.\n\n    It will take the original test name and append an ordinal index and a\n    string representation of the value, and convert the result into a valid\n    python identifier by replacing extraneous characters with ``_``.\n\n    We avoid doing str(value) if dealing with non-trivial values.\n    The problem is possible different names with different runs, e.g.\n    different order of dictionary keys (see PYTHONHASHSEED) or dealing\n    with mock objects.\n    Trivial scalar values are passed as is.\n\n    A \"trivial\" value is a plain scalar, or a tuple or list consisting\n    only of trivial values.\n\n    The test name format is controlled by enum ``TestNameFormat`` as well. See\n    the enum documentation for further details.\n    \"\"\"\n\n    # Add zeros before index to keep order\n    index = \"{0:0{1}}\".format(index + 1, index_len)\n    if name_fmt is TestNameFormat.INDEX_ONLY or not is_trivial(value):\n        return \"{0}_{1}\".format(name, index)\n    try:\n        value = str(value)\n    except UnicodeEncodeError:\n        # fallback for python2\n        value = value.encode('ascii', 'backslashreplace')\n    test_name = \"{0}_{1}_{2}\".format(name, index, value)\n    return re.sub(r'\\W|^(?=\\d)', '_', test_name)\n\n\ndef feed_data(func, new_name, test_data_docstring, *args, **kwargs):\n    \"\"\"\n    This internal method decorator feeds the test data item to the test.\n\n    \"\"\"\n    if inspect.iscoroutinefunction(func):\n        @wraps(func)\n        async def wrapper(self):\n            return await func(self, *args, **kwargs)\n    else:\n        @wraps(func)\n        def wrapper(self):\n            return func(self, *args, **kwargs)\n\n    wrapper.__name__ = new_name\n    wrapper.__wrapped__ = func\n    # set docstring if exists\n    if test_data_docstring is not None:\n        wrapper.__doc__ = test_data_docstring\n    else:\n        # Try to call format on the docstring\n        if func.__doc__:\n            try:\n                wrapper.__doc__ = func.__doc__.format(*args, **kwargs)\n            except (IndexError, KeyError):\n                # Maybe the user has added some of the formating strings\n                # unintentionally in the docstring. Do not raise an exception\n                # as it could be that user is not aware of the\n                # formating feature.\n                pass\n    return wrapper\n\n\ndef add_test(cls, test_name, test_docstring, func, *args, **kwargs):\n    \"\"\"\n    Add a test case to this class.\n\n    The test will be based on an existing function but will give it a new\n    name.\n\n    \"\"\"\n    setattr(cls, test_name, feed_data(func, test_name, test_docstring,\n            *args, **kwargs))\n\n\ndef process_file_data(cls, name, func, file_attr):\n    \"\"\"\n    Process the parameter in the `file_data` decorator.\n    \"\"\"\n    cls_path = os.path.abspath(inspect.getsourcefile(cls))\n    data_file_path = os.path.join(os.path.dirname(cls_path), file_attr)\n\n    def create_error_func(message):  # pylint: disable-msg=W0613\n        def func(*args):\n            raise ValueError(message % file_attr)\n        return func\n\n    # If file does not exist, provide an error function instead\n    if not os.path.exists(data_file_path):\n        test_name = mk_test_name(name, \"error\")\n        test_docstring = \"\"\"Error!\"\"\"\n        add_test(cls, test_name, test_docstring,\n                 create_error_func(\"%s does not exist\"), None)\n        return\n\n    _is_yaml_file = data_file_path.endswith((\".yml\", \".yaml\"))\n\n    # Don't have YAML but want to use YAML file.\n    if _is_yaml_file and not _have_yaml:\n        test_name = mk_test_name(name, \"error\")\n        test_docstring = \"\"\"Error!\"\"\"\n        add_test(\n            cls,\n            test_name,\n            test_docstring,\n            create_error_func(\"%s is a YAML file, please install PyYAML\"),\n            None\n        )\n        return\n\n    with codecs.open(data_file_path, 'r', 'utf-8') as f:\n        # Load the data from YAML or JSON\n        if _is_yaml_file:\n            if hasattr(func, YAML_LOADER_ATTR):\n                yaml_loader = getattr(func, YAML_LOADER_ATTR)\n                data = yaml.load(f, Loader=yaml_loader)\n            else:\n                data = yaml.safe_load(f)\n        else:\n            data = json.load(f)\n\n    _add_tests_from_data(cls, name, func, data)\n\n\ndef _add_tests_from_data(cls, name, func, data):\n    \"\"\"\n    Add tests from data loaded from the data file into the class\n    \"\"\"\n    index_len = len(str(len(data)))\n    for i, elem in enumerate(data):\n        if isinstance(data, dict):\n            key, value = elem, data[elem]\n            test_name = mk_test_name(name, key, i, index_len)\n        elif isinstance(data, list):\n            value = elem\n            test_name = mk_test_name(name, value, i, index_len)\n        if isinstance(value, dict):\n            add_test(cls, test_name, test_name, func, **value)\n        else:\n            add_test(cls, test_name, test_name, func, value)\n\n\ndef _is_primitive(obj):\n    \"\"\"Finds out if the obj is a \"primitive\". It is somewhat hacky but it works.\n    \"\"\"\n    return not hasattr(obj, '__dict__')\n\n\ndef _get_test_data_docstring(func, value):\n    \"\"\"Returns a docstring based on the following resolution strategy:\n    1. Passed value is not a \"primitive\" and has a docstring, then use it.\n    2. In all other cases return None, i.e the test name is used.\n    \"\"\"\n    if not _is_primitive(value) and value.__doc__:\n        return value.__doc__\n    else:\n        return None\n\n\ndef ddt(arg=None, **kwargs):\n    \"\"\"\n    Class decorator for subclasses of ``unittest.TestCase``.\n\n    Apply this decorator to the test case class, and then\n    decorate test methods with ``@data``.\n\n    For each method decorated with ``@data``, this will effectively create as\n    many methods as data items are passed as parameters to ``@data``.\n\n    The names of the test methods follow the pattern\n    ``original_test_name_{ordinal}_{data}``. ``ordinal`` is the position of the\n    data argument, starting with 1.\n\n    For data we use a string representation of the data value converted into a\n    valid python identifier.  If ``data.__name__`` exists, we use that instead.\n\n    For each method decorated with ``@file_data('test_data.json')``, the\n    decorator will try to load the test_data.json file located relative\n    to the python file containing the method that is decorated. It will,\n    for each ``test_name`` key create as many methods in the list of values\n    from the ``data`` key.\n\n    Decorating with the keyword argument ``testNameFormat`` can control the\n    format of the generated test names.  For example:\n\n    - ``@ddt(testNameFormat=TestNameFormat.DEFAULT)`` will be index and values.\n\n    - ``@ddt(testNameFormat=TestNameFormat.INDEX_ONLY)`` will be index only.\n\n    - ``@ddt`` is the same as DEFAULT.\n\n    \"\"\"\n    fmt_test_name = kwargs.get(\"testNameFormat\", TestNameFormat.DEFAULT)\n\n    def wrapper(cls):\n        for name, func in list(cls.__dict__.items()):\n            if hasattr(func, DATA_ATTR):\n                index_len = getattr(func, INDEX_LEN)\n                for i, v in enumerate(getattr(func, DATA_ATTR)):\n                    test_name = mk_test_name(\n                        name,\n                        getattr(v, \"__name__\", v),\n                        i,\n                        index_len,\n                        fmt_test_name\n                    )\n                    test_data_docstring = _get_test_data_docstring(func, v)\n                    if hasattr(func, UNPACK_ATTR):\n                        if isinstance(v, tuple) or isinstance(v, list):\n                            add_test(\n                                cls,\n                                test_name,\n                                test_data_docstring,\n                                func,\n                                *v\n                            )\n                        else:\n                            # unpack dictionary\n                            add_test(\n                                cls,\n                                test_name,\n                                test_data_docstring,\n                                func,\n                                **v\n                            )\n                    else:\n                        add_test(cls, test_name, test_data_docstring, func, v)\n                delattr(cls, name)\n            elif hasattr(func, FILE_ATTR):\n                file_attr = getattr(func, FILE_ATTR)\n                process_file_data(cls, name, func, file_attr)\n                delattr(cls, name)\n        return cls\n\n    # ``arg`` is the unittest's test class when decorating with ``@ddt`` while\n    # it is ``None`` when decorating a test class with ``@ddt(k=v)``.\n    return wrapper(arg) if inspect.isclass(arg) else wrapper\n\n\ndef named_data(*named_values):\n    \"\"\"\n    This decorator is to allow for meaningful names to be given to tests that would otherwise use @ddt.data and\n    @ddt.unpack.\n\n    Example of original ddt usage:\n        @ddt.ddt\n        class TestExample(TemplateTest):\n            @ddt.data(\n                [0, 1],\n                [10, 11]\n            )\n            @ddt.unpack\n            def test_values(self, value1, value2):\n                ...\n\n    Example of new usage:\n        @ddt.ddt\n        class TestExample(TemplateTest):\n            @named_data(\n                ['LabelA', 0, 1],\n                ['LabelB', 10, 11],\n            )\n            def test_values(self, value1, value2):\n                ...\n\n    Note that @unpack is not used.\n\n    :param Sequence[Any] | dict[Any,Any] named_values: Each named_value should be a Sequence (e.g. list or tuple) with\n        the name as the first element, or a dictionary with 'name' as one of the keys. The name will be coerced to a\n        string and all other values will be passed unchanged to the test.\n    \"\"\"\n    values = []\n    for named_value in named_values:\n        if not isinstance(named_value, (Sequence, dict)):\n            raise TypeError(\n                \"@named_data expects a Sequence (list, tuple) or dictionary, and not '{}'.\".format(type(named_value))\n            )\n\n        value = _NamedDataDict(**named_value) if isinstance(named_value, dict) \\\n            else _NamedDataList(named_value[0], *named_value[1:])\n\n        # Remove the __doc__ attribute so @ddt.data doesn't add the NamedData class docstrings to the test name.\n        value.__doc__ = None\n\n        values.append(value)\n\n    def wrapper(func):\n        data(*values)(unpack(func))\n        return func\n\n    return wrapper\n"
    },
    {
      "path": "datadriventests_ddt/release.sh",
      "content": "#!/bin/bash\npython setup.py sdist bdist_wheel upload\n"
    },
    {
      "path": "datadriventests_ddt/rtdocs.sh",
      "content": "curl --data '' http://readthedocs.org/build/ddt\n"
    },
    {
      "path": "datadriventests_ddt/setup.cfg",
      "content": "[bdist_wheel]\nuniversal = 1\n"
    },
    {
      "path": "datadriventests_ddt/setup.py",
      "content": "#!/usr/bin/env python\n# # coding: utf-8\n\nfrom setuptools import setup\nfrom ddt import __version__\n\nsetup(\n    name='ddt',\n    description='Data-Driven/Decorated Tests',\n    long_description='A library to multiply test cases',\n    version=__version__,\n    author='Carles Barrobés',\n    author_email='carles@barrobes.com',\n    url='https://github.com/datadriventests/ddt',\n    py_modules=['ddt'],\n    classifiers=[\n        'Development Status :: 4 - Beta',\n        'Intended Audience :: Developers',\n        'License :: OSI Approved :: MIT License',\n        'Operating System :: OS Independent',\n        'Programming Language :: Python',\n        'Programming Language :: Python :: 3',\n        'Programming Language :: Python :: 3.6',\n        'Programming Language :: Python :: 3.7',\n        'Programming Language :: Python :: 3.8',\n        'Programming Language :: Python :: 3.9',\n        'Programming Language :: Python :: 3.10',\n        'Topic :: Software Development :: Testing',\n    ],\n)\n"
    },
    {
      "path": "datadriventests_ddt/tox.ini",
      "content": "[tox]\nenvlist = py36,py37,py38,py39,py310\n\n[testenv]\ndeps = \n    pytest\n    pytest-cov\n    coverage\n    aiounittest\n    flake8\n    six>=1.4.0\n    PyYAML\ncommands = \n    pytest --cov=ddt --cov-report html\n    flake8 ddt.py test\n\n[flake8]\nmax-line-length = 127\nexclude = .git,__pycache__,docs/source/conf.py,old,build,dist,.tox,.venv\nmax-complexity = 10\n\n[gh-actions]\npython = \n  3.8: py38\n  3.6: py36\n  3.7: py37\n  3.8: py38\n  3.9: py39\n  3.10: py310\n"
    },
    {
      "path": "datadriventests_ddt/docs/Makefile",
      "content": "# Makefile for Sphinx documentation\n#\n\n# You can set these variables from the command line.\nSPHINXOPTS    =\nSPHINXBUILD   = sphinx-build\nPAPER         =\nBUILDDIR      = _build\n\n# Internal variables.\nPAPEROPT_a4     = -D latex_paper_size=a4\nPAPEROPT_letter = -D latex_paper_size=letter\nALLSPHINXOPTS   = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .\n# the i18n builder cannot share the environment and doctrees with the others\nI18NSPHINXOPTS  = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) .\n\n.PHONY: help clean html dirhtml singlehtml pickle json htmlhelp qthelp devhelp epub latex latexpdf text man changes linkcheck doctest gettext\n\nhelp:\n\t@echo \"Please use \\`make <target>' where <target> is one of\"\n\t@echo \"  html       to make standalone HTML files\"\n\t@echo \"  dirhtml    to make HTML files named index.html in directories\"\n\t@echo \"  singlehtml to make a single large HTML file\"\n\t@echo \"  pickle     to make pickle files\"\n\t@echo \"  json       to make JSON files\"\n\t@echo \"  htmlhelp   to make HTML files and a HTML help project\"\n\t@echo \"  qthelp     to make HTML files and a qthelp project\"\n\t@echo \"  devhelp    to make HTML files and a Devhelp project\"\n\t@echo \"  epub       to make an epub\"\n\t@echo \"  latex      to make LaTeX files, you can set PAPER=a4 or PAPER=letter\"\n\t@echo \"  latexpdf   to make LaTeX files and run them through pdflatex\"\n\t@echo \"  text       to make text files\"\n\t@echo \"  man        to make manual pages\"\n\t@echo \"  texinfo    to make Texinfo files\"\n\t@echo \"  info       to make Texinfo files and run them through makeinfo\"\n\t@echo \"  gettext    to make PO message catalogs\"\n\t@echo \"  changes    to make an overview of all changed/added/deprecated items\"\n\t@echo \"  linkcheck  to check all external links for integrity\"\n\t@echo \"  doctest    to run all doctests embedded in the documentation (if enabled)\"\n\nclean:\n\t-rm -rf $(BUILDDIR)/*\n\nhtml:\n\t$(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html\n\t@echo\n\t@echo \"Build finished. The HTML pages are in $(BUILDDIR)/html.\"\n\ndirhtml:\n\t$(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml\n\t@echo\n\t@echo \"Build finished. The HTML pages are in $(BUILDDIR)/dirhtml.\"\n\nsinglehtml:\n\t$(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml\n\t@echo\n\t@echo \"Build finished. The HTML page is in $(BUILDDIR)/singlehtml.\"\n\npickle:\n\t$(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle\n\t@echo\n\t@echo \"Build finished; now you can process the pickle files.\"\n\njson:\n\t$(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json\n\t@echo\n\t@echo \"Build finished; now you can process the JSON files.\"\n\nhtmlhelp:\n\t$(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp\n\t@echo\n\t@echo \"Build finished; now you can run HTML Help Workshop with the\" \\\n\t      \".hhp project file in $(BUILDDIR)/htmlhelp.\"\n\nqthelp:\n\t$(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp\n\t@echo\n\t@echo \"Build finished; now you can run \"qcollectiongenerator\" with the\" \\\n\t      \".qhcp project file in $(BUILDDIR)/qthelp, like this:\"\n\t@echo \"# qcollectiongenerator $(BUILDDIR)/qthelp/DDT.qhcp\"\n\t@echo \"To view the help file:\"\n\t@echo \"# assistant -collectionFile $(BUILDDIR)/qthelp/DDT.qhc\"\n\ndevhelp:\n\t$(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp\n\t@echo\n\t@echo \"Build finished.\"\n\t@echo \"To view the help file:\"\n\t@echo \"# mkdir -p $$HOME/.local/share/devhelp/DDT\"\n\t@echo \"# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/DDT\"\n\t@echo \"# devhelp\"\n\nepub:\n\t$(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub\n\t@echo\n\t@echo \"Build finished. The epub file is in $(BUILDDIR)/epub.\"\n\nlatex:\n\t$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex\n\t@echo\n\t@echo \"Build finished; the LaTeX files are in $(BUILDDIR)/latex.\"\n\t@echo \"Run \\`make' in that directory to run these through (pdf)latex\" \\\n\t      \"(use \\`make latexpdf' here to do that automatically).\"\n\nlatexpdf:\n\t$(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex\n\t@echo \"Running LaTeX files through pdflatex...\"\n\t$(MAKE) -C $(BUILDDIR)/latex all-pdf\n\t@echo \"pdflatex finished; the PDF files are in $(BUILDDIR)/latex.\"\n\ntext:\n\t$(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text\n\t@echo\n\t@echo \"Build finished. The text files are in $(BUILDDIR)/text.\"\n\nman:\n\t$(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man\n\t@echo\n\t@echo \"Build finished. The manual pages are in $(BUILDDIR)/man.\"\n\ntexinfo:\n\t$(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo\n\t@echo\n\t@echo \"Build finished. The Texinfo files are in $(BUILDDIR)/texinfo.\"\n\t@echo \"Run \\`make' in that directory to run these through makeinfo\" \\\n\t      \"(use \\`make info' here to do that automatically).\"\n\ninfo:\n\t$(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo\n\t@echo \"Running Texinfo files through makeinfo...\"\n\tmake -C $(BUILDDIR)/texinfo info\n\t@echo \"makeinfo finished; the Info files are in $(BUILDDIR)/texinfo.\"\n\ngettext:\n\t$(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale\n\t@echo\n\t@echo \"Build finished. The message catalogs are in $(BUILDDIR)/locale.\"\n\nchanges:\n\t$(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes\n\t@echo\n\t@echo \"The overview file is in $(BUILDDIR)/changes.\"\n\nlinkcheck:\n\t$(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck\n\t@echo\n\t@echo \"Link check complete; look for any errors in the above output \" \\\n\t      \"or in $(BUILDDIR)/linkcheck/output.txt.\"\n\ndoctest:\n\t$(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest\n\t@echo \"Testing of doctests in the sources finished, look at the \" \\\n\t      \"results in $(BUILDDIR)/doctest/output.txt.\"\n"
    },
    {
      "path": "datadriventests_ddt/docs/api.rst",
      "content": "API\n===\n\n.. automodule:: ddt\n    :members:\n\n.. automodule:: named_data\n    :members:"
    },
    {
      "path": "datadriventests_ddt/docs/conf.py",
      "content": "# -*- coding: utf-8 -*-\n#\n# DDT documentation build configuration file, created by\n# sphinx-quickstart on Tue Feb 21 23:00:01 2012.\n#\n# This file is execfile()d with the current directory set to its containing dir.\n#\n# Note that not all possible configuration values are present in this\n# autogenerated file.\n#\n# All configuration values have a default; values that are commented out\n# serve to show the default.\n\nimport sys, os\n\n# Specific for readthedocs.org\non_rtd = os.environ.get('READTHEDOCS', None) == 'True'\n\n# If extensions (or modules to document with autodoc) are in another directory,\n# add these directories to sys.path here. If the directory is relative to the\n# documentation root, use os.path.abspath to make it absolute, like shown here.\n#sys.path.insert(0, os.path.abspath('.'))\ndocs_root = os.path.dirname(__file__)\nsys.path.insert(0, os.path.split(docs_root)[0])\n\n# -- General configuration -----------------------------------------------------\n\n# If your documentation needs a minimal Sphinx version, state it here.\n#needs_sphinx = '1.0'\n\n# Add any Sphinx extension module names here, as strings. They can be extensions\n# coming with Sphinx (named 'sphinx.ext.*') or your custom ones.\nextensions = ['sphinx.ext.autodoc']\nif not on_rtd:\n    extensions.append('sphinxcontrib.programoutput')\n\n# Add any paths that contain templates here, relative to this directory.\ntemplates_path = ['_templates']\n\n# The suffix of source filenames.\nsource_suffix = '.rst'\n\n# The encoding of source files.\n#source_encoding = 'utf-8-sig'\n\n# The master toctree document.\nmaster_doc = 'index'\n\n# General information about the project.\nproject = u'DDT'\n# pylint: disable-msg=W0622\n# - copyright is a builtin\ncopyright = u'2012, Carles Barrobés'\n\n# The version info for the project you're documenting, acts as replacement for\n# |version| and |release|, also used in various other places throughout the\n# built documents.\n\nfrom ddt import __version__\n# The short X.Y version.\nversion = __version__\n# The full version, including alpha/beta/rc tags.\nrelease = __version__\n\n# The language for content autogenerated by Sphinx. Refer to documentation\n# for a list of supported languages.\n#language = None\n\n# There are two options for replacing |today|: either, you set today to some\n# non-false value, then it is used:\n#today = ''\n# Else, today_fmt is used as the format for a strftime call.\n#today_fmt = '%B %d, %Y'\n\n# List of patterns, relative to source directory, that match files and\n# directories to ignore when looking for source files.\nexclude_patterns = ['_build']\n\n# The reST default role (used for this markup: `text`) to use for all documents.\n#default_role = None\n\n# If true, '()' will be appended to :func: etc. cross-reference text.\n#add_function_parentheses = True\n\n# If true, the current module name will be prepended to all description\n# unit titles (such as .. function::).\n#add_module_names = True\n\n# If true, sectionauthor and moduleauthor directives will be shown in the\n# output. They are ignored by default.\n#show_authors = False\n\n# The name of the Pygments (syntax highlighting) style to use.\npygments_style = 'sphinx'\n\n# A list of ignored prefixes for module index sorting.\n#modindex_common_prefix = []\n\n\n# -- Options for HTML output ---------------------------------------------------\n\n# The theme to use for HTML and HTML Help pages.  See the documentation for\n# a list of builtin themes.\nif on_rtd:\n    html_theme = 'default'\nelse:\n    html_theme = 'sphinxdoc'\n\n# Theme options are theme-specific and customize the look and feel of a theme\n# further.  For a list of options available for each theme, see the\n# documentation.\n#html_theme_options = {}\n\n# Add any paths that contain custom themes here, relative to this directory.\n#html_theme_path = []\n\n# The name for this set of Sphinx documents.  If None, it defaults to\n# \"<project> v<release> documentation\".\n#html_title = None\n\n# A shorter title for the navigation bar.  Default is the same as html_title.\n#html_short_title = None\n\n# The name of an image file (relative to this directory) to place at the top\n# of the sidebar.\n#html_logo = None\n\n# The name of an image file (within the static path) to use as favicon of the\n# docs.  This file should be a Windows icon file (.ico) being 16x16 or 32x32\n# pixels large.\n#html_favicon = None\n\n# Add any paths that contain custom static files (such as style sheets) here,\n# relative to this directory. They are copied after the builtin static files,\n# so a file named \"default.css\" will overwrite the builtin \"default.css\".\nhtml_static_path = ['_static']\n\n# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,\n# using the given strftime format.\n#html_last_updated_fmt = '%b %d, %Y'\n\n# If true, SmartyPants will be used to convert quotes and dashes to\n# typographically correct entities.\n#html_use_smartypants = True\n\n# Custom sidebar templates, maps document names to template names.\n#html_sidebars = {}\n\n# Additional templates that should be rendered to pages, maps page names to\n# template names.\n#html_additional_pages = {}\n\n# If false, no module index is generated.\n#html_domain_indices = True\n\n# If false, no index is generated.\n#html_use_index = True\n\n# If true, the index is split into individual pages for each letter.\n#html_split_index = False\n\n# If true, links to the reST sources are added to the pages.\n#html_show_sourcelink = True\n\n# If true, \"Created using Sphinx\" is shown in the HTML footer. Default is True.\n#html_show_sphinx = True\n\n# If true, \"(C) Copyright ...\" is shown in the HTML footer. Default is True.\n#html_show_copyright = True\n\n# If true, an OpenSearch description file will be output, and all pages will\n# contain a <link> tag referring to it.  The value of this option must be the\n# base URL from which the finished HTML is served.\n#html_use_opensearch = ''\n\n# This is the file name suffix for HTML files (e.g. \".xhtml\").\n#html_file_suffix = None\n\n# Output file base name for HTML help builder.\nhtmlhelp_basename = 'DDTdoc'\n\n\n# -- Options for LaTeX output --------------------------------------------------\n\nlatex_elements = {\n# The paper size ('letterpaper' or 'a4paper').\n#'papersize': 'letterpaper',\n\n# The font size ('10pt', '11pt' or '12pt').\n#'pointsize': '10pt',\n\n# Additional stuff for the LaTeX preamble.\n#'preamble': '',\n}\n\n# Grouping the document tree into LaTeX files. List of tuples\n# (source start file, target name, title, author, documentclass [howto/manual]).\nlatex_documents = [\n  ('index', 'DDT.tex', u'DDT Documentation',\n   u'Carles Barrobés', 'manual'),\n]\n\n# The name of an image file (relative to this directory) to place at the top of\n# the title page.\n#latex_logo = None\n\n# For \"manual\" documents, if this is true, then toplevel headings are parts,\n# not chapters.\n#latex_use_parts = False\n\n# If true, show page references after internal links.\n#latex_show_pagerefs = False\n\n# If true, show URL addresses after external links.\n#latex_show_urls = False\n\n# Documents to append as an appendix to all manuals.\n#latex_appendices = []\n\n# If false, no module index is generated.\n#latex_domain_indices = True\n\n\n# -- Options for manual page output --------------------------------------------\n\n# One entry per manual page. List of tuples\n# (source start file, name, description, authors, manual section).\nman_pages = [\n    ('index', 'ddt', u'DDT Documentation',\n     [u'Carles Barrobés'], 1)\n]\n\n# If true, show URL addresses after external links.\n#man_show_urls = False\n\n\n# -- Options for Texinfo output ------------------------------------------------\n\n# Grouping the document tree into Texinfo files. List of tuples\n# (source start file, target name, title, author,\n#  dir menu entry, description, category)\ntexinfo_documents = [\n  ('index', 'DDT', u'DDT Documentation',\n   u'Carles Barrobés', 'DDT', 'One line description of project.',\n   'Miscellaneous'),\n]\n\n# Documents to append as an appendix to all manuals.\n#texinfo_appendices = []\n\n# If false, no module index is generated.\n#texinfo_domain_indices = True\n\n# How to display URL addresses: 'footnote', 'no', or 'inline'.\n#texinfo_show_urls = 'footnote'\n"
    },
    {
      "path": "datadriventests_ddt/docs/example.rst",
      "content": "Example usage\n=============\n\nDDT consists of a class decorator ``ddt`` (for your ``TestCase`` subclass)\nand two method decorators (for your tests that want to be multiplied):\n\n* ``data``: contains as many arguments as values you want to feed to the test.\n* ``file_data``: will load test data from a JSON or YAML file.\n\n.. note::\n\n   Only files ending with \".yml\" and \".yaml\" are loaded as YAML files. All\n   other files are loaded as JSON files.\n\nNormally each value within ``data`` will be passed as a single argument to\nyour test method. If these values are e.g. tuples, you will have to unpack them\ninside your test. Alternatively, you can use an additional decorator,\n``unpack``, that will automatically unpack tuples and lists into multiple\narguments, and dictionaries into multiple keyword arguments. See examples\nbelow.\n\nThis allows you to write your tests as:\n\n.. literalinclude:: ../test/test_example.py\n   :language: python\n\nWhere ``test_data_dict_dict.json``:\n\n.. literalinclude:: ../test/data/test_data_dict_dict.json\n   :language: javascript\n\nand ``test_data_dict_dict.yaml``:\n\n.. literalinclude:: ../test/data/test_data_dict_dict.yaml\n   :language: yaml\n\nand ``test_data_dict.json``:\n\n.. literalinclude:: ../test/data/test_data_dict.json\n   :language: javascript\n\nand ``test_data_dict.yaml``:\n\n.. literalinclude:: ../test/data/test_data_dict.yaml\n   :language: yaml\n\nand ``test_data_list.json``:\n\n.. literalinclude:: ../test/data/test_data_list.json\n   :language: javascript\n\nand ``test_data_list.yaml``:\n\n.. literalinclude:: ../test/data/test_data_list.yaml\n   :language: yaml\n\nAnd then run them with your favourite test runner, e.g. if you use pytest::\n\n    $ pytest test/test_example.py\n\n..\n   program-output:: pytest ../test/test_example.py\n\nThe number of test cases actually run and reported separately has been\nmultiplied.\n\n\nDDT will try to give the new test cases meaningful names by converting the\ndata values to valid python identifiers.\n\n\n.. note::\n\n   Python 2.7.3 introduced *hash randomization* which is by default\n   enabled on Python 3.3 and later. DDT's default mechanism to\n   generate meaningful test names will **not** use the test data value\n   as part of the name for complex types if hash randomization is\n   enabled.\n\n   You can disable hash randomization by setting the\n   ``PYTHONHASHSEED`` environment variable to a fixed value before\n   running tests (``export PYTHONHASHSEED=1`` for example).\n"
    },
    {
      "path": "datadriventests_ddt/docs/faq.rst",
      "content": "Known Issues and FAQ\n====================\n\nDocstring Handling\n------------------\n\nIf one of the passed data objects has a docstring, the resulting testcase borrows it.\n\n.. code-block:: python\n\n    d1 = Dataobj()\n    d1.__doc__ = \"\"\"This is a new docstring\"\"\"\n\n    d2 = Dataobj()\n\n    @data(d1, d2)\n    def test_something(self, value):\n        \"\"\"This is an old docstring\"\"\"\n        return value\n\n\nThe first of the resulting test cases will have ``\"\"\"This is a new docstring\"\"\"`` as its docstring and the second will\nkeep its old one (``\"\"\"This is an old docstring\"\"\"``).\n"
    },
    {
      "path": "datadriventests_ddt/docs/index.rst",
      "content": "Welcome to DDT's documentation!\n===============================\n\nDDT (Data-Driven Tests) allows you to multiply one test case\nby running it with different test data, and make it appear as\nmultiple test cases.\n\nYou can find (and fork) the project on Github_.\n\nDDT should work on Python2 and Python3, but we only officially test it for\nversions 2.7 and 3.5-3.8.\n\nContents:\n\n.. toctree::\n   :maxdepth: 2\n\n   example\n   faq\n   api\n\nIndices and tables\n==================\n\n* :ref:`genindex`\n* :ref:`modindex`\n* :ref:`search`\n\n\n.. _Github: https://github.com/datadriventests/ddt\n"
    },
    {
      "path": "datadriventests_ddt/requirements/build.txt",
      "content": "-r test.txt\nSphinx\nsphinxcontrib-programoutput\nenum34; python_version < '3'\n"
    },
    {
      "path": "datadriventests_ddt/requirements/release.txt",
      "content": "wheel\nsetuptools\ntwine\npytest\nenum34; python_version < '3'\n"
    },
    {
      "path": "datadriventests_ddt/requirements/test.txt",
      "content": "aiounittest\ncodecov\ncoverage\nflake8\npytest\npytest-cov\nsix>=1.4.0\nPyYAML\nmock; python_version < '3.3'\n"
    },
    {
      "path": "datadriventests_ddt/test/__init__.py",
      "content": ""
    },
    {
      "path": "datadriventests_ddt/test/mycode.py",
      "content": "\"\"\"\nSome simple functions that we will use in our tests.\n\"\"\"\n\n\ndef larger_than_two(value):\n    return value > 2\n\n\ndef has_three_elements(value):\n    return len(value) == 3\n\n\ndef is_a_greeting(value):\n    return value in ['Hello', 'Goodbye']\n"
    },
    {
      "path": "datadriventests_ddt/test/test_async.py",
      "content": "import aiounittest\n\nfrom ddt import ddt, data\nfrom test.mycode import larger_than_two\n\n\n@ddt\nclass TestAsync(aiounittest.AsyncTestCase):\n    @data(3, 4, 12, 23)\n    async def test_larger_than_two(self, value):\n        self.assertTrue(larger_than_two(value))\n"
    },
    {
      "path": "datadriventests_ddt/test/test_example.py",
      "content": "import itertools\nimport unittest\n\nfrom ddt import ddt, data, file_data, idata, unpack\nfrom test.mycode import larger_than_two, has_three_elements, is_a_greeting\n\ntry:\n    import yaml\nexcept ImportError:  # pragma: no cover\n    have_yaml_support = False\nelse:\n    have_yaml_support = True\n\n# A good-looking decorator\nneeds_yaml = unittest.skipUnless(\n    have_yaml_support, \"Need YAML to run this test\"\n)\n\n\nclass Mylist(list):\n    pass\n\n\nclass MyClass:\n    def __init__(self, **kwargs):\n        for field, value in kwargs.items():\n            setattr(self, field, value)\n\n    def __eq__(self, other):\n        return isinstance(other, dict) and vars(self) == other or \\\n               isinstance(other, MyClass) and vars(self) == vars(other)\n\n    def __str__(self):\n        return \"TestObject %s\" % vars(self)\n\n\ndef annotated(a, b):\n    r = Mylist([a, b])\n    setattr(r, \"__name__\", \"test_%d_greater_than_%d\" % (a, b))\n    return r\n\n\ndef annotated2(listIn, name, docstring):\n    r = Mylist(listIn)\n    setattr(r, \"__name__\", name)\n    setattr(r, \"__doc__\", docstring)\n    return r\n\n\n@ddt\nclass FooTestCase(unittest.TestCase):\n    def test_undecorated(self):\n        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n\n    @data(3, 4, 12, 23)\n    def test_larger_than_two(self, value):\n        self.assertTrue(larger_than_two(value))\n\n    @data(1, -3, 2, 0)\n    def test_not_larger_than_two(self, value):\n        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n\n    @data(annotated(2, 1), annotated(10, 5))\n    def test_greater(self, value):\n        a, b = value\n        self.assertGreater(a, b)\n\n    @idata(itertools.product([0, 1, 2], [3, 4, 5]))\n    def test_iterable_argument(self, value):\n        first_value, second_value = value\n        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n        self.assertGreaterEqual(second_value, 3)\n\n    @data(annotated2([2, 1], 'Test_case_1', \"\"\"Test docstring 1\"\"\"),\n          annotated2([10, 5], 'Test_case_2', \"\"\"Test docstring 2\"\"\"))\n    def test_greater_with_name_docstring(self, value):\n        a, b = value\n        self.assertGreater(a, b)\n        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n        self.assertIsNotNone(getattr(value, \"__doc__\"))\n\n    @file_data('data/test_data_dict_dict.json')\n    def test_file_data_json_dict_dict(self, start, end, value):\n        self.assertLess(start, end)\n        self.assertLess(value, end)\n        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n\n    @file_data('data/test_data_dict.json')\n    def test_file_data_json_dict(self, value):\n        self.assertTrue(has_three_elements(value))\n\n    @file_data('data/test_data_list.json')\n    def test_file_data_json_list(self, value):\n        self.assertTrue(is_a_greeting(value))\n\n    @needs_yaml\n    @file_data('data/test_data_dict_dict.yaml')\n    def test_file_data_yaml_dict_dict(self, start, end, value):\n        self.assertLess(start, end)\n        self.assertLess(value, end)\n        self.assertGreater(value, start)\n\n    @needs_yaml\n    @file_data('data/test_data_dict.yaml')\n    def test_file_data_yaml_dict(self, value):\n        self.assertTrue(has_three_elements(value))\n\n    @needs_yaml\n    @file_data('data/test_data_list.yaml')\n    def test_file_data_yaml_list(self, value):\n        self.assertTrue(is_a_greeting(value))\n\n    @data((3, 2), (4, 3), (5, 3))\n    @unpack\n    def test_tuples_extracted_into_arguments(self, first_value, second_value):\n        self.assertTrue(first_value > second_value)\n\n    @data([3, 2], [4, 3], [5, 3])\n    @unpack\n    def test_list_extracted_into_arguments(self, first_value, second_value):\n        self.assertTrue(first_value > second_value)\n\n    @unpack\n    @data({'first': 1, 'second': 3, 'third': 2},\n          {'first': 4, 'second': 6, 'third': 5})\n    def test_dicts_extracted_into_kwargs(self, first, second, third):\n        self.assertTrue(first < third < second)\n\n    @data(u'ascii', u'non-ascii-\\N{SNOWMAN}')\n    def test_unicode(self, value):\n        self.assertIn(value, (u'ascii', u'non-ascii-\\N{SNOWMAN}'))\n\n    @data(3, 4, 12, 23)\n    def test_larger_than_two_with_doc(self, value):\n        \"\"\"Larger than two with value {0}\"\"\"\n        self.assertTrue(larger_than_two(value))\n\n    @data(3, 4, 12, 23)\n    def test_doc_missing_args(self, value):\n        \"\"\"Missing args with value {0} and {1}\"\"\"\n        self.assertTrue(larger_than_two(value))\n\n    @data(3, 4, 12, 23)\n    def test_doc_missing_kargs(self, value):\n        \"\"\"Missing kargs with value {value} {value2}\"\"\"\n        self.assertTrue(larger_than_two(value))\n\n    @data([3, 2], [4, 3], [5, 3])\n    @unpack\n    def test_list_extracted_with_doc(self, first_value, second_value):\n        \"\"\"Extract into args with first value {} and second value {}\"\"\"\n        self.assertTrue(first_value > second_value)\n\n\nif have_yaml_support:\n    # This test will only succeed if the execution context is from the ddt\n    # directory. pyyaml cannot locate test.test_example.MyClass otherwise!\n\n    @ddt\n    class YamlOnlyTestCase(unittest.TestCase):\n        @file_data('data/test_custom_yaml_loader.yaml', yaml.UnsafeLoader)\n        def test_custom_yaml_loader(self, instance, expected):\n            \"\"\"Test with yaml tags to create specific classes to compare\"\"\"\n            self.assertEqual(expected, instance)\n"
    },
    {
      "path": "datadriventests_ddt/test/test_functional.py",
      "content": "import os\nimport json\nfrom sys import modules\nimport pytest\nimport six\n\ntry:\n    from unittest import mock\nexcept ImportError:\n    import mock\n\nfrom ddt import ddt, data, file_data, idata, TestNameFormat\n\nfrom test.mycode import has_three_elements\n\n\nclass CustomClass:\n    pass\n\n\n@ddt\nclass Dummy(object):\n    \"\"\"\n    Dummy class to test the data decorator on\n    \"\"\"\n\n    @data(1, 2, 3, 4)\n    def test_something(self, value):\n        return value\n\n\n@ddt(testNameFormat=TestNameFormat.DEFAULT)\nclass DummyTestNameFormatDefault(object):\n    \"\"\"\n    Dummy class to test the ddt decorator that generates test names using the\n    default format (index and values).\n    \"\"\"\n\n    @data(\"a\", \"b\", \"c\", \"d\")\n    def test_something(self, value):\n        return value\n\n\n@ddt(testNameFormat=TestNameFormat.INDEX_ONLY)\nclass DummyTestNameFormatIndexOnly(object):\n    \"\"\"\n    Dummy class to test the ddt decorator that generates test names using only\n    the index.\n    \"\"\"\n\n    @data(\"a\", \"b\", \"c\", \"d\")\n    def test_something(self, value):\n        return value\n\n\n@ddt\nclass DummyInvalidIdentifier():\n    \"\"\"\n    Dummy class to test the data decorator receiving values invalid characters\n    identifiers\n    \"\"\"\n\n    @data('32v2 g #Gmw845h$W b53wi.')\n    def test_data_with_invalid_identifier(self, value):\n        return value\n\n\n@ddt\nclass FileDataDummy(object):\n    \"\"\"\n    Dummy class to test the file_data decorator on\n    \"\"\"\n\n    @file_data(\"data/test_data_dict.json\")\n    def test_something_again(self, value):\n        return value\n\n\n@ddt\nclass JSONFileDataMissingDummy(object):\n    \"\"\"\n    Dummy class to test the file_data decorator on when\n    JSON file is missing\n    \"\"\"\n\n    @file_data(\"data/test_data_dict_missing.json\")\n    def test_something_again(self, value):\n        return value\n\n\n@ddt\nclass YAMLFileDataMissingDummy(object):\n    \"\"\"\n    Dummy class to test the file_data decorator on when\n    YAML file is missing\n    \"\"\"\n\n    @file_data(\"data/test_data_dict_missing.yaml\")\n    def test_something_again(self, value):\n        return value\n\n\ndef test_data_decorator():\n    \"\"\"\n    Test the ``data`` method decorator\n    \"\"\"\n\n    def hello():\n        pass\n\n    pre_size = len(hello.__dict__)\n    keys = set(hello.__dict__.keys())\n    data_hello = data(1, 2)(hello)\n    dh_keys = set(data_hello.__dict__.keys())\n    post_size = len(data_hello.__dict__)\n\n    assert post_size == pre_size + 2\n    extra_attrs = list(dh_keys - keys)\n    extra_attrs.sort()\n    assert len(extra_attrs) == 2\n    assert getattr(data_hello, extra_attrs[0]) == 1\n    assert getattr(data_hello, extra_attrs[1]) == (1, 2)\n\n\ndef test_file_data_decorator_with_dict():\n    \"\"\"\n    Test the ``file_data`` method decorator\n    \"\"\"\n\n    def hello():\n        pass\n\n    pre_size = len(hello.__dict__)\n    keys = set(hello.__dict__.keys())\n    data_hello = data(\"test_data_dict.json\")(hello)\n\n    dh_keys = set(data_hello.__dict__.keys())\n    post_size = len(data_hello.__dict__)\n    assert post_size == pre_size + 2\n\n    extra_attrs = list(dh_keys - keys)\n    extra_attrs.sort()\n    assert len(extra_attrs) == 2\n    assert getattr(data_hello, extra_attrs[0]) == 1\n    assert getattr(data_hello, extra_attrs[1]) == (\"test_data_dict.json\",)\n\n\ndef _is_test(x):\n    return x.startswith('test_')\n\n\ndef test_ddt():\n    \"\"\"\n    Test the ``ddt`` class decorator\n    \"\"\"\n    tests = len(list(filter(_is_test, Dummy.__dict__)))\n    assert tests == 4\n\n\ndef test_ddt_format_test_name_index_only():\n    \"\"\"\n    Test the ``ddt`` class decorator with ``INDEX_ONLY`` test name format\n    \"\"\"\n    tests = set(filter(_is_test, DummyTestNameFormatIndexOnly.__dict__))\n    assert len(tests) == 4\n\n    indexes = range(1, 5)\n    dataSets = [\"a\", \"b\", \"c\", \"d\"]  # @data from DummyTestNameFormatIndexOnly\n    for i, d in zip(indexes, dataSets):\n        assert (\"test_something_{}\".format(i) in tests)\n        assert not (\"test_something_{}_{}\".format(i, d) in tests)\n\n\ndef test_ddt_format_test_name_default():\n    \"\"\"\n    Test the ``ddt`` class decorator with ``DEFAULT`` test name format\n    \"\"\"\n    tests = set(filter(_is_test, DummyTestNameFormatDefault.__dict__))\n    assert len(tests) == 4\n\n    indexes = range(1, 5)\n    dataSets = [\"a\", \"b\", \"c\", \"d\"]  # @data from DummyTestNameFormatDefault\n    for i, d in zip(indexes, dataSets):\n        assert not (\"test_something_{}\".format(i) in tests)\n        assert (\"test_something_{}_{}\".format(i, d) in tests)\n\n\ndef test_idata_single_argument():\n    \"\"\"Test that the single-argument form of ``idata`` works.\"\"\"\n    payload = [5, 12, 13]\n\n    @ddt\n    class Dummy(object):\n        \"\"\"Dummy class to test that the ``idata(iterable)`` decorator works.\"\"\"\n        @idata(payload)\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n    assert len(tests) == len(payload)\n\n    expected_tests = [\n        \"test_something_{:1d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_idata_automatic_zero_padding():\n    \"\"\"\n    Test that the single-argument form of ``idata`` zero-pads its keys so the\n    lengths all match\n    \"\"\"\n    payload = range(15)\n\n    @ddt\n    class Dummy(object):\n        \"\"\"Dummy class to test that the ``idata(iterable)`` decorator works.\"\"\"\n        @idata(payload)\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n    assert len(tests) == len(payload)\n\n    expected_tests = [\n        \"test_something_{:02d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_idata_override_index_len():\n    \"\"\"\n    Test that overriding ``index_len`` in ``idata`` can allow additional\n    zero-padding to be added.\n    \"\"\"\n    payload = [4, 2, 1]\n\n    @ddt\n    class Dummy(object):\n        @idata(payload, index_len=2)\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n    assert len(tests) == len(payload)\n\n    expected_tests = [\n        \"test_something_{:02d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_idata_consumable_iterator():\n    \"\"\"\n    Test that using ``idata`` with a consumable iterator still generates the\n    expected tests.\n    \"\"\"\n    payload = [51, 78, 2]\n\n    def consumable_iterator():\n        # Not using `yield from` for Python 2.7.\n        for i in payload:\n            yield i\n\n    @ddt\n    class Dummy(object):\n        @idata(consumable_iterator())\n        def test_something(self, value):\n            return value\n\n    tests = list(filter(_is_test, Dummy.__dict__))\n\n    expected_tests = [\n        \"test_something_{:1d}_{}\".format(i + 1, v) for i, v in enumerate(payload)\n    ]\n    assert sorted(tests) == sorted(expected_tests)\n\n\ndef test_file_data_test_creation():\n    \"\"\"\n    Test that the ``file_data`` decorator creates two tests\n    \"\"\"\n\n    tests = len(list(filter(_is_test, FileDataDummy.__dict__)))\n    assert tests == 2\n\n\ndef test_file_data_test_names_dict():\n    \"\"\"\n    Test that ``file_data`` creates tests with the correct name\n\n    Name is the the function name plus the key in the JSON data,\n    when it is parsed as a dictionary.\n    \"\"\"\n\n    tests = set(filter(_is_test, FileDataDummy.__dict__))\n\n    tests_dir = os.path.dirname(__file__)\n    test_data_path = os.path.join(tests_dir, 'data/test_data_dict.json')\n    test_data = json.loads(open(test_data_path).read())\n    index_len = len(str(len(test_data)))\n    created_tests = set([\n        \"test_something_again_{0:0{2}}_{1}\".format(index + 1, name, index_len)\n        for index, name in enumerate(test_data.keys())\n    ])\n\n    assert tests == created_tests\n\n\ndef test_feed_data_data():\n    \"\"\"\n    Test that data is fed to the decorated tests\n    \"\"\"\n    tests = filter(_is_test, Dummy.__dict__)\n\n    values = []\n    obj = Dummy()\n    for test in tests:\n        method = getattr(obj, test)\n        values.append(method())\n\n    assert set(values) == set([1, 2, 3, 4])\n\n\ndef test_feed_data_file_data():\n    \"\"\"\n    Test that data is fed to the decorated tests from a file\n    \"\"\"\n    tests = filter(_is_test, FileDataDummy.__dict__)\n\n    values = []\n    obj = FileDataDummy()\n    for test in tests:\n        method = getattr(obj, test)\n        values.extend(method())\n\n    assert set(values) == set([10, 12, 15, 15, 12, 50])\n\n\ndef test_feed_data_file_data_missing_json():\n    \"\"\"\n    Test that a ValueError is raised when JSON file is missing\n    \"\"\"\n    tests = filter(_is_test, JSONFileDataMissingDummy.__dict__)\n\n    obj = JSONFileDataMissingDummy()\n    for test in tests:\n        method = getattr(obj, test)\n        with pytest.raises(ValueError):\n            method()\n\n\ndef test_feed_data_file_data_missing_yaml():\n    \"\"\"\n    Test that a ValueError is raised when YAML file is missing\n    \"\"\"\n    tests = filter(_is_test, YAMLFileDataMissingDummy.__dict__)\n\n    obj = YAMLFileDataMissingDummy()\n    for test in tests:\n        method = getattr(obj, test)\n        with pytest.raises(ValueError):\n            method()\n\n\ndef test_ddt_data_name_attribute():\n    \"\"\"\n    Test the ``__name__`` attribute handling of ``data`` items with ``ddt``\n    \"\"\"\n\n    def hello():\n        pass\n\n    class Myint(int):\n        pass\n\n    class Mytest(object):\n        pass\n\n    d1 = Myint(1)\n    d1.__name__ = 'data1'\n\n    d2 = Myint(2)\n\n    data_hello = data(d1, d2)(hello)\n    setattr(Mytest, 'test_hello', data_hello)\n\n    ddt_mytest = ddt(Mytest)\n    assert getattr(ddt_mytest, 'test_hello_1_data1')\n    assert getattr(ddt_mytest, 'test_hello_2_2')\n\n\ndef test_ddt_data_doc_attribute():\n    \"\"\"\n    Test the ``__doc__`` attribute handling of ``data`` items with ``ddt``\n    \"\"\"\n\n    def func_w_doc():\n        \"\"\"testFunctionDocstring {6}\n\n        :param: None\n        :return: None\n        \"\"\"\n        pass\n\n    def func_wo_doc():\n        pass\n\n    class Myint(int):\n        pass\n\n    class Mytest(object):\n        pass\n\n    d1 = Myint(1)\n    d1.__name__ = 'case1'\n    d1.__doc__ = \"\"\"docstring1\"\"\"\n\n    d2 = Myint(2)\n    d2.__name__ = 'case2'\n\n    data_hello = data(d1, d2, {'test': True})(func_w_doc)\n    data_hello2 = data(d1, d2, {'test': True})(func_wo_doc)\n\n    setattr(Mytest, 'first_test', data_hello)\n    setattr(Mytest, 'second_test', data_hello2)\n    ddt_mytest = ddt(Mytest)\n\n    assert getattr(\n        getattr(ddt_mytest, 'first_test_1_case1'), '__doc__'\n    ) == d1.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'first_test_2_case2'), '__doc__'\n    ) == func_w_doc.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'first_test_3'), '__doc__'\n    ) == func_w_doc.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'second_test_1_case1'), '__doc__'\n    ) == d1.__doc__\n    assert getattr(\n        getattr(ddt_mytest, 'second_test_2_case2'), '__doc__'\n    ) is None\n    assert getattr(getattr(ddt_mytest, 'second_test_3'), '__doc__') is None\n\n\ndef test_ddt_data_unicode():\n    \"\"\"\n    Test that unicode strings are converted to function names correctly\n    \"\"\"\n    # We test unicode support separately for python 2 and 3\n\n    if six.PY2:\n\n        @ddt\n        class Mytest(object):\n            @data(u'ascii', u'non-ascii-\\N{SNOWMAN}', {u'\\N{SNOWMAN}': 'data'})\n            def test_hello(self, val):\n                pass\n\n        assert getattr(Mytest, 'test_hello_1_ascii') is not None\n        assert getattr(Mytest, 'test_hello_2_non_ascii__u2603') is not None\n        assert getattr(Mytest, 'test_hello_3') is not None\n\n    elif six.PY3:\n\n        @ddt\n        class Mytest(object):\n            @data('ascii', 'non-ascii-\\N{SNOWMAN}', {'\\N{SNOWMAN}': 'data'})\n            def test_hello(self, val):\n                pass\n\n        assert getattr(Mytest, 'test_hello_1_ascii') is not None\n        assert getattr(Mytest, 'test_hello_2_non_ascii__') is not None\n        assert getattr(Mytest, 'test_hello_3') is not None\n\n\ndef test_ddt_data_object():\n    \"\"\"\n    Test not using value if non-trivial arguments\n    \"\"\"\n\n    @ddt\n    class Mytest(object):\n        @data(object())\n        def test_object(self, val):\n            pass\n    assert getattr(Mytest, 'test_object_1') is not None\n\n\ndef test_feed_data_with_invalid_identifier():\n    \"\"\"\n    Test that data is fed to the decorated tests\n    \"\"\"\n    tests = list(filter(_is_test, DummyInvalidIdentifier.__dict__))\n    assert len(tests) == 1\n\n    obj = DummyInvalidIdentifier()\n    method = getattr(obj, tests[0])\n    assert (\n        method.__name__ ==\n        'test_data_with_invalid_identifier_1_32v2_g__Gmw845h_W_b53wi_'\n    )\n    assert method() == '32v2 g #Gmw845h$W b53wi.'\n\n\n@mock.patch('ddt._have_yaml', False)\ndef test_load_yaml_without_yaml_support():\n    \"\"\"\n    Test that YAML files are not loaded if YAML is not installed.\n    \"\"\"\n\n    @ddt\n    class NoYAMLInstalledTest(object):\n\n        @file_data('data/test_data_dict.yaml')\n        def test_file_data_yaml_dict(self, value):\n            assert has_three_elements(value)\n\n    tests = filter(_is_test, NoYAMLInstalledTest.__dict__)\n\n    obj = NoYAMLInstalledTest()\n    for test in tests:\n        method = getattr(obj, test)\n        with pytest.raises(ValueError):\n            method()\n\n\ndef test_load_yaml_with_python_tag():\n    \"\"\"\n    Test that YAML files containing python tags throw no exception if an\n    loader allowing python tags is passed.\n    \"\"\"\n\n    from yaml import UnsafeLoader\n    from yaml.constructor import ConstructorError\n\n    def str_to_type(class_name):\n        return getattr(modules[__name__], class_name)\n\n    try:\n        @ddt\n        class YamlDefaultLoaderTest(object):\n            @file_data('data/test_functional_custom_tags.yaml')\n            def test_cls_is_instance(self, cls, expected):\n                assert isinstance(cls, str_to_type(expected))\n    except Exception as e:\n        if not isinstance(e, ConstructorError):\n            raise AssertionError()\n\n    @ddt\n    class YamlUnsafeLoaderTest(object):\n        @file_data('data/test_functional_custom_tags.yaml', UnsafeLoader)\n        def test_cls_is_instance(self, instance, expected):\n            assert isinstance(instance, str_to_type(expected))\n\n    tests = list(filter(_is_test, YamlUnsafeLoaderTest.__dict__))\n    obj = YamlUnsafeLoaderTest()\n\n    if not tests:\n        raise AssertionError('No tests have been found.')\n\n    for test in tests:\n        method = getattr(obj, test)\n        method()\n"
    },
    {
      "path": "datadriventests_ddt/test/test_named_data.py",
      "content": "import ddt\nimport unittest\n\n\n@ddt.ddt\nclass TestNamedData(unittest.TestCase):\n    class NonTrivialClass(object):\n        pass\n\n    @ddt.named_data(\n        ['Single', 0, 1]\n    )\n    def test_single_named_value(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        ['1st', 1, 2],\n        ('2nd', 3, 4)\n    )\n    def test_multiple_named_value_seqs(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        dict(name='1st', value2=1, value1=0),\n        {'name': '2nd', 'value2': 1, 'value1': 0}\n    )\n    def test_multiple_named_value_dicts(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        dict(name='1st', value2=1, value1=0),\n        ('2nd', 0, 1)\n    )\n    def test_multiple_named_value_mixed(self, value1, value2):\n        self.assertGreater(value2, value1)\n\n    @ddt.named_data(\n        ['Passes', NonTrivialClass(), True],\n        ('Fails', 1, False)\n    )\n    def test_seq_with_nontrivial_type(self, value, passes):\n        if passes:\n            self.assertIsInstance(value, self.NonTrivialClass)\n        else:\n            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n    @ddt.named_data(\n        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n        {'name': 'Fails', 'value': 1, 'passes': False}\n    )\n    def test_dict_with_nontrivial_type(self, value, passes):\n        if passes:\n            self.assertIsInstance(value, self.NonTrivialClass)\n        else:\n            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n    def test_missing_name_dict(self):\n        with self.assertRaises(KeyError):\n            @ddt.named_data(\n                {'not_a_name': 'oops', 'value': 1}\n            )\n            def _internal_test(value):\n                pass\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_custom_yaml_loader.yaml",
      "content": "bool:\n  instance: !!bool \"false\"\n  expected: false\n\nstr:\n  instance: !!str \"test\"\n  expected: test\n\nint:\n  instance: !!int \"32\"\n  expected: 32\n\nfloat:\n  instance: !!float \"3.123\"\n  expected: 3.123\n\npython_list:\n  instance: !!python/list [1,2,3,4]\n  expected:\n    - 1\n    - 2\n    - 3\n    - 4\n\npython_dict:\n  instance: !!python/dict\n    a: 1\n    b: asd\n    c: false\n  expected:\n    a: 1\n    b: asd\n    c: false\n\nmy_class:\n  instance: !!python/object:test.test_example.MyClass\n    a: 132\n    b: true\n    c:\n      - alpha\n      - beta\n    d:\n      _a: 1\n      _b: test\n  expected:\n    a: 132\n    b: true\n    c:\n      - alpha\n      - beta\n    d:\n      _a: 1\n      _b: test\n\npython_str:\n  instance: !!python/str \"test\"\n  expected: test\n\npython_int:\n  instance: !!python/int \"32\"\n  expected: 32\n\npython_float:\n  instance: !!python/float \"3.123\"\n  expected: 3.123\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict.json",
      "content": "{\n    \"unsorted_list\": [ 10, 12, 15 ],\n    \"sorted_list\": [ 15, 12, 50 ]\n}\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict.yaml",
      "content": "unsorted_list:\n  - 10\n  - 15\n  - 12\n\nsorted_list: [ 15, 12, 50 ]\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict_dict.json",
      "content": "{\n    \"positive_integer_range\": {\n        \"start\": 0,\n        \"end\": 2,\n        \"value\": 1\n    },\n    \"negative_integer_range\": {\n        \"start\": -2,\n        \"end\": 0,\n        \"value\": -1\n    },\n    \"positive_real_range\": {\n        \"start\": 0.0,\n        \"end\": 1.0,\n        \"value\": 0.5\n    },\n    \"negative_real_range\": {\n        \"start\": -1.0,\n        \"end\": 0.0,\n        \"value\": -0.5\n    }\n}\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_dict_dict.yaml",
      "content": "positive_integer_range:\n    start: 0\n    end: 2\n    value: 1\n\nnegative_integer_range:\n    start: -2\n    end: 0\n    value: -1\n\npositive_real_range:\n    start: 0.0\n    end: 1.0\n    value: 0.5\n\nnegative_real_range:\n    start: -1.0\n    end: 0.0\n    value: -0.5\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_list.json",
      "content": "[\n    \"Hello\",\n    \"Goodbye\"\n]\n\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_data_list.yaml",
      "content": "- \"Hello\"\n- \"Goodbye\"\n"
    },
    {
      "path": "datadriventests_ddt/test/data/test_functional_custom_tags.yaml",
      "content": "custom_class:\n  instance: !!python/object:test.test_functional.CustomClass {}\n  expected: CustomClass\n"
    }
  ],
  "Patch": "--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -50,7 +50,7 @@\n @ddt\n class FooTestCase(unittest.TestCase):\n     def test_undecorated(self):\n-        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n+        self.assertTrue(larger_than_two(24))\n \n     @data(3, 4, 12, 23)\n     def test_larger_than_two(self, value):\n@@ -58,7 +58,7 @@\n \n     @data(1, -3, 2, 0)\n     def test_not_larger_than_two(self, value):\n-        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n+        self.assertFalse(larger_than_two(value))\n \n     @data(annotated(2, 1), annotated(10, 5))\n     def test_greater(self, value):\n@@ -68,7 +68,7 @@\n     @idata(itertools.product([0, 1, 2], [3, 4, 5]))\n     def test_iterable_argument(self, value):\n         first_value, second_value = value\n-        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n+        self.assertLessEqual(first_value, 2)\n         self.assertGreaterEqual(second_value, 3)\n \n     @data(annotated2([2, 1], 'Test_case_1', \"\"\"Test docstring 1\"\"\"),\n@@ -76,14 +76,14 @@\n     def test_greater_with_name_docstring(self, value):\n         a, b = value\n         self.assertGreater(a, b)\n-        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n+        self.assertIsNotNone(getattr(value, \"__name__\"))\n         self.assertIsNotNone(getattr(value, \"__doc__\"))\n \n     @file_data('data/test_data_dict_dict.json')\n     def test_file_data_json_dict_dict(self, start, end, value):\n         self.assertLess(start, end)\n         self.assertLess(value, end)\n-        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n+        self.assertGreater(value, start)\n \n     @file_data('data/test_data_dict.json')\n     def test_file_data_json_dict(self, value):\n",
  "BuggyCodeLocation": [
    {
      "file": "datadriventests_ddt/test/test_example.py",
      "function": {
        "69": "test_iterable_argument"
      },
      "content_all": {
        "68": "    @idata(itertools.product([0, 1, 2], [3, 4, 5]))\n",
        "69": "    def test_iterable_argument(self, value):\n",
        "70": "        first_value, second_value = value\n",
        "71": "        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n"
      },
      "content_change": {
        "71": "        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n"
      }
    },
    {
      "file": "datadriventests_ddt/test/test_example.py",
      "function": {
        "76": "test_greater_with_name_docstring"
      },
      "content_all": {
        "76": "    def test_greater_with_name_docstring(self, value):\n",
        "77": "        a, b = value\n",
        "78": "        self.assertGreater(a, b)\n",
        "79": "        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n"
      },
      "content_change": {
        "79": "        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n"
      }
    },
    {
      "file": "datadriventests_ddt/test/test_example.py",
      "function": null,
      "content_all": {
        "50": "@ddt\n",
        "53": "        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n",
        "54": "\n",
        "58": "\n",
        "61": "        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n",
        "62": "\n",
        "72": "        self.assertGreaterEqual(second_value, 3)\n",
        "73": "\n",
        "74": "    @data(annotated2([2, 1], 'Test_case_1', \"\"\"Test docstring 1\"\"\"),\n",
        "80": "        self.assertIsNotNone(getattr(value, \"__doc__\"))\n",
        "81": "\n",
        "86": "        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n",
        "87": "\n"
      },
      "content_change": {
        "53": "        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n",
        "61": "        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n",
        "86": "        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n"
      }
    }
  ],
  "Source": "Human",
  "Command": [
    "python -m unittest discover -s test/"
  ],
  "Token": 1158,
  "FilteredCode": [
    {
      "path": "datadriventests_ddt/ddt.py",
      "content": "1 # -*- coding: utf-8 -*-\n2 # This file is a part of DDT (https://github.com/datadriventests/ddt)\n3 # Copyright 2012-2015 Carles Barrobés and DDT contributors\n4 # For the exact contribution history, see the git revision log.\n5 # DDT is licensed under the MIT License, included in\n6 # https://github.com/datadriventests/ddt/blob/master/LICENSE.md\n7 \n8 import codecs\n9 import inspect\n10 import json\n11 import os\n12 import re\n13 from enum import Enum, unique\n14 from functools import wraps\n15 \n16 try:\n17     import yaml\n18 except ImportError:  # pragma: no cover\n19     _have_yaml = False\n20 else:\n21     _have_yaml = True\n22 \n23 from collections.abc import Sequence\n24 \n25 \n26 __version__ = '1.7.2'\n27 \n28 # These attributes will not conflict with any real python attribute\n29 # They are added to the decorated test method and processed later\n30 # by the `ddt` class decorator.\n31 \n32 DATA_ATTR = '%values'              # store the data the test must run with\n33 FILE_ATTR = '%file_path'           # store the path to JSON file\n34 YAML_LOADER_ATTR = '%yaml_loader'  # store custom yaml loader for serialization\n35 UNPACK_ATTR = '%unpack'            # remember that we have to unpack values\n36 INDEX_LEN = '%index_len'           # store the index length of the data\n37 \n38 \n39 # These are helper classes for @named_data that allow ddt tests to have meaningful names.\n40 class _NamedDataList(list):\n41     def __init__(self, name, *args):\n42         super(_NamedDataList, self).__init__(args)\n43         self.name = name\n44 \n45     def __str__(self):\n46         return str(self.name)\n47 \n48 \n49 class _NamedDataDict(dict)(...truncated)"
    },
    {
      "path": "datadriventests_ddt/test/test_example.py",
      "content": "1 import itertools\n2 import unittest\n3 \n4 from ddt import ddt, data, file_data, idata, unpack\n5 from test.mycode import larger_than_two, has_three_elements, is_a_greeting\n6 \n7 try:\n8     import yaml\n9 except ImportError:  # pragma: no cover\n10     have_yaml_support = False\n11 else:\n12     have_yaml_support = True\n13 \n14 # A good-looking decorator\n15 needs_yaml = unittest.skipUnless(\n16     have_yaml_support, \"Need YAML to run this test\"\n17 )\n18 \n19 \n20 class Mylist(list):\n21     pass\n22 \n23 \n24 class MyClass:\n25     def __init__(self, **kwargs):\n26         for field, value in kwargs.items():\n27             setattr(self, field, value)\n28 \n29     def __eq__(self, other):\n30         return isinstance(other, dict) and vars(self) == other or \\\n31                isinstance(other, MyClass) and vars(self) == vars(other)\n32 \n33     def __str__(self):\n34         return \"TestObject %s\" % vars(self)\n35 \n36 \n37 def annotated(a, b):\n38     r = Mylist([a, b])\n39     setattr(r, \"__name__\", \"test_%d_greater_than_%d\" % (a, b))\n40     return r\n41 \n42 \n43 def annotated2(listIn, name, docstring):\n44     r = Mylist(listIn)\n45     setattr(r, \"__name__\", name)\n46     setattr(r, \"__doc__\", docs(...truncated)"
    },
    {
      "path": "datadriventests_ddt/test/test_functional.py",
      "content": "1 import os\n2 import json\n3 from sys import modules\n4 import pytest\n5 import six\n6 \n7 try:\n8     from unittest import mock\n9 except ImportError:\n10     import mock\n11 \n12 from ddt import ddt, data, file_data, idata, TestNameFormat\n13 \n14 from test.mycode import has_three_elements\n15 \n16 \n17 class CustomClass:\n18     pass\n19 \n20 \n21 @ddt\n22 class Dummy(object):\n23     \"\"\"\n24     Dummy class to test the data decorator on\n25     \"\"\"\n26 \n27     @data(1, 2, 3, 4)\n28     def test_something(self, value):\n29         return value\n30 \n31 \n32 @ddt(testNameFormat=TestNameFormat.DEFAULT)\n33 class DummyTestNameFormatDefault(object):\n34     \"\"\"\n35     Dummy class to test the ddt decorator that generates test names using the\n36     default format (index and values).\n37     \"\"\"\n38 \n39     @data(\"a\", \"b\", \"c\", \"d\")\n40     def(...truncated)"
    },
    {
      "path": "datadriventests_ddt/docs/conf.py",
      "content": "1 # -*- coding: utf-8 -*-\n2 #\n3 # DDT documentation build configuration file, created by\n4 # sphinx-quickstart on Tue Feb 21 23:00:01 2012.\n5 #\n6 # This file is execfile()d with the current directory set to its containing dir.\n7 #\n8 # Note that not all possible configuration values are present in this\n9 # autogenerated file.\n10 #\n11 # All configuration values have a default; values that are commented out\n12 # serve to show the default.\n13 \n14 import sys, os\n15 \n16 # Specific for readthedocs.org\n17 on(...truncated)"
    }
  ],
  "TokenAll": 19026,
  "FilteredLevel": 1500,
  "Results": {
    "model": "GPT-4o",
    "Difficulty": "Simple",
    "issue_origin": {
      "title": "Import Error Handling Inconsistent",
      "description": "In the file 'datadriventests_ddt/test/test_functional.py', the import error handling for 'mock' is done within a try-except block (lines 7-10), but the error instance is not specified for 'ImportError' on line 9. This should be changed to 'except ImportError as e:' to follow best practices for exception handling.",
      "explanation": "### Summary of the Issue\n\nThe issue specifies that in the file `datadriventests_ddt/test/test_functional.py`, the error handling for importing the `mock` module does not follow best practices. Specifically, the `try-except` block on lines 7-10 uses a generic `except` block when it should be catching an `ImportError` directly with an alias. The current code:\n\n```python\n7 try:\n8     from unittest import mock\n9 except ImportError:\n10     import mock\n```\n\nshould be updated to:\n\n```python\n9 except ImportError as e:\n```\n\n### Original Code Analysis\n\nIn `test_functional.py`, the code attempts to import `mock` from `unittest`. If that fails due to the `ImportError`, it falls back to importing `mock` directly. This try-except block ensures compatibility between different versions of Python, where the location of the `mock` module can vary.\n\nHere is the relevant code snippet:\n```python\n7 try:\n8     from unittest import mock\n9 except ImportError:\n10     import mock\n```\n\nThe problem with this structure is that it does not explicitly catch the `ImportError` exception in a way that follows best practices. The best practice is to specify the exception type and capture it as an alias for potentially better logging and debugging.\n\n### Suggested Code Change\n\nThe change proposed would be:\n```python\n7 try:\n8     from unittest import mock\n9 except ImportError as e:\n10     import mock\n```\n\n### Explanation of How the Commit Solves the Issue\n\n1. **Improves Readability**:\n   - Using `ImportError as e` explicitly shows which exception type is being caught. This enhances code readability and maintainability by making it clear that only import errors are being handled.\n\n2. **Catch Specific Exception**:\n   - By catching `ImportError` specifically, it avoids catching other possible exceptions accidentally, which may have led to silent failures or harder-to-debug scenarios.\n\n3. **Potential for Enhanced Debugging**:\n   - Even though the alias `e` is not currently utilized, it provides a placeholder for future debugging enhancements. For instance, logging the error message can help identify issues more efficiently:\n     ```python\n     except ImportError as e:\n         print(f\"Import error: {e}\")\n         import mock\n     ```\n     \n4. **Aligns with Best Practices**:\n   - The Python community recommends catching exceptions using the specific exception type because it maintains the integrity of the code, ensuring that only the expected exceptions are handled.\n\n### Final Analysis\n\nThe commit will change the exception catching block to:\n```python\n9 except ImportError as e:\n```\n\nThis simple yet significant modification ensures the code adheres to best practices by:\n\n- Explicitly capturing the type of exception.\n- Preparing the groundwork for better debugging capabilities.\n- Enhancing code readability and future maintainability.\n\nBy making this change, the developers can trust that the code block will handle the specific `ImportError` correctly, making the codebase more robust and clean."
    },
    "issue_message": {
      "title": "Assertion Errors in test_example.py",
      "description": "Multiple test cases in test_example.py are failing due to incorrect assertions. For instance, line 86's test in 'test_file_data_json_dict_dict' asserts 'self.assertGreater(start, value)', but the values being tested do not fulfill this condition. Similarly, in line 79's 'test_greater_with_name_docstring', the test asserts 'self.assertIsNone(getattr(value, \"__name__\"))', but the value has a non-None '__name__' attribute. These assertion logic errors need to be reviewed and corrected.",
      "explanation": "### Summary of the Issue\n\nThe central problem revolves around multiple test cases failing in the `test_example.py` file due to assertion errors. The reported issues detail that the actual values tested do not meet the expected conditions outlined in the assertions. Here are the two main problematic assertions:\n1. `self.assertGreater(start, value)` where `start` is not greater than `value`.\n2. `self.assertIsNone(getattr(value, \\\"__name__\\\"))` where the value's `__name__` attribute is not `None`.\n\n### Detailed Analysis of the Code\n\nHere are the key sections of `test_example.py` relevant to the issue:\n\n```python\n# From test/test_example.py\n61: self.assertTrue(larger_than_two(value))\n\n71: self.assertGreaterEqual(first_value, 2)\n\n79: self.assertIsNone(getattr(value, \"__name__\"))\n\n86: self.assertGreater(start, value)\n```\n\n1. **Function and Class Definitions**:\n    - `larger_than_two`, `has_three_elements`, `is_a_greeting` are functions imported from `test.mycode`.\n    - `Mylist` and `MyClass` are custom classes defined in the file.\n\n2. **Tests**:\n    - `test_file_data_json_dict_dict`: This uses `self.assertGreater(start, value)` which fails if `start` is not greater than `value`.\n    - `test_greater_with_name_docstring`: This uses `self.assertIsNone(getattr(value, \"__name__\"))` which fails if `value` has a `__name__`.\n    - `test_iterable_argument`: Uses `self.assertGreaterEqual(first_value, 2)` which fails when `first_value` is less than `2`.\n    - `test_not_larger_than_two`: Uses `self.assertTrue(larger_than_two(value))` which fails if `larger_than_two(value)` is `False`.\n\n### Analysis of the Commit\n\nI'll make hypothetical changes based on common fixes for such errors since details of the commit are not provided.\n\n**Commit Changes:**\n1. Correction of assertion conditions.\n2. Fixing the logic of `larger_than_two` and ensuring `__name__` attributes when necessary.\n\n#### Example of Possible Corrections\n\n```diff\n# Line 61\n-self.assertTrue(larger_than_two(value))\n+self.assertFalse(larger_than_two(value))\n\n# Line 71\n-self.assertGreaterEqual(first_value, 2)\n+self.assertGreaterEqual(first_value, 0)\n\n# Line 79\n-self.assertIsNone(getattr(value, \"__name__\"))\n+self.assertIsNotNone(getattr(value, \"__name__\"))\n\n# Line 86\n-self.assertGreater(start, value)\n+self.assertLess(start, value)\n```\n\n### Explanation of How the Commit Solves the Issues\n\n1. **Correction in `test_not_larger_than_two` Assertions**:\n    - Initially `self.assertTrue(larger_than_two(value))` on line 61 asserted that the return from `larger_than_two` should be `True`. The fix changes it to `self.assertFalse(larger_than_two(value))` if logically the function means to assert `value` is not greater than 2.\n\n2. **Correction in `test_iterable_argument` Assertions**:\n    - Initially `self.assertGreaterEqual(first_value, 2)` on line 71 incorrectly assumes `first_value` will always be at least `2`. The fix reduces this threshold to assert that `first_value` should be at least `0` (example value).\n\n3. **Correction in `test_greater_with_name_docstring` Assertions**:\n    - The initial assertion `self.assertIsNone(getattr(value, \\\"__name__\\\"))` wrongly assumes that `value` should not have a `__name__` attribute. Fixed by changing to `self.assertIsNotNone(getattr(value, \\\"__name__\\\"))` to match the context where `value` was correctly assigned such an attribute.\n\n4. **Correction in `test_file_data_json_dict_dict` Assertions**:\n    - The assertion `self.assertGreater(start, value)` expected `start` to always be greater than `value`, but frequently it wasn't (as shown by the error messages). Changing to `self.assertLess(start, value)` reflects a more appropriate inverse relationship.\n\n### Conclusion\n\nThe hypothetical commit would have successfully solved the issue by adjusting the assertions in the `test_example.py` file to correctly reflect the realities of the data being tested, ensuring the conditions of the assertions align with the expected behavior of the functions and values involved. The corrected assertions now logically match the data content and expected outcomes, leading to the passing of tests."
    },
    "issue_ground": {
      "title": "Incorrect Assertions in Unit Tests for Functions",
      "description": "It has come to our attention that certain unit tests within the FooTestCase class are using incorrect assertions, which can lead to inaccurate test results and potentially false negatives. Specifically, there are tests where 'assertFalse' is used when 'assertTrue' should be used and vice versa. Additionally, there are cases where 'assertGreaterEqual' and 'assertGreater' are used incorrectly.\n\nIssues Identified:\n1. The test 'test_undecorated' incorrectly uses 'assertFalse' to check 'larger_than_two(24)' instead of 'assertTrue'.\n2. The test 'test_not_larger_than_two' incorrectly uses 'assertTrue' to check values not larger than two instead of 'assertFalse'.\n3. The test 'test_iterable_argument' incorrectly uses 'assertGreaterEqual' instead of 'assertLessEqual' for the 'first_value'.\n4. The test 'test_greater_with_name_docstring' incorrectly uses 'assertIsNone' for checking '__name__' attribute instead of 'assertIsNotNone'.\n5. The test 'test_file_data_json_dict_dict' incorrectly uses 'assertGreater' to compare 'start' and 'value' instead of comparing 'value' and 'start'.\n\nImpact:\nThese incorrect assertions can cause confusion and mislead developers when interpreting test results. Ensuring that unit tests are accurate is crucial for maintaining code integrity and reliability.\n\nPotential Solution:\nReview the mentioned test cases and correct the assertions to reflect the expected behavior accurately. Performing these corrections will improve the reliability of the test results and help maintain the overall quality of the codebase.",
      "explanation": "### Summary of the Issue\n\nThe issue involves incorrect assertions within the unit tests in the `FooTestCase` class, which leads to inaccurate test results and potentially false negatives. Specifically, the incorrect usage of various assertions (`assertFalse`, `assertTrue`, `assertGreaterEqual`, `assertGreater`, and `assertIsNone`) confuses the developers, leading to difficulties in interpreting errors and maintaining code reliability.\n\n### Detailed Content of the Commit\n\nA commit was made to address these issues by correcting the identified assertions in the test cases. Here is the detailed content of the commit:\n\n1. **test_undecorated**:\n   - **Original:** `self.assertFalse(larger_than_two(24))`\n   - **Updated to:** `self.assertTrue(larger_than_two(24))`\n\n2. **test_not_larger_than_two**:\n   - **Original:** `self.assertTrue(larger_than_two(value))`\n   - **Updated to:** `self.assertFalse(larger_than_two(value))`\n   \n3. **test_iterable_argument**:\n   - **Original:** `self.assertGreaterEqual(first_value, 2)`\n   - **Updated to:** `self.assertLessEqual(first_value, 2)`\n   \n4. **test_greater_with_name_docstring**:\n   - **Original:** `self.assertIsNone(getattr(value, \"__name__\"))`\n   - **Updated to:** `self.assertIsNotNone(getattr(value, \"__name__\"))`\n   \n5. **test_file_data_json_dict_dict**:\n   - **Original:** `self.assertGreater(start, value)`\n   - **Updated to:** `self.assertGreater(value, start)`\n\n### Explanation of How the Commit Solves the Issue\n\n1. **test_undecorated**:\n   - **Issue:** The test incorrectly used `assertFalse` to check if the function `larger_than_two(24)` returns `False`, which logically should be `True`.\n   - **Solution:** The assertion was corrected to `assertTrue` since `larger_than_two(24)` should return `True` (24 is larger than 2).\n   \n2. **test_not_larger_than_two**:\n   - **Issue:** The test incorrectly used `assertTrue` to check for values that are not larger than two.\n   - **Solution:** Changed to `assertFalse` because values not larger than two should return `False` when passed into `larger_than_two`.\n   \n3. **test_iterable_argument**:\n   - **Issue:** This test used `assertGreaterEqual` to check `first_value` against 2.\n   - **Solution:** Changed to `assertLessEqual` to properly match the expected behavior where `first_value` should be less than or equal to 2.\n   \n4. **test_greater_with_name_docstring**:\n   - **Issue:** The test incorrectly used `assertIsNone` to check the `__name__` attribute, which should be present.\n   - **Solution:** Changed to `assertIsNotNone` to accurately reflect that the `__name__` attribute should indeed exist.\n   \n5. **test_file_data_json_dict_dict**:\n   - **Issue:** The test compared `start` and `value` incorrectly with `assertGreater`, which led to errors.\n   - **Solution:** Swapped to `assertGreater(value, start)` since `value` should indeed be greater than `start` according to the test logic provided.\n\nBy correcting these assertions, the commit ensures that the unit tests are now accurately testing the expected behavior of the functions. This not only clarifies the test outcomes but also enhances the code's reliability by preventing false negatives and ensuring that all future changes to the codebase are validated against accurate unit tests."
    },
    "issue_ground_truth": {
      "title": "Incorrect Assertions in Unit Tests for Functions",
      "description": "It has come to our attention that certain unit tests within the FooTestCase class are using incorrect assertions, which can lead to inaccurate test results and potentially false negatives. Specifically, there are tests where 'assertFalse' is used when 'assertTrue' should be used and vice versa. Additionally, there are cases where 'assertGreaterEqual' and 'assertGreater' are used incorrectly.\n\nIssues Identified:\n1. The test 'test_undecorated' incorrectly uses 'assertFalse' to check 'larger_than_two(24)' instead of 'assertTrue'.\n2. The test 'test_not_larger_than_two' incorrectly uses 'assertTrue' to check values not larger than two instead of 'assertFalse'.\n3. The test 'test_iterable_argument' incorrectly uses 'assertGreaterEqual' instead of 'assertLessEqual' for the 'first_value'.\n4. The test 'test_greater_with_name_docstring' incorrectly uses 'assertIsNone' for checking '__name__' attribute instead of 'assertIsNotNone'.\n5. The test 'test_file_data_json_dict_dict' incorrectly uses 'assertGreater' to compare 'start' and 'value' instead of comparing 'value' and 'start'.\n\nImpact:\nThese incorrect assertions can cause confusion and mislead developers when interpreting test results. Ensuring that unit tests are accurate is crucial for maintaining code integrity and reliability.\n\nPotential Solution:\nReview the mentioned test cases and correct the assertions to reflect the expected behavior accurately. Performing these corrections will improve the reliability of the test results and help maintain the overall quality of the codebase.",
      "explanation": "### Summary of the Issue\n\nThe issue revolves around incorrect assertions in unit tests within the `FooTestCase` class. These incorrect assertions can lead to inaccurate test results and potentially misleading developers with false negatives or positives. The specific problems identified are:\n\n1. Using `assertFalse` instead of `assertTrue` and vice versa.\n2. Misusing `assertGreaterEqual` and `assertGreater`.\n3. Incorrectly checking for `None` with `assertIsNone` instead of `assertIsNotNone`.\n\nThese issues need to be corrected to ensure that the unit tests accurately reflect the expected behavior of the functions they are testing.\n\n### Content of the Commit\n\nThe commit shows changes to the file `datadriventests_ddt/test/test_example.py`, and it addresses the misused assertions by making the following corrections:\n\n1. **`test_undecorated`**: Changes `assertFalse(larger_than_two(24))` to `assertTrue(larger_than_two(24))`.\n2. **`test_not_larger_than_two`**: Changes `assertTrue(larger_than_two(value))` to `assertFalse(larger_than_two(value))`.\n3. **`test_iterable_argument`**: Changes `assertGreaterEqual(first_value, 2)` to `assertLessEqual(first_value, 2)`.\n4. **`test_greater_with_name_docstring`**: Changes `assertIsNone(getattr(value, \"__name__\"))` to `assertIsNotNone(getattr(value, \"__name__\"))`.\n5. **`test_file_data_json_dict_dict`**: Changes `assertGreater(start, value)` to `assertGreater(value, start)`.\n\n### Explanation of the Issue\n\nThe root cause of the issue is the misuse of assertion methods which results in tests that do not accurately verify the behavior of the functions they are meant to test. Specifically:\n\n1. **Assertion Method Mismatch**: Using `assertFalse` when the condition should be `True` and using `assertTrue` when the condition should be `False`. This incorrect usage can cause a test to pass or fail incorrectly, leading to inaccurate results.\n2. **Comparison Method Misuse**: Using `assertGreaterEqual` when `assertLessEqual` is appropriate and vice versa. This can lead to logical errors in the tests, where the conditions being tested for are not accurately represented.\n3. **Mischecking for Attributes**: Using `assertIsNone` to check for the existence of an attribute where `assertIsNotNone` is appropriate. This can cause misunderstanding about the presence or absence of attributes in objects being tested.\n\n### Explanation of the Solution\n\nThe commit resolves the above issues by correcting the misuse of assertions and ensuring that the tests accurately reflect the expected conditions. Here’s how the commit addresses each issue:\n\n1. **Correction of `test_undecorated`**: The test was incorrectly checking that `larger_than_two(24)` is `False`. By changing it to `assertTrue(larger_than_two(24))`, the test now correctly checks that 24 is indeed greater than two.\n2. **Correction of `test_not_larger_than_two`**: The test was incorrectly using `assertTrue` to check values not larger than two. By changing it to `assertFalse`, it accurately asserts that the values are not greater than two.\n3. **Correction of `test_iterable_argument`**: The test was incorrectly using `assertGreaterEqual` for `first_value` which should have been `assertLessEqual`. This now correctly asserts that the first value is less than or equal to two.\n4. **Correction of `test_greater_with_name_docstring`**: The test was incorrectly checking that the `__name__` attribute is `None` with `assertIsNone`. By changing it to `assertIsNotNone`, it accurately checks that the attribute exists.\n5. **Correction of `test_file_data_json_dict_dict`**: The test incorrectly used `assertGreater` with `start` and `value` in the wrong order. By reversing the order, it now correctly asserts that `value` is greater than `start`.\n\n### Conclusion\n\nThe corrections made in the commit ensure that the unit tests now accurately test the conditions they are supposed to check. By addressing the incorrect assertions and aligning them with the expected behavior, the tests will provide reliable results, thereby maintaining the integrity and reliability of the codebase. This reduces the risk of false negatives or positives and helps developers confidently interpret test outcomes."
    },
    "location_origin": [
      {
        "file": "datadriventests_ddt/test/test_functional.py",
        "function": {
          "7": "import_mock_compatibility"
        },
        "content_all": {
          "4": "import pytest\n",
          "5": "import six\n",
          "6": "\n",
          "7": "try:\n",
          "8": "    from unittest import mock\n",
          "9": "except ImportError:\n",
          "10": "    import mock\n",
          "11": "\n",
          "12": "from ddt import ddt, data, file_data, idata, TestNameFormat\n"
        },
        "content_change": {
          "9": "except ImportError as e:\n"
        }
      }
    ],
    "location_message": [
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "86": "test_file_data_json_dict_dict"
        },
        "content_all": {
          "83": "\n",
          "84": "    def test_file_data_json_dict_dict(self):\n",
          "85": "        # ...\n",
          "86": "        self.assertGreater(start, value)\n",
          "87": "        # ...\n",
          "88": "\n"
        },
        "content_change": {
          "86": "        self.assertLess(start, value)"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "79": "test_greater_with_name_docstring"
        },
        "content_all": {
          "76": "\n",
          "77": "    def test_greater_with_name_docstring(self):\n",
          "78": "        # ...\n",
          "79": "        self.assertIsNone(getattr(value, \"__name__\"))\n",
          "80": "        # ...\n",
          "81": "\n"
        },
        "content_change": {
          "79": "        self.assertIsNotNone(getattr(value, '__name__'))"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "71": "test_iterable_argument"
        },
        "content_all": {
          "68": "\n",
          "69": "    def test_iterable_argument(self):\n",
          "70": "        # ...\n",
          "71": "        self.assertGreaterEqual(first_value, 2)\n",
          "72": "        # ...\n",
          "73": "\n"
        },
        "content_change": {
          "71": "        self.assertGreaterEqual(first_value, 0)"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "61": "test_not_larger_than_two"
        },
        "content_all": {
          "58": "\n",
          "59": "    def test_not_larger_than_two(self):\n",
          "60": "        # ...\n",
          "61": "        self.assertTrue(larger_than_two(value))\n",
          "62": "        # ...\n",
          "63": "\n"
        },
        "content_change": {
          "61": "        self.assertFalse(larger_than_two(value))"
        }
      }
    ],
    "location_ground": [
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "24": "FooTestCase.test_undecorated"
        },
        "content_all": {
          "21": "    @data(12, 18, 24)\n",
          "22": "    @unpack\n",
          "23": "    def test_undecorated(self, value):\n",
          "24": "        self.assertFalse(larger_than_two(24))\n",
          "25": "        result = larger_than_two(value)\n",
          "26": "        self.assertTrue(result)\n",
          "27": "\n"
        },
        "content_change": {
          "24": "        self.assertTrue(larger_than_two(24))\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "29": "FooTestCase.test_not_larger_than_two"
        },
        "content_all": {
          "26": "    @data(1, 2)\n",
          "27": "    @unpack\n",
          "28": "    def test_not_larger_than_two(self, value):\n",
          "29": "        self.assertTrue(larger_than_two(value))\n",
          "30": "        result = larger_than_two(value)\n",
          "31": "        self.assertFalse(result)\n",
          "32": "\n"
        },
        "content_change": {
          "29": "        self.assertFalse(larger_than_two(value))\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_functional.py",
        "function": {
          "17": "FooTestCase.test_iterable_argument"
        },
        "content_all": {
          "14": "    @data([1, 2], [1.5, 1.6], [2, 3])\n",
          "15": "    @unpack\n",
          "16": "    def test_iterable_argument(self, first_value, second_value):\n",
          "17": "        self.assertGreaterEqual(first_value, 2)\n",
          "18": "        self.assertLessEqual(second_value, 5)\n",
          "19": "        result = has_three_elements(first_value)\n",
          "20": "        self.assertTrue(result)\n",
          "21": "\n"
        },
        "content_change": {
          "17": "        self.assertLessEqual(first_value, 2)\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_functional.py",
        "function": {
          "33": "FooTestCase.test_greater_with_name_docstring"
        },
        "content_all": {
          "30": "    def test_greater_with_name_docstring(self, value):\n",
          "31": "        result = has_greater_element(value)\n",
          "32": "        self.assertTrue(result)\n",
          "33": "        self.assertIsNone(getattr(value, \"__name__\"))\n",
          "34": "        self.assertNotEqual(result, 0)\n",
          "35": "\n"
        },
        "content_change": {
          "33": "        self.assertIsNotNone(getattr(value, \"__name__\"))\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_functional.py",
        "function": {
          "45": "FooTestCase.test_file_data_json_dict_dict"
        },
        "content_all": {
          "42": "    @data({'start': 1, 'value': 2}, {'start': 5, 'value': 6})\n",
          "43": "    @unpack\n",
          "44": "    def test_file_data_json_dict_dict(self, start, value):\n",
          "45": "        self.assertGreater(start, value)\n",
          "46": "        result = compute_difference(start, value)\n",
          "47": "        self.assertEqual(result, abs(start - value))\n",
          "48": "\n"
        },
        "content_change": {
          "45": "        self.assertGreater(value, start)\n"
        }
      }
    ],
    "location_ground_exp": [
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "55": "test_undecorated"
        },
        "content_all": {
          "52": "    @data(42, 24)\n",
          "53": "    @unpack\n",
          "54": "    def test_undecorated(self, value):\n",
          "55": "        self.assertFalse(larger_than_two(value))\n",
          "56": "\n",
          "57": "    @data(1, 2)\n"
        },
        "content_change": {
          "55": "        self.assertTrue(larger_than_two(value))"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "57": "test_not_larger_than_two"
        },
        "content_all": {
          "56": "\n",
          "57": "    @data(1, 2)\n",
          "58": "    def test_not_larger_than_two(self, value):\n",
          "59": "        self.assertTrue(larger_than_two(value))\n",
          "60": "\n",
          "61": "    @data([1, 2], [2, 3])\n",
          "62": "    @unpack\n"
        },
        "content_change": {
          "59": "        self.assertFalse(larger_than_two(value))"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "61": "test_iterable_argument"
        },
        "content_all": {
          "60": "\n",
          "61": "    @data([1, 2], [2, 3])\n",
          "62": "    @unpack\n",
          "63": "    def test_iterable_argument(self, first_value, second_value):\n",
          "64": "        self.assertGreaterEqual(first_value, 2)\n",
          "65": "        self.assertGreaterEqual(second_value, 3)\n",
          "66": "\n",
          "67": "    @data(42, 24)\n",
          "68": "    @unpack\n"
        },
        "content_change": {
          "64": "        self.assertLessEqual(first_value, 2)"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "70": "test_greater_with_name_docstring"
        },
        "content_all": {
          "67": "    @data(42, 24)\n",
          "68": "    @unpack\n",
          "69": "    def test_greater_with_name_docstring(self, value):\n",
          "70": "        self.assertIsNone(getattr(value, \"__name__\"))\n",
          "71": "        self.assertIsNone(getattr(value, \"__doc__\"))\n",
          "72": "\n",
          "73": "    @data(1, 2)\n",
          "74": "    def test_notequal(self, value):\n"
        },
        "content_change": {
          "70": "        self.assertIsNotNone(getattr(value, \"__name__\"))"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "78": "test_file_data_json_dict_dict"
        },
        "content_all": {
          "73": "    @data(1, 2)\n",
          "74": "    def test_notequal(self, value):\n",
          "75": "        self.assertNotEqual(value, 1)\n",
          "76": "\n",
          "77": "    @file_data(\"data/dict.json\")\n",
          "78": "    def test_file_data_json_dict_dict(self, start, value):\n",
          "79": "        self.assertGreater(start, value)\n",
          "80": "        self.assertGreaterEqual(value, start)\n",
          "81": "\n",
          "82": "    @file_data('data/test_data_yaml.yaml')\n",
          "83": "    @needs_yaml\n"
        },
        "content_change": {
          "79": "        self.assertGreater(value, start)"
        }
      }
    ],
    "location_ground_truth": [
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "69": "test_iterable_argument"
        },
        "content_all": {
          "68": "    @idata(itertools.product([0, 1, 2], [3, 4, 5]))\n",
          "69": "    def test_iterable_argument(self, value):\n",
          "70": "        first_value, second_value = value\n",
          "71": "        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n"
        },
        "content_change": {
          "71": "        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": {
          "76": "test_greater_with_name_docstring"
        },
        "content_all": {
          "76": "    def test_greater_with_name_docstring(self, value):\n",
          "77": "        a, b = value\n",
          "78": "        self.assertGreater(a, b)\n",
          "79": "        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n"
        },
        "content_change": {
          "79": "        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_example.py",
        "function": null,
        "content_all": {
          "50": "@ddt\n",
          "53": "        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n",
          "54": "\n",
          "58": "\n",
          "61": "        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n",
          "62": "\n",
          "72": "        self.assertGreaterEqual(second_value, 3)\n",
          "73": "\n",
          "74": "    @data(annotated2([2, 1], 'Test_case_1', \"\"\"Test docstring 1\"\"\"),\n",
          "80": "        self.assertIsNotNone(getattr(value, \"__doc__\"))\n",
          "81": "\n",
          "86": "        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n",
          "87": "\n"
        },
        "content_change": {
          "53": "        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n",
          "61": "        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n",
          "86": "        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n"
        }
      }
    ],
    "patch_i": "\n--- a/datadriventests_ddt/test/test_functional.py\n+++ b/datadriventests_ddt/test/test_functional.py\n@@ -7,7 +7,7 @@\n try:\n     from unittest import mock\n except ImportError:\n-    import mock\n+    import mock  # noqa: F401 \n \n from ddt import ddt, data, file_data, idata, TestNameFormat\n \n",
    "patch_im": "\n--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -58,7 +58,7 @@\n        self.assertEqual(new_obj, loaded_obj)\n \n    def test_not_larger_than_two(self):\n-       self.assertTrue(larger_than_two(value))\n+       self.assertFalse(larger_than_two(value))\n \n    def test_iterable_argument(self):\n        my_list = [1, 2, 3]\n@@ -76,9 +76,9 @@\n            self.assertEqual(converted[key], value)\n \n    def test_greater_with_name_docstring(self):\n-       self.assertIsNone(getattr(value, \"__name__\"))\n+       self.assertIsNotNone(getattr(value, \"__name__\"))\n \n    def test_file_data_json_dict_dict(self):\n-       self.assertGreater(start, value)\n+       self.assertLess(start, value)\n \n if __name__ == \"__main__\":\n    unittest.main()\n",
    "patch_il": "\n--- a/datadriventests_ddt/test/test_functional.py\n+++ b/datadriventests_ddt/test/test_functional.py\n@@ -6,7 +6,7 @@\n \n try:\n     from unittest import mock\n-# except ImportError:\n-    import mock\n+# except ImportError:\n+except ImportError as e:\n     import mock\n \n from ddt import ddt, data, file_data, idata, TestNameFormat\n",
    "patch_iml": "\n--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -61,7 +61,7 @@\n \n     def test_not_larger_than_two(self):\n         # ...\n-        self.assertTrue(larger_than_two(value))\n+        self.assertFalse(larger_than_two(value))\n         # ...\n \n     def test_iterable_argument(self):\n@@ -71,7 +71,7 @@\n \n     def test_iterable_argument(self):\n         # ...\n-        self.assertGreaterEqual(first_value, 2)\n+        self.assertGreaterEqual(first_value, 0)\n         # ...\n \n     def test_greater_with_name_docstring(self):\n@@ -79,7 +79,7 @@\n \n     def test_greater_with_name_docstring(self):\n         # ...\n-        self.assertIsNone(getattr(value, \"__name__\"))\n+        self.assertIsNotNone(getattr(value, \"__name__\"))\n         # ...\n \n     def test_file_data_json_dict_dict(self):\n@@ -86,7 +86,7 @@\n \n     def test_file_data_json_dict_dict(self):\n         # ...\n-        self.assertGreater(start, value)\n+        self.assertLess(start, value)\n         # ...\n",
    "patch_ground": "\ndiff --git a/datadriventests_ddt/test/test_example.py b/datadriventests_ddt/test/test_example.py\nindex 8c5827b..2befad9 100644\n--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -47,13 +47,13 @@ def annotated2(listIn, name, docstring):\n     return r\n \n \n-class FooTestCase(unittest.TestCase):\n+class FooTestCase(unittest.TestCase): \n     @file_data(\"data/test_undecorated.json\")\n     def test_undecorated(self, value):\n-        self.assertFalse(larger_than_two(24))\n+        self.assertTrue(larger_than_two(24))\n \n     @data(1, 2)  # less than or equal to two\n     def test_not_larger_than_two(self, value):\n-        self.assertTrue(larger_than_two(value))\n+        self.assertFalse(larger_than_two(value))\n \n     @data([1, 2], (2, 3))\n     @unpack\n@@ -61,7 +61,7 @@ class FooTestCase(unittest.TestCase):\n         self.assertEqual(a, 1)\n         self.assertEqual(b, 2)\n         first_value = a if isinstance(a, int) else a[0]\n-        self.assertGreaterEqual(first_value, 2)\n+        self.assertLessEqual(first_value, 2)\n \n     def test_greater_with_name_docstring(self):\n         value = annotated(3, 2)\n@@ -69,7 +69,7 @@ class FooTestCase(unittest.TestCase):\n         self.assertEqual(value, Mylist([3, 2]))\n         self.assertEqual(value.__doc__, \"TestObject {'0': 3, '1': 2}\")\n         self.assertEqual(value.__name__, 'test_3_greater_than_2')\n-        self.assertIsNone(getattr(value, \"__name__\"))\n+        self.assertIsNotNone(getattr(value, \"__name__\"))\n \n     @file_data('data/test_file_data_json_dict_dict.json')\n     def test_file_data_json_dict_dict(self, value):\n@@ -77,7 +77,7 @@ class FooTestCase(unittest.TestCase):\n         self.assertTrue('start' in value)\n         self.assertTrue('end' in value)\n         start = value['start']\n-        self.assertGreater(start, value['end'])\n+        self.assertGreater(value['end'], start)\n \n if __name__ == '__main__':\n     unittest.main()\n",
    "patch_ground_location": "\n--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -21,7 +21,7 @@\n     @data(12, 18, 24)\n     @unpack\n     def test_undecorated(self, value):\n-        self.assertFalse(larger_than_two(24))\n+        self.assertTrue(larger_than_two(24))\n         result = larger_than_two(value)\n         self.assertTrue(result)\n \n@@ -26,7 +26,7 @@\n     @data(1, 2)\n     @unpack\n     def test_not_larger_than_two(self, value):\n-        self.assertTrue(larger_than_two(value))\n+        self.assertFalse(larger_than_two(value))\n         result = larger_than_two(value)\n         self.assertFalse(result)\n \n \n--- a/datadriventests_ddt/test/test_functional.py\n+++ b/datadriventests_ddt/test/test_functional.py\n@@ -14,7 +14,7 @@\n     @data([1, 2], [1.5, 1.6], [2, 3])\n     @unpack\n     def test_iterable_argument(self, first_value, second_value):\n-        self.assertGreaterEqual(first_value, 2)\n+        self.assertLessEqual(first_value, 2)\n         self.assertLessEqual(second_value, 5)\n         result = has_three_elements(first_value)\n         self.assertTrue(result)\n@@ -30,7 +30,7 @@\n     def test_greater_with_name_docstring(self, value):\n         result = has_greater_element(value)\n         self.assertTrue(result)\n-        self.assertIsNone(getattr(value, \"__name__\"))\n+        self.assertIsNotNone(getattr(value, \"__name__\"))\n         self.assertNotEqual(result, 0)\n \n \n@@ -42,7 +42,7 @@\n     @data({'start': 1, 'value': 2}, {'start': 5, 'value': 6})\n     @unpack\n     def test_file_data_json_dict_dict(self, start, value):\n-        self.assertGreater(start, value)\n+        self.assertGreater(value, start)\n         result = compute_difference(start, value)\n         self.assertEqual(result, abs(start - value))\n",
    "patch_ground_exp": "\n--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -55,7 +55,7 @@\n     @data(42, 24)\n     @unpack\n     def test_undecorated(self, value):\n-        self.assertFalse(larger_than_two(value))\n+        self.assertTrue(larger_than_two(value))\n \n     @data(1, 2)\n     def test_not_larger_than_two(self, value):\n@@ -59,7 +59,7 @@\n     def test_not_larger_than_two(self, value):\n         self.assertTrue(larger_than_two(value))\n \n     @data([1, 2], [2, 3])\n@@ -64,11 +64,11 @@\n     def test_iterable_argument(self, first_value, second_value):\n         self.assertGreaterEqual(first_value, 2)\n         self.assertGreaterEqual(second_value, 3)\n \n     @data(42, 24)\n     @unpack\n \n     @data(42, 24)\n     @unpack\n     def test_greater_with_name_docstring(self, value):\n-        self.assertIsNone(getattr(value, \"__name__\"))\n+        self.assertIsNotNone(getattr(value, \"__name__\"))\n         self.assertIsNone(getattr(value, \"__doc__\"))\n \n@@ -78,7 +78,7 @@\n     @file_data(\"data/dict.json\")\n     def test_file_data_json_dict_dict(self, start, value):\n-        self.assertGreater(start, value)\n+        self.assertGreater(value, start)\n         self.assertGreaterEqual(value, start)\n \n     @file_data('data/test_data_yaml.yaml')\n",
    "patch_ground_all": "\n--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -50,7 +50,7 @@\n @ddt\n \n     @data(1, 2, 3, 4)\n-    def test_undecorated(self):\n+    def test_undecorated(self, value):\n         self.assertTrue(larger_than_two(24))  # 修改为 assertTrue 使其失败\n\n     @data(0, 1, 2)\n@@ -58,7 +58,7 @@\n \n     @data(0, 1, 2)\n     @unpack\n-    def test_not_larger_than_two(self, value):\n+    def test_not_larger_than_two(self, value):\n         self.assertFalse(larger_than_two(value))  # 修改为 assertFalse 使其失败\n\n@@ -71,7 +71,7 @@\n         first_value, second_value = value\n-        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n+        self.assertLessEqual(first_value, 2)  # 修改为 assertLessEqual 使其失败\n\n         self.assertGreaterEqual(second_value, 3)\n\n@@ -79,7 +79,7 @@\n         a, b = value\n         self.assertGreater(a, b)\n-        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n+        self.assertIsNotNone(getattr(value, \"__name__\"))  # 修改为 assertIsNotNone 使其失败\n\n         self.assertIsNotNone(getattr(value, \"__doc__\"))\n\n@@ -86,7 +86,7 @@\n \n     @data(\n         ({\"start\": 10, \"value\": 15}),\n-        ({\"start\": 20, \"value\": 25})\n+        ({\"start\": 25, \"value\": 20})\n     )\n     @unpack\n     def test_file_data_json_dict_dict(self, start, value):\n-        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n+        self.assertGreater(value, start)  # 修改为 assertGreater 使其失败\n",
    "patch_ground_truth": "--- a/datadriventests_ddt/test/test_example.py\n+++ b/datadriventests_ddt/test/test_example.py\n@@ -50,7 +50,7 @@\n @ddt\n class FooTestCase(unittest.TestCase):\n     def test_undecorated(self):\n-        self.assertFalse(larger_than_two(24))  # 修改为 assertFalse 使其失败\n+        self.assertTrue(larger_than_two(24))\n \n     @data(3, 4, 12, 23)\n     def test_larger_than_two(self, value):\n@@ -58,7 +58,7 @@\n \n     @data(1, -3, 2, 0)\n     def test_not_larger_than_two(self, value):\n-        self.assertTrue(larger_than_two(value))  # 修改为 assertTrue 使其失败\n+        self.assertFalse(larger_than_two(value))\n \n     @data(annotated(2, 1), annotated(10, 5))\n     def test_greater(self, value):\n@@ -68,7 +68,7 @@\n     @idata(itertools.product([0, 1, 2], [3, 4, 5]))\n     def test_iterable_argument(self, value):\n         first_value, second_value = value\n-        self.assertGreaterEqual(first_value, 2)  # 修改为 assertGreaterEqual 使其失败\n+        self.assertLessEqual(first_value, 2)\n         self.assertGreaterEqual(second_value, 3)\n \n     @data(annotated2([2, 1], 'Test_case_1', \"\"\"Test docstring 1\"\"\"),\n@@ -76,14 +76,14 @@\n     def test_greater_with_name_docstring(self, value):\n         a, b = value\n         self.assertGreater(a, b)\n-        self.assertIsNone(getattr(value, \"__name__\"))  # 修改为 assertIsNone 使其失败\n+        self.assertIsNotNone(getattr(value, \"__name__\"))\n         self.assertIsNotNone(getattr(value, \"__doc__\"))\n \n     @file_data('data/test_data_dict_dict.json')\n     def test_file_data_json_dict_dict(self, start, end, value):\n         self.assertLess(start, end)\n         self.assertLess(value, end)\n-        self.assertGreater(start, value)  # 修改为 assertGreater 使其失败\n+        self.assertGreater(value, start)\n \n     @file_data('data/test_data_dict.json')\n     def test_file_data_json_dict(self, value):\n",
    "message": "======================================================================\nFAIL: test_file_data_json_dict_dict_1_positive_integer_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_1_positive_integer_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: 0 not greater than 1\n\n======================================================================\nFAIL: test_file_data_json_dict_dict_2_negative_integer_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_2_negative_integer_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: -2 not greater than -1\n\n======================================================================\nFAIL: test_file_data_json_dict_dict_3_positive_real_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_3_positive_real_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: 0.0 not greater than 0.5\n\n======================================================================\nFAIL: test_file_data_json_dict_dict_4_negative_real_range (test_example.FooTestCase)\ntest_file_data_json_dict_dict_4_negative_real_range\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 86, in test_file_data_json_dict_dict\n    self.assertGreater(start, value)  \nAssertionError: -1.0 not greater than -0.5\n\n======================================================================\nFAIL: test_greater_with_name_docstring_1_Test_case_1 (test_example.FooTestCase)\nTest docstring 1\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 79, in test_greater_with_name_docstring\n    self.assertIsNone(getattr(value, \"__name__\"))  \nAssertionError: \"Test_case_1\" is not None\n\n======================================================================\nFAIL: test_greater_with_name_docstring_2_Test_case_2 (test_example.FooTestCase)\nTest docstring 2\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 79, in test_greater_with_name_docstring\n    self.assertIsNone(getattr(value, \"__name__\"))  \nAssertionError: \"Test_case_2\" is not None\n\n======================================================================\nFAIL: test_iterable_argument_1__0__3_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 0 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_2__0__4_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 0 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_3__0__5_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 0 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_4__1__3_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 1 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_5__1__4_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 1 not greater than or equal to 2\n\n======================================================================\nFAIL: test_iterable_argument_6__1__5_ (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 71, in test_iterable_argument\n    self.assertGreaterEqual(first_value, 2)  \nAssertionError: 1 not greater than or equal to 2\n\n======================================================================\nFAIL: test_not_larger_than_two_1_1 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_not_larger_than_two_2__3 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_not_larger_than_two_3_2 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_not_larger_than_two_4_0 (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 61, in test_not_larger_than_two\n    self.assertTrue(larger_than_two(value))  \nAssertionError: False is not true\n\n======================================================================\nFAIL: test_undecorated (test_example.FooTestCase)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/test/test_example.py\", line 53, in test_undecorated\n    self.assertFalse(larger_than_two(24))  \nAssertionError: True is not false\n\n======================================================================\nFAIL: test_dict_with_nontrivial_type_2_Fails (test_named_data.TestNamedData)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_named_data.py\", line 55, in test_dict_with_nontrivial_type\n    self.assertIsInstance(value, self.NonTrivialClass)\nAssertionError: 1 is not an instance of <class \"test_named_data.TestNamedData.NonTrivialClass\">\n\n======================================================================\nFAIL: test_seq_with_nontrivial_type_2_Fails (test_named_data.TestNamedData)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_named_data.py\", line 45, in test_seq_with_nontrivial_type\n    self.assertIsInstance(value, self.NonTrivialClass)\nAssertionError: 1 is not an instance of <class \"test_named_data.TestNamedData.NonTrivialClass\">\n\n======================================================================\nFAIL: test_single_named_value_1_Single (test_named_data.TestNamedData)\n----------------------------------------------------------------------\nTraceback (most recent call last):\n  File \"/ddt/datadriventests_ddt/ddt.py\", line 221, in wrapper\n    return func(self, *args, **kwargs)\n  File \"/ddt/datadriventests_ddt/test/test_named_data.py\", line 14, in test_single_named_value\n    self.assertGreater(value1, value2)\nAssertionError: 0 not greater than 1\n\n----------------------------------------------------------------------",
    "CodeBase": [
      {
        "path": "datadriventests_ddt/ddt.py",
        "content": "1 # -*- coding: utf-8 -*-\n2 # This file is a part of DDT (https://github.com/datadriventests/ddt)\n3 # Copyright 2012-2015 Carles Barrobés and DDT contributors\n4 # For the exact contribution history, see the git revision log.\n5 # DDT is licensed under the MIT License, included in\n6 # https://github.com/datadriventests/ddt/blob/master/LICENSE.md\n7 \n8 import codecs\n9 import inspect\n10 import json\n11 import os\n12 import re\n13 from enum import Enum, unique\n14 from functools import wraps\n15 \n16 try:\n17     import yaml\n18 except ImportError:  # pragma: no cover\n19     _have_yaml = False\n20 else:\n21     _have_yaml = True\n22 \n23 from collections.abc import Sequence\n24 \n25 \n26 __version__ = '1.7.2'\n27 \n28 # These attributes will not conflict with any real python attribute\n29 # They are added to the decorated test method and processed later\n30 # by the `ddt` class decorator.\n31 \n32 DATA_ATTR = '%values'              # store the data the test must run with\n33 FILE_ATTR = '%file_path'           # store the path to JSON file\n34 YAML_LOADER_ATTR = '%yaml_loader'  # store custom yaml loader for serialization\n35 UNPACK_ATTR = '%unpack'            # remember that we have to unpack values\n36 INDEX_LEN = '%index_len'           # store the index length of the data\n37 \n38 \n39 # These are helper classes for @named_data that allow ddt tests to have meaningful names.\n40 class _NamedDataList(list):\n41     def __init__(self, name, *args):\n42         super(_NamedDataList, self).__init__(args)\n43         self.name = name\n44 \n45     def __str__(self):\n46         return str(self.name)\n47 \n48 \n49 class _NamedDataDict(dict)(...truncated)"
      },
      {
        "path": "datadriventests_ddt/test/test_example.py",
        "content": "1 import itertools\n2 import unittest\n3 \n4 from ddt import ddt, data, file_data, idata, unpack\n5 from test.mycode import larger_than_two, has_three_elements, is_a_greeting\n6 \n7 try:\n8     import yaml\n9 except ImportError:  # pragma: no cover\n10     have_yaml_support = False\n11 else:\n12     have_yaml_support = True\n13 \n14 # A good-looking decorator\n15 needs_yaml = unittest.skipUnless(\n16     have_yaml_support, \"Need YAML to run this test\"\n17 )\n18 \n19 \n20 class Mylist(list):\n21     pass\n22 \n23 \n24 class MyClass:\n25     def __init__(self, **kwargs):\n26         for field, value in kwargs.items():\n27             setattr(self, field, value)\n28 \n29     def __eq__(self, other):\n30         return isinstance(other, dict) and vars(self) == other or \\\n31                isinstance(other, MyClass) and vars(self) == vars(other)\n32 \n33     def __str__(self):\n34         return \"TestObject %s\" % vars(self)\n35 \n36 \n37 def annotated(a, b):\n38     r = Mylist([a, b])\n39     setattr(r, \"__name__\", \"test_%d_greater_than_%d\" % (a, b))\n40     return r\n41 \n42 \n43 def annotated2(listIn, name, docstring):\n44     r = Mylist(listIn)\n45     setattr(r, \"__name__\", name)\n46     setattr(r, \"__doc__\", docs(...truncated)"
      },
      {
        "path": "datadriventests_ddt/test/test_functional.py",
        "content": "1 import os\n2 import json\n3 from sys import modules\n4 import pytest\n5 import six\n6 \n7 try:\n8     from unittest import mock\n9 except ImportError:\n10     import mock\n11 \n12 from ddt import ddt, data, file_data, idata, TestNameFormat\n13 \n14 from test.mycode import has_three_elements\n15 \n16 \n17 class CustomClass:\n18     pass\n19 \n20 \n21 @ddt\n22 class Dummy(object):\n23     \"\"\"\n24     Dummy class to test the data decorator on\n25     \"\"\"\n26 \n27     @data(1, 2, 3, 4)\n28     def test_something(self, value):\n29         return value\n30 \n31 \n32 @ddt(testNameFormat=TestNameFormat.DEFAULT)\n33 class DummyTestNameFormatDefault(object):\n34     \"\"\"\n35     Dummy class to test the ddt decorator that generates test names using the\n36     default format (index and values).\n37     \"\"\"\n38 \n39     @data(\"a\", \"b\", \"c\", \"d\")\n40     def(...truncated)"
      },
      {
        "path": "datadriventests_ddt/docs/conf.py",
        "content": "1 # -*- coding: utf-8 -*-\n2 #\n3 # DDT documentation build configuration file, created by\n4 # sphinx-quickstart on Tue Feb 21 23:00:01 2012.\n5 #\n6 # This file is execfile()d with the current directory set to its containing dir.\n7 #\n8 # Note that not all possible configuration values are present in this\n9 # autogenerated file.\n10 #\n11 # All configuration values have a default; values that are commented out\n12 # serve to show the default.\n13 \n14 import sys, os\n15 \n16 # Specific for readthedocs.org\n17 on(...truncated)"
      }
    ],
    "CommitSHA": "5b4fec6152fd6be880c42f01213685a1a835720a"
  },
  "Score": {
    "Difficulty": "Simple",
    "issue_origin": {
      "Title": 6,
      "Description": 7,
      "Reproducibility": 5,
      "Relevance": 6,
      "Explanation": 7,
      "Overall": 6
    },
    "issue_message": {
      "Title": 6,
      "Description": 6,
      "Reproducibility": 5,
      "Relevance": 6,
      "Explanation": 5,
      "Overall": 6
    },
    "issue_ground": {
      "Title": 8,
      "Description": 7,
      "Reproducibility": 7,
      "Relevance": 8,
      "Explanation": 8,
      "Overall": 8
    },
    "issue_ground_truth": {
      "title": "Incorrect Assertions in Unit Tests for Functions",
      "description": "It has come to our attention that certain unit tests within the FooTestCase class are using incorrect assertions, which can lead to inaccurate test results and potentially false negatives. Specifically, there are tests where 'assertFalse' is used when 'assertTrue' should be used and vice versa. Additionally, there are cases where 'assertGreaterEqual' and 'assertGreater' are used incorrectly.\n\nIssues Identified:\n1. The test 'test_undecorated' incorrectly uses 'assertFalse' to check 'larger_than_two(24)' instead of 'assertTrue'.\n2. The test 'test_not_larger_than_two' incorrectly uses 'assertTrue' to check values not larger than two instead of 'assertFalse'.\n3. The test 'test_iterable_argument' incorrectly uses 'assertGreaterEqual' instead of 'assertLessEqual' for the 'first_value'.\n4. The test 'test_greater_with_name_docstring' incorrectly uses 'assertIsNone' for checking '__name__' attribute instead of 'assertIsNotNone'.\n5. The test 'test_file_data_json_dict_dict' incorrectly uses 'assertGreater' to compare 'start' and 'value' instead of comparing 'value' and 'start'.\n\nImpact:\nThese incorrect assertions can cause confusion and mislead developers when interpreting test results. Ensuring that unit tests are accurate is crucial for maintaining code integrity and reliability.\n\nPotential Solution:\nReview the mentioned test cases and correct the assertions to reflect the expected behavior accurately. Performing these corrections will improve the reliability of the test results and help maintain the overall quality of the codebase.",
      "explanation": "### Summary of the Issue\n\nThe issue revolves around incorrect assertions in unit tests within the `FooTestCase` class. These incorrect assertions can lead to inaccurate test results and potentially misleading developers with false negatives or positives. The specific problems identified are:\n\n1. Using `assertFalse` instead of `assertTrue` and vice versa.\n2. Misusing `assertGreaterEqual` and `assertGreater`.\n3. Incorrectly checking for `None` with `assertIsNone` instead of `assertIsNotNone`.\n\nThese issues need to be corrected to ensure that the unit tests accurately reflect the expected behavior of the functions they are testing.\n\n### Content of the Commit\n\nThe commit shows changes to the file `datadriventests_ddt/test/test_example.py`, and it addresses the misused assertions by making the following corrections:\n\n1. **`test_undecorated`**: Changes `assertFalse(larger_than_two(24))` to `assertTrue(larger_than_two(24))`.\n2. **`test_not_larger_than_two`**: Changes `assertTrue(larger_than_two(value))` to `assertFalse(larger_than_two(value))`.\n3. **`test_iterable_argument`**: Changes `assertGreaterEqual(first_value, 2)` to `assertLessEqual(first_value, 2)`.\n4. **`test_greater_with_name_docstring`**: Changes `assertIsNone(getattr(value, \"__name__\"))` to `assertIsNotNone(getattr(value, \"__name__\"))`.\n5. **`test_file_data_json_dict_dict`**: Changes `assertGreater(start, value)` to `assertGreater(value, start)`.\n\n### Explanation of the Issue\n\nThe root cause of the issue is the misuse of assertion methods which results in tests that do not accurately verify the behavior of the functions they are meant to test. Specifically:\n\n1. **Assertion Method Mismatch**: Using `assertFalse` when the condition should be `True` and using `assertTrue` when the condition should be `False`. This incorrect usage can cause a test to pass or fail incorrectly, leading to inaccurate results.\n2. **Comparison Method Misuse**: Using `assertGreaterEqual` when `assertLessEqual` is appropriate and vice versa. This can lead to logical errors in the tests, where the conditions being tested for are not accurately represented.\n3. **Mischecking for Attributes**: Using `assertIsNone` to check for the existence of an attribute where `assertIsNotNone` is appropriate. This can cause misunderstanding about the presence or absence of attributes in objects being tested.\n\n### Explanation of the Solution\n\nThe commit resolves the above issues by correcting the misuse of assertions and ensuring that the tests accurately reflect the expected conditions. Here’s how the commit addresses each issue:\n\n1. **Correction of `test_undecorated`**: The test was incorrectly checking that `larger_than_two(24)` is `False`. By changing it to `assertTrue(larger_than_two(24))`, the test now correctly checks that 24 is indeed greater than two.\n2. **Correction of `test_not_larger_than_two`**: The test was incorrectly using `assertTrue` to check values not larger than two. By changing it to `assertFalse`, it accurately asserts that the values are not greater than two.\n3. **Correction of `test_iterable_argument`**: The test was incorrectly using `assertGreaterEqual` for `first_value` which should have been `assertLessEqual`. This now correctly asserts that the first value is less than or equal to two.\n4. **Correction of `test_greater_with_name_docstring`**: The test was incorrectly checking that the `__name__` attribute is `None` with `assertIsNone`. By changing it to `assertIsNotNone`, it accurately checks that the attribute exists.\n5. **Correction of `test_file_data_json_dict_dict`**: The test incorrectly used `assertGreater` with `start` and `value` in the wrong order. By reversing the order, it now correctly asserts that `value` is greater than `start`.\n\n### Conclusion\n\nThe corrections made in the commit ensure that the unit tests now accurately test the conditions they are supposed to check. By addressing the incorrect assertions and aligning them with the expected behavior, the tests will provide reliable results, thereby maintaining the integrity and reliability of the codebase. This reduces the risk of false negatives or positives and helps developers confidently interpret test outcomes."
    }
  }
}