{
  "RepoName": "https://github.com/datadriventests/ddt.git",
  "CommitSHA": "5b4fec6152fd6be880c42f01213685a1a835720a",
  "Type": "logic error",
  "ErrorMessage": "======================================================================\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----------------------------------------------------------------------\nRan 89 tests in 0.005s\n\nFAILED (failures=3)",
  "Issue": {
    "title": "Inaccurate Assertions in Test Cases for Named Data",
    "description": "### Description\nThere are inaccurate assertions in the test cases for named data, which lead to incorrect test results. Specifically, two test cases are using 'assertIsInstance' to verify instances of a class where 'assertNotIsInstance' should be used. Furthermore, the comparison logic in another test case is reversed, potentially causing false positives.\n\n### Issues Detected\n1. **test_single_named_value Method:** The comparison logic is reversed, potentially leading to inaccurate results. It asserts `self.assertGreater(value1, value2)` when it should assert the opposite.\n2. **test_seq_with_nontrivial_type and test_dict_with_nontrivial_type Methods:** These tests verify class instances incorrectly using `assertIsInstance` in both branches of an if-else statement, causing incorrect pass/fail results.\n\n### Impact\nThese issues result in misleading test outcomes, where tests may pass or fail incorrectly based on flawed assertions. Accurate testing is crucial for maintaining the robustness and reliability of the codebase.\n\n### Proposed Solution\n- Reverse the comparison in the `test_single_named_value` method to correctly evaluate `self.assertGreater(value2, value1)`.\n- Update the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to correctly use `assertNotIsInstance` in the 'else' clauses.\n\nResolving these issues will ensure that the test cases accurately validate the code under test, leading to more reliable and meaningful test results.",
    "explanation": "### Summary of the Issue\nThe issue centers around inaccurate assertions in the test cases for named data in the `datadriventests_ddt` codebase. Specifically, there are two main problems:\n1. **Reversed Comparison Logic:** In the `test_single_named_value` method, the comparison logic is reversed, leading to incorrect results.\n2. **Incorrect Instance Verification:** In the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, the test assertions incorrectly use `assertIsInstance` in both branches of an if-else statement, which results in misleading test outcomes.\n\n### Summary of the Commit\nThe commit addresses the issue by making specific changes to the test file `tests/test_named_data.py` to correct the assertions:\n1. **Correcting the Comparison Logic:** The comparison logic in the `test_single_named_value` method is corrected to ensure that the values are compared correctly.\n2. **Fixing Instance Verification:** The logic for verifying class instances is corrected in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods. The correct assertion `assertNotIsInstance` is used when verifying values that should not be instances of a specific class.\n\n### Explanation of the Solution\n#### Problem 1: Incorrect Comparison Logic\nThe `test_single_named_value` method previously had a comparison that was reversed. This means it was checking if `value1` was greater than `value2` when it should have been doing the opposite.\n\n**Cause**: The reversed comparison led to potentially incorrect test results, causing the test to pass or fail incorrectly based on flawed logic.\n\n**Solution**: The commit corrects the comparison so that the method now accurately checks if `value2` is greater than `value1`. This ensures that the test reflects the intended logic and produces accurate results. By swapping the positions of the values being compared, the test can now correctly determine the relationship between them.\n\n#### Problem 2: Incorrect Instance Verification\nIn the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, assertions for verifying instance types were incorrectly using the same assertion (`assertIsInstance`) in both the `if` and `else` branches of conditionals. This led to incorrect verification of instances, causing misleading results.\n\n**Cause**: Using `assertIsInstance` in both branches meant that the tests could not correctly differentiate between cases where the value should be an instance of a specific class and cases where it should not. This led to incorrect test passes or failures.\n\n**Solution**: The commit changes the assertion in the `else` branch from `assertIsInstance` to `assertNotIsInstance`. This ensures that when the condition is not met (`passes` is `False`), the test correctly verifies that the value is not an instance of the specified class (`NonTrivialClass`). By making this change, the tests can now accurately check the instance type based on the condition, leading to reliable and meaningful test results.\n\n### Conclusion\nThe commit effectively addresses and resolves the identified issues by:\n1. Correcting the comparison logic in the `test_single_named_value` method to ensure accurate test results.\n2. Adjusting the instance verification logic in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to use the correct assertion type (`assertNotIsInstance`).\n\nThese changes ensure that the tests can accurately and reliably validate the code under test, maintaining the robustness and reliability of the overall codebase."
  },
  "Explain": "### Summary of the Issue\nThe issue centers around inaccurate assertions in the test cases for named data in the `datadriventests_ddt` codebase. Specifically, there are two main problems:\n1. **Reversed Comparison Logic:** In the `test_single_named_value` method, the comparison logic is reversed, leading to incorrect results.\n2. **Incorrect Instance Verification:** In the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, the test assertions incorrectly use `assertIsInstance` in both branches of an if-else statement, which results in misleading test outcomes.\n\n### Summary of the Commit\nThe commit addresses the issue by making specific changes to the test file `tests/test_named_data.py` to correct the assertions:\n1. **Correcting the Comparison Logic:** The comparison logic in the `test_single_named_value` method is corrected to ensure that the values are compared correctly.\n2. **Fixing Instance Verification:** The logic for verifying class instances is corrected in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods. The correct assertion `assertNotIsInstance` is used when verifying values that should not be instances of a specific class.\n\n### Explanation of the Solution\n#### Problem 1: Incorrect Comparison Logic\nThe `test_single_named_value` method previously had a comparison that was reversed. This means it was checking if `value1` was greater than `value2` when it should have been doing the opposite.\n\n**Cause**: The reversed comparison led to potentially incorrect test results, causing the test to pass or fail incorrectly based on flawed logic.\n\n**Solution**: The commit corrects the comparison so that the method now accurately checks if `value2` is greater than `value1`. This ensures that the test reflects the intended logic and produces accurate results. By swapping the positions of the values being compared, the test can now correctly determine the relationship between them.\n\n#### Problem 2: Incorrect Instance Verification\nIn the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, assertions for verifying instance types were incorrectly using the same assertion (`assertIsInstance`) in both the `if` and `else` branches of conditionals. This led to incorrect verification of instances, causing misleading results.\n\n**Cause**: Using `assertIsInstance` in both branches meant that the tests could not correctly differentiate between cases where the value should be an instance of a specific class and cases where it should not. This led to incorrect test passes or failures.\n\n**Solution**: The commit changes the assertion in the `else` branch from `assertIsInstance` to `assertNotIsInstance`. This ensures that when the condition is not met (`passes` is `False`), the test correctly verifies that the value is not an instance of the specified class (`NonTrivialClass`). By making this change, the tests can now accurately check the instance type based on the condition, leading to reliable and meaningful test results.\n\n### Conclusion\nThe commit effectively addresses and resolves the identified issues by:\n1. Correcting the comparison logic in the `test_single_named_value` method to ensure accurate test results.\n2. Adjusting the instance verification logic in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to use the correct assertion type (`assertNotIsInstance`).\n\nThese changes ensure that the tests can accurately and reliably validate the code under test, maintaining the robustness and reliability of the overall codebase.",
  "Time": "2024-02-26",
  "Difficulty": "Medium",
  "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.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(value1, value2) \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.assertIsInstance(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.assertIsInstance(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_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -11,7 +11,7 @@\n         ['Single', 0, 1]\n     )\n     def test_single_named_value(self, value1, value2):\n-        self.assertGreater(value1, value2) \n+        self.assertGreater(value2, value1)\n \n     @ddt.named_data(\n         ['1st', 1, 2],\n@@ -42,7 +42,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -52,7 +52,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
  "BuggyCodeLocation": [
    {
      "file": "datadriventests_ddt/test/test_named_data.py",
      "function": null,
      "content_all": {
        "11": "        ['Single', 0, 1]\n",
        "14": "        self.assertGreater(value1, value2) \n",
        "15": "\n",
        "16": "    @ddt.named_data(\n",
        "17": "        ['1st', 1, 2],\n",
        "45": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
        "46": "\n",
        "47": "    @ddt.named_data(\n",
        "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n",
        "55": "            self.assertIsInstance(value, self.NonTrivialClass)\n"
      },
      "content_change": {
        "14": "        self.assertGreater(value1, value2) \n",
        "45": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
        "55": "            self.assertIsInstance(value, self.NonTrivialClass)\n"
      }
    }
  ],
  "Source": "Human",
  "Command": [
    "python -m unittest discover -s test/"
  ],
  "Token": 1359,
  "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_named_data.py",
      "content": "1 import ddt\n2 import unittest\n3 \n4 \n5 @ddt.ddt\n6 class TestNamedData(unittest.TestCase):\n7     class NonTrivialClass(object):\n8         pass\n9 \n10     @ddt.named_data(\n11         ['Single', 0, 1]\n12     )\n13     def test_single_named_value(self, value1, value2):\n14         self.assertGreater(value1, value2) \n15 \n16     @ddt.named_data(\n17         ['1st', 1, 2],\n18         ('2nd', 3, 4)\n19     )\n20     def test_multiple_named_value_seqs(self, value1, value2):\n21         self.assertGreater(value2, value1)\n22 \n23     @ddt.named_data(\n24         dict(name='1st', value2=1, value1=0),\n25         {'name': '2nd', 'value2': 1, 'value1': 0}\n26     )\n27     def test_multiple_named_value_dicts(self, value1, value2):\n28         self.assertGreater(value2, value1)\n29 \n30     @ddt.named_data(\n31         dict(name='1st', value2=1, value1=0),\n32         ('2nd', 0, 1)\n33     )\n34     def test_multiple_named_value_mixed(self, value1, value2):\n35         self.assertGreater(value2, value1)\n36 \n37     @ddt.named_data(\n38         ['Passes', NonTrivialClass(), True],\n39         ('Fails', 1, False)\n40     )\n41     def test_seq_with_nontrivial_type(self, value, passes):\n42         if passes:\n43             self.assertIsInstance(value, self.NonTrivialClass)\n44         else:\n45             self.assertIsInstance(value, self.NonTrivialClass)\n46 \n47     @ddt.named_data(\n48         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n49         {'name': 'Fails', 'value': 1, 'passes': False}\n50     )\n51     def test_dict_with_nontrivial_type(self, value, passes):\n52         if passes:\n53             self.assertIsInstance(value, self.NonTrivialClass)\n54         else:\n55             self.assertIsInstance(value, self.NonTrivialClass)\n56 \n57     def test_missing_name_dict(self):\n58         with self.assertRaises(KeyError):\n59             @ddt.named_data(\n60                 {'not_a_name': 'oops', 'value': 1}\n61             )\n62             def _internal_test(value):\n63                 pass"
    },
    {
      "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 __i(...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  (...truncated)"
    },
    {
      "path": "datadriventests_ddt/docs/example.rst",
      "content": "1 Example usage\n2 =============\n3 \n4 DDT consists of a class decorator ``ddt`` (for your ``TestCase`` subclass)\n5 and two method decorators (for your tests that want to be multiplied):\n6 \n7 * ``data``: contai(...truncated)"
    }
  ],
  "TokenAll": 18977,
  "FilteredLevel": 1500,
  "Results": {
    "model": "GPT-4o",
    "Difficulty": "Medium",
    "issue_origin": {
      "title": "Potential false positive in test_seq_with_nontrivial_type",
      "description": "In the function test_seq_with_nontrivial_type in 'datadriventests_ddt/test/test_named_data.py', line 45, there's a possibility of incorrectly asserting an instance type. The `else` block is currently asserting the same type as the `then` block (`self.NonTrivialClass`). This could lead to a false positive in the test case. Please ensure the `else` block checks for the correct type or raises an appropriate exception.",
      "explanation": "### Issue Summary:\nThe issue titled \"Potential false positive in test_seq_with_nontrivial_type\" indicates that in the function `test_seq_with_nontrivial_type` found in `'datadriventests_ddt/test/test_named_data.py'`, specifically at line 45, there is a potential for a false positive when asserting instance types. The problem arises because both the `if` and `else` blocks are checking for the same type, `self.NonTrivialClass`. This means that even if the test should fail, it may pass incorrectly, thus producing a false positive result in the test.\n\n### Code Analysis:\nThe relevant section of the code where the issue exists looks like this:\n```python\n37 @ddt.named_data(\n38     ['Passes', NonTrivialClass(), True],\n39     ('Fails', 1, False)\n40 )\n41 def test_seq_with_nontrivial_type(self, value, passes):\n42     if passes:\n43         self.assertIsInstance(value, self.NonTrivialClass)\n44     else:\n45         self.assertIsInstance(value, self.NonTrivialClass)\n```\nHere, the issue is in lines 43 and 45, where the else clause should check for an incorrect type or raise an appropriate exception instead of checking for `self.NonTrivialClass`.\n\n### Explanation of the Commit:\nThe commit aimed at resolving this issue might look like this:\n```diff\n37 @ddt.named_data(\n38     ['Passes', NonTrivialClass(), True],\n39     ('Fails', 1, False)\n40 )\n41 def test_seq_with_nontrivial_type(self, value, passes):\n42     if passes:\n43         self.assertIsInstance(value, self.NonTrivialClass)\n44     else:\n-         self.assertIsInstance(value, self.NonTrivialClass)\n+         self.assertNotIsInstance(value, self.NonTrivialClass)\n```\nIn this modification, the `else` block on line 45 has been changed to `self.assertNotIsInstance(value, self.NonTrivialClass)`. \n\n### Detailed Explanation:\n1. **Understanding the Functionality**:\n   - The function `test_seq_with_nontrivial_type` tests sequences where some elements can have a \"non-trivial\" type (in this case, `NonTrivialClass`). \n   - The test is parameterized with `named_data`, which provides different combinations of inputs to the test in a structured way.\n   - The test expects certain values to be instances of `NonTrivialClass` (when `passes` is `True`) and others not to be instances of this class (when `passes` is `False`).\n\n2. **The Issue**:\n   - Initially, both the `if` and `else` blocks were checking `assertIsInstance(value, self.NonTrivialClass)`.\n   - This would incorrectly pass the test in either case, if `value` is an instance of `NonTrivialClass`, leading to a situation where the `else` branch does not serve its intended purpose.\n\n3. **Commit Changes**:\n   - The commit fixes the issue by changing the `else` block to check `self.assertNotIsInstance(value, self.NonTrivialClass)`.\n   - This modification ensures that when `passes` is `False`, the test asserts that `value` should not be an instance of `NonTrivialClass`.\n   - Hence, if a non-instance value (like an integer `1`) is passed in the test, the else block will correctly assert that this is not an instance of `NonTrivialClass`.\n\n4. **Explanation of the Fix**:\n   - The `assertIsInstance()` method checks if the first parameter is an instance of the second parameter (a class or type).\n   - Conversely, `assertNotIsInstance()` checks if the first parameter is not an instance of the second parameter.\n   - By using `assertNotIsInstance` in the else block, the test now correctly checks for non-instance values, which aligns with the expected behavior identified by the boolean `passes`.\n\n5. **Outcome**:\n   - This change eliminates the potential for false positives in the test. If `value` should not be an instance of `NonTrivialClass` (as indicated by `passes` being `False`), the test will correctly assert this.\n   - Therefore, any incorrect assumptions about the type of `value` will be caught, and the test will fail as expected, ensuring robustness of the tests.\n\nIn summary, the commit addresses the possibility of false positives by ensuring that the `else` block asserts the correct type check (`assertNotIsInstance`). This prevents erroneous passing results when `value` is not supposed to be an instance of `NonTrivialClass`, maintaining the integrity of the test suite."
    },
    "issue_message": {
      "title": "Incorrect Assert Statement",
      "description": "The test case test_single_named_value in test_named_data.py fails because the assertion self.assertGreater(value1, value2) is incorrect for the provided values (0, 1). Update the test data to ensure value1 is greater than value2 or modify the assertion logic to match the intended behavior.",
      "explanation": "### Summary of the Issue\n\nThe given issue revolves around the failure of an assertion in the `test_single_named_value` test case in the `test_named_data.py` file. Specifically, the assertion statement `self.assertGreater(value1, value2)` is failing for the provided test data `(0, 1)`, as `0` is not greater than `1`. The task is to either update the test data to ensure `value1` is greater than `value2` or to modify the assertion logic to align with the intended behavior.\n\n### Content of the Commit\n\nLet's assume a commit has been made with the following modifications to address the issue:\n\n#### Modified `test_named_data.py`\n```python\n1 import ddt\n2 import unittest\n3 \n4 \n5 @ddt.ddt\n6 class TestNamedData(unittest.TestCase):\n7     class NonTrivialClass(object):\n8         pass\n9 \n10     @ddt.named_data(\n11         ['Single', 2, 1]\n12     )\n13     def test_single_named_value(self, value1, value2):\n14         self.assertGreater(value1, value2)\n15 \n16     @ddt.named_data(\n17         ['1st', 1, 2],\n18         ('2nd', 3, 4)\n19     )\n20     def test_multiple_named_value_seqs(self, value1, value2):\n21         self.assertGreater(value2, value1)\n22 \n23     @ddt.named_data(\n24         dict(name='1st', value2=1, value1=0),\n25         {'name': '2nd', 'value2': 1, 'value1': 0}\n26     )\n27     def test_multiple_named_value_dicts(self, value1, value2):\n28         self.assertGreater(value2, value1)\n29 \n30     @ddt.named_data(\n31         dict(name='1st', value2=1, value1=0),\n32         ('2nd', 0, 1)\n33     )\n34     def test_multiple_named_value_mixed(self, value1, value2):\n35         self.assertGreater(value2, value1)\n36 \n37     @ddt.named_data(\n38         ['Passes', NonTrivialClass(), True],\n39         ('Fails', 1, False)\n40     )\n41     def test_seq_with_nontrivial_type(self, value, passes):\n42         if passes:\n43             self.assertIsInstance(value, self.NonTrivialClass)\n44         else:\n45             self.assertNotIsInstance(value, self.NonTrivialClass)\n46 \n47     @ddt.named_data(\n48         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n49         {'name': 'Fails', 'value': 1, 'passes': False}\n50     )\n51     def test_dict_with_nontrivial_type(self, value, passes):\n52         if passes:\n53             self.assertIsInstance(value, self.NonTrivialClass)\n54         else:\n55             self.assertNotIsInstance(value, self.NonTrivialClass)\n56 \n57     def test_missing_name_dict(self):\n58         with self.assertRaises(KeyError):\n59             @ddt.named_data(\n60                 {'not_a_name': 'oops', 'value': 1}\n61             )\n62             def _internal_test(value):\n63                 pass\n```\n\n### Explanation of How the Commit Solves the Issue\n\n1. **Updating the Test Data in `test_single_named_value`**:\n   - **Original Data**: The test case `test_single_named_value` originally used the data `['Single', 0, 1]`.\n   - **Reason for Failure**: The assertion `self.assertGreater(value1, value2)` expects `value1` to be greater than `value2`. However, `0` is not greater than `1`, causing the test to fail.\n   - **Commit Change**: The data is updated to `['Single', 2, 1]`. Now `value1 = 2` and `value2 = 1`, hence `2 > 1` holds true.\n\n2. **Adjustment in Assertion Statements in Other Test Cases**:\n   - While the primary issue was in `test_single_named_value`, worth noting are related assertion logic adjustments in other tests:\n     - Example: In `test_seq_with_nontrivial_type`, `self.assertNotIsInstance` is used instead of repeating `self.assertIsInstance`.\n\n3. **Modifying the Related Data and Logic**:\n   - Ensured similar updates and corrections are applied to other test cases where necessary, maintaining consistency.\n\nBy updating `test_single_named_value` with appropriate data where `value1` is greater than `value2`, the test now correctly validates the intended behavior using `self.assertGreater`. This change directly addresses and resolves the error `AssertionError: 0"
    },
    "issue_ground": {
      "title": "Inaccurate Assertions in Test Cases for Named Data",
      "description": "### Description\nThere are inaccurate assertions in the test cases for named data, which lead to incorrect test results. Specifically, two test cases are using 'assertIsInstance' to verify instances of a class where 'assertNotIsInstance' should be used. Furthermore, the comparison logic in another test case is reversed, potentially causing false positives.\n\n### Issues Detected\n1. **test_single_named_value Method:** The comparison logic is reversed, potentially leading to inaccurate results. It asserts `self.assertGreater(value1, value2)` when it should assert the opposite.\n2. **test_seq_with_nontrivial_type and test_dict_with_nontrivial_type Methods:** These tests verify class instances incorrectly using `assertIsInstance` in both branches of an if-else statement, causing incorrect pass/fail results.\n\n### Impact\nThese issues result in misleading test outcomes, where tests may pass or fail incorrectly based on flawed assertions. Accurate testing is crucial for maintaining the robustness and reliability of the codebase.\n\n### Proposed Solution\n- Reverse the comparison in the `test_single_named_value` method to correctly evaluate `self.assertGreater(value2, value1)`.\n- Update the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to correctly use `assertNotIsInstance` in the 'else' clauses.\n\nResolving these issues will ensure that the test cases accurately validate the code under test, leading to more reliable and meaningful test results.",
      "explanation": "### Summary of the Issue\n\nThe main issue pertains to inaccuracies in the test cases for named data within the file `test_named_data.py`. There are three specific problems identified:\n\n1. **test_single_named_value Method:** The comparison logic in the assertion is reversed. The assertion currently checks `self.assertGreater(value1, value2)` which is incorrect based on the data provided, resulting in failed tests.\n   \n2. **test_seq_with_nontrivial_type and test_dict_with_nontrivial_type Methods:** These methods incorrectly use `assertIsInstance` for both the `if` and `else` branches. The `else` branches should instead use `assertNotIsInstance` to ensure the values are not instances of a specific class when expected not to be. This current setup causes false test outcomes.\n\n### Detailed Content of the Commit\n\nHere's a summary of the changes proposed to solve the issues:\n\n1. **test_single_named_value Method:** Change the assertion to compare `value2` and `value1` correctly.\n   ```python\n   self.assertGreater(value2, value1)\n   ```\n\n2. **test_seq_with_nontrivial_type and test_dict_with_nontrivial_type Methods:** Use `assertNotIsInstance` in the `else` branches to correctly validate that the given values are not instances of the `NonTrivialClass`.\n   ```python\n   # For test_seq_with_nontrivial_type method\n   if passes:\n       self.assertIsInstance(value, self.NonTrivialClass)\n   else:\n       self.assertNotIsInstance(value, self.NonTrivialClass)\n   \n   # For test_dict_with_nontrivial_type method\n   if passes:\n       self.assertIsInstance(value, self.NonTrivialClass)\n   else:\n       self.assertNotIsInstance(value, self.NonTrivialClass)\n   ```\n\n### Explanation of How the Commit Solves the Issue\n\n1. **Correcting the Comparison Logic in `test_single_named_value`:**\n\n   The previous logic was:\n   ```python\n   self.assertGreater(value1, value2)\n   ```\n   which tested if `value1` is greater than `value2`. Given the data `['Single', 0, 1]`, this test would fail because 0 is not greater than 1. By changing the logic to:\n   ```python\n   self.assertGreater(value2, value1)\n   ```\n   the test now correctly verifies that 1 is greater than 0, thereby passing the test.\n\n2. **Using `assertNotIsInstance` in `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type`:**\n\n   The issue arises from both the `if` and `else` branches using `assertIsInstance`, which is incorrect:\n   ```python\n   if passes:\n       self.assertIsInstance(value, self.NonTrivialClass)\n   else:\n       self.assertIsInstance(value, self.NonTrivialClass)\n   ```\n   For the values that should not be instances of `NonTrivialClass`, the `else` branch should employ `assertNotIsInstance`:\n   ```python\n   if passes:\n       self.assertIsInstance(value, self.NonTrivialClass)\n   else:\n       self.assertNotIsInstance(value, self.NonTrivialClass)\n   ```\n   This modification correctly identifies whether the value is or is not an instance of `NonTrivialClass`, yielding accurate test outcomes.\n\n### Conclusion\n\nThis commit resolves the inaccuracies in the named data test cases by addressing logical mistakes in comparisons and instance checks:\n\n1. **Reversing the comparison in `test_single_named_value` to accurately reflect the intended checks.**\n2. **Utilizing `assertNotIsInstance` for values that should not be instances of a specified class, thus validating the correctness of the tests in `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type`.**\n\nBy making these changes, the tests will now accurately reflect the expected outcomes, ensuring the reliability and accuracy of the testing framework."
    },
    "issue_ground_truth": {
      "title": "Inaccurate Assertions in Test Cases for Named Data",
      "description": "### Description\nThere are inaccurate assertions in the test cases for named data, which lead to incorrect test results. Specifically, two test cases are using 'assertIsInstance' to verify instances of a class where 'assertNotIsInstance' should be used. Furthermore, the comparison logic in another test case is reversed, potentially causing false positives.\n\n### Issues Detected\n1. **test_single_named_value Method:** The comparison logic is reversed, potentially leading to inaccurate results. It asserts `self.assertGreater(value1, value2)` when it should assert the opposite.\n2. **test_seq_with_nontrivial_type and test_dict_with_nontrivial_type Methods:** These tests verify class instances incorrectly using `assertIsInstance` in both branches of an if-else statement, causing incorrect pass/fail results.\n\n### Impact\nThese issues result in misleading test outcomes, where tests may pass or fail incorrectly based on flawed assertions. Accurate testing is crucial for maintaining the robustness and reliability of the codebase.\n\n### Proposed Solution\n- Reverse the comparison in the `test_single_named_value` method to correctly evaluate `self.assertGreater(value2, value1)`.\n- Update the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to correctly use `assertNotIsInstance` in the 'else' clauses.\n\nResolving these issues will ensure that the test cases accurately validate the code under test, leading to more reliable and meaningful test results.",
      "explanation": "### Summary of the Issue\nThe issue centers around inaccurate assertions in the test cases for named data in the `datadriventests_ddt` codebase. Specifically, there are two main problems:\n1. **Reversed Comparison Logic:** In the `test_single_named_value` method, the comparison logic is reversed, leading to incorrect results.\n2. **Incorrect Instance Verification:** In the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, the test assertions incorrectly use `assertIsInstance` in both branches of an if-else statement, which results in misleading test outcomes.\n\n### Summary of the Commit\nThe commit addresses the issue by making specific changes to the test file `tests/test_named_data.py` to correct the assertions:\n1. **Correcting the Comparison Logic:** The comparison logic in the `test_single_named_value` method is corrected to ensure that the values are compared correctly.\n2. **Fixing Instance Verification:** The logic for verifying class instances is corrected in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods. The correct assertion `assertNotIsInstance` is used when verifying values that should not be instances of a specific class.\n\n### Explanation of the Solution\n#### Problem 1: Incorrect Comparison Logic\nThe `test_single_named_value` method previously had a comparison that was reversed. This means it was checking if `value1` was greater than `value2` when it should have been doing the opposite.\n\n**Cause**: The reversed comparison led to potentially incorrect test results, causing the test to pass or fail incorrectly based on flawed logic.\n\n**Solution**: The commit corrects the comparison so that the method now accurately checks if `value2` is greater than `value1`. This ensures that the test reflects the intended logic and produces accurate results. By swapping the positions of the values being compared, the test can now correctly determine the relationship between them.\n\n#### Problem 2: Incorrect Instance Verification\nIn the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, assertions for verifying instance types were incorrectly using the same assertion (`assertIsInstance`) in both the `if` and `else` branches of conditionals. This led to incorrect verification of instances, causing misleading results.\n\n**Cause**: Using `assertIsInstance` in both branches meant that the tests could not correctly differentiate between cases where the value should be an instance of a specific class and cases where it should not. This led to incorrect test passes or failures.\n\n**Solution**: The commit changes the assertion in the `else` branch from `assertIsInstance` to `assertNotIsInstance`. This ensures that when the condition is not met (`passes` is `False`), the test correctly verifies that the value is not an instance of the specified class (`NonTrivialClass`). By making this change, the tests can now accurately check the instance type based on the condition, leading to reliable and meaningful test results.\n\n### Conclusion\nThe commit effectively addresses and resolves the identified issues by:\n1. Correcting the comparison logic in the `test_single_named_value` method to ensure accurate test results.\n2. Adjusting the instance verification logic in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to use the correct assertion type (`assertNotIsInstance`).\n\nThese changes ensure that the tests can accurately and reliably validate the code under test, maintaining the robustness and reliability of the overall codebase."
    },
    "location_origin": [
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "41": "test_seq_with_nontrivial_type"
        },
        "content_all": {
          "38": "        ['Passes', NonTrivialClass(), True],",
          "39": "        ('Fails', 1, False)",
          "40": "    )",
          "41": "    def test_seq_with_nontrivial_type(self, value, passes):",
          "42": "        if passes:",
          "43": "            self.assertIsInstance(value, self.NonTrivialClass)",
          "44": "        else:",
          "45": "            self.assertIsInstance(value, self.NonTrivialClass)",
          "46": "",
          "47": "    @ddt.named_data(",
          "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},",
          "49": "        {'name': 'Fails', 'value': 1, 'passes': False}"
        },
        "content_change": {
          "45": "            self.assertNotIsInstance(value, self.NonTrivialClass)"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "51": "test_dict_with_nontrivial_type"
        },
        "content_all": {
          "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},",
          "49": "        {'name': 'Fails', 'value': 1, 'passes': False}",
          "50": "    )",
          "51": "    def test_dict_with_nontrivial_type(self, value, passes):",
          "52": "        if passes:",
          "53": "            self.assertIsInstance(value, self.NonTrivialClass)",
          "54": "        else:",
          "55": "            self.assertIsInstance(value, self.NonTrivialClass)",
          "56": "",
          "57": "    def test_missing_name_dict(self):",
          "58": "        with self.assertRaises(KeyError):",
          "59": "            @ddt.named_data("
        },
        "content_change": {
          "55": "            self.assertNotIsInstance(value, self.NonTrivialClass)"
        }
      }
    ],
    "location_message": [
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "13": "test_single_named_value"
        },
        "content_all": {
          "10": "    @ddt.named_data(\n",
          "11": "        ['Single', 0, 1]\n",
          "12": "    )\n",
          "13": "    def test_single_named_value(self, value1, value2):\n",
          "14": "        self.assertGreater(value1, value2) \n",
          "15": " ",
          "16": "    @ddt.named_data(\n"
        },
        "content_change": {
          "11": "        ['Single', 2, 1]\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "41": "test_seq_with_nontrivial_type"
        },
        "content_all": {
          "38": "    @ddt.named_data(\n",
          "39": "        ['Passes', NonTrivialClass(), True],\n",
          "40": "        ('Fails', 1, False)\n",
          "41": "    )\n",
          "42": "    def test_seq_with_nontrivial_type(self, value, passes):\n",
          "43": "        if passes:\n",
          "44": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "45": "        else:\n",
          "46": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        },
        "content_change": {
          "45": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "51": "test_dict_with_nontrivial_type"
        },
        "content_all": {
          "47": "    @ddt.named_data(\n",
          "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n",
          "49": "        {'name': 'Fails', 'value': 1, 'passes': False}\n",
          "50": "    )\n",
          "51": "    def test_dict_with_nontrivial_type(self, value, passes):\n",
          "52": "        if passes:\n",
          "53": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "54": "        else:\n",
          "55": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        },
        "content_change": {
          "55": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        }
      }
    ],
    "location_ground": [
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "13": "test_single_named_value"
        },
        "content_all": {
          "10": "    @ddt.named_data(\n",
          "11": "        ['Single', 0, 1]\n",
          "12": "    )\n",
          "13": "    def test_single_named_value(self, value1, value2):\n",
          "14": "        self.assertGreater(value1, value2)\n",
          "15": "\n",
          "16": "    @ddt.named_data(\n"
        },
        "content_change": {
          "14": "        self.assertGreater(value2, value1)\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "41": "test_seq_with_nontrivial_type"
        },
        "content_all": {
          "38": "        ['Passes', NonTrivialClass(), True],\n",
          "39": "        ('Fails', 1, False)\n",
          "40": "    )\n",
          "41": "    def test_seq_with_nontrivial_type(self, value, passes):\n",
          "42": "        if passes:\n",
          "43": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "44": "        else:\n",
          "45": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "46": "\n",
          "47": "    @ddt.named_data(\n"
        },
        "content_change": {
          "45": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "51": "test_dict_with_nontrivial_type"
        },
        "content_all": {
          "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n",
          "49": "        {'name': 'Fails', 'value': 1, 'passes': False}\n",
          "50": "    )\n",
          "51": "    def test_dict_with_nontrivial_type(self, value, passes):\n",
          "52": "        if passes:\n",
          "53": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "54": "        else:\n",
          "55": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "56": "\n",
          "57": "    def test_missing_name_dict(self):\n"
        },
        "content_change": {
          "55": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        }
      }
    ],
    "location_ground_exp": [
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "13": "test_single_named_value"
        },
        "content_all": {
          "10": "    @ddt.named_data(\n",
          "11": "        ['Single', 0, 1]\n",
          "12": "    )\n",
          "13": "    def test_single_named_value(self, value1, value2):\n",
          "14": "        self.assertGreater(value1, value2)\n",
          "15": "    \n",
          "16": "    @ddt.named_data(\n"
        },
        "content_change": {
          "14": "        self.assertGreater(value2, value1)\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "41": "test_seq_with_nontrivial_type"
        },
        "content_all": {
          "37": "    @ddt.named_data(\n",
          "38": "        ['Passes', NonTrivialClass(), True],\n",
          "39": "         ('Fails', 1, False)\n",
          "40": "    )\n",
          "41": "    def test_seq_with_nontrivial_type(self, value, passes):\n",
          "42": "        if passes:\n",
          "43": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "44": "        else:\n",
          "45": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "46": "    \n"
        },
        "content_change": {
          "45": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        }
      },
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": {
          "51": "test_dict_with_nontrivial_type"
        },
        "content_all": {
          "47": "    @ddt.named_data(\n",
          "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n",
          "49": "        {'name': 'Fails', 'value': 1, 'passes': False}\n",
          "50": "    )\n",
          "51": "    def test_dict_with_nontrivial_type(self, value, passes):\n",
          "52": "        if passes:\n",
          "53": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "54": "        else:\n",
          "55": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "56": "    \n"
        },
        "content_change": {
          "55": "            self.assertNotIsInstance(value, self.NonTrivialClass)\n"
        }
      }
    ],
    "location_ground_truth": [
      {
        "file": "datadriventests_ddt/test/test_named_data.py",
        "function": null,
        "content_all": {
          "11": "        ['Single', 0, 1]\n",
          "14": "        self.assertGreater(value1, value2) \n",
          "15": "\n",
          "16": "    @ddt.named_data(\n",
          "17": "        ['1st', 1, 2],\n",
          "45": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "46": "\n",
          "47": "    @ddt.named_data(\n",
          "48": "        {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n",
          "55": "            self.assertIsInstance(value, self.NonTrivialClass)\n"
        },
        "content_change": {
          "14": "        self.assertGreater(value1, value2) \n",
          "45": "            self.assertIsInstance(value, self.NonTrivialClass)\n",
          "55": "            self.assertIsInstance(value, self.NonTrivialClass)\n"
        }
      }
    ],
    "patch_i": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -41,7 +41,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -52,7 +52,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
    "patch_im": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -10,7 +10,7 @@\n     @ddt.named_data(\n-        ['Single', 0, 1]\n+        ['Single', 2, 1]\n     )\n     def test_single_named_value(self, value1, value2):\n         self.assertGreater(value1, value2) \n",
    "patch_il": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -45,7 +45,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -55,7 +55,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
    "patch_iml": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -11,7 +11,7 @@\n     @ddt.named_data(\n-        ['Single', 0, 1]\n+        ['Single', 2, 1]\n     )\n     def test_single_named_value(self, value1, value2):\n         self.assertGreater(value1, value2)\n@@ -45,7 +45,7 @@\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -55,7 +55,7 @@\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
    "patch_ground": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -13,7 +13,7 @@\n     ) \n     def test_single_named_value(self, value1, value2):\n-        self.assertGreater(value1, value2) \n+        self.assertGreater(value2, value1) \n \n     @ddt.named_data(\n         ['1st', 1, 2],\n@@ -42,7 +42,7 @@\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -54,7 +54,7 @@\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
    "patch_ground_location": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -13,7 +13,7 @@\n     def test_single_named_value(self, value1, value2):\n-        self.assertGreater(value1, value2)\n+        self.assertGreater(value2, value1)\n \n@@ -43,7 +43,7 @@\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n@@ -53,7 +53,7 @@\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n",
    "patch_ground_exp": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -13,7 +13,7 @@\n     def test_single_named_value(self, value1, value2):\n-        self.assertGreater(value1, value2)\n+        self.assertGreater(value2, value1)\n\n     @ddt.named_data(\n         ['1st', 1, 2],\n@@ -45,7 +45,7 @@\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -55,7 +55,7 @@\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n\n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
    "patch_ground_all": "\n--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -11,7 +11,7 @@\n         ['Single', 0, 1]\n     )\n     def test_single_named_value(self, value1, value2):\n-        self.assertGreater(value1, value2) \n+        self.assertGreater(value2, value1) \n \n     @ddt.named_data(\n         ['1st', 1, 2],\n@@ -45,7 +45,7 @@\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n             self.assertIsInstance(value, self.NonTrivialClass)\n \n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n         {'name': 'Fails', 'value': 1, 'passes': False}\n@@ -53,7 +53,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n@@ -47,9 +47,9 @@\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@@ -55,11 +55,11 @@\n         \n            self.assertIsInstance(value, self.NonTrivialClass)\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",
    "patch_ground_truth": "--- a/datadriventests_ddt/test/test_named_data.py\n+++ b/datadriventests_ddt/test/test_named_data.py\n@@ -11,7 +11,7 @@\n         ['Single', 0, 1]\n     )\n     def test_single_named_value(self, value1, value2):\n-        self.assertGreater(value1, value2) \n+        self.assertGreater(value2, value1)\n \n     @ddt.named_data(\n         ['1st', 1, 2],\n@@ -42,7 +42,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     @ddt.named_data(\n         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n@@ -52,7 +52,7 @@\n         if passes:\n             self.assertIsInstance(value, self.NonTrivialClass)\n         else:\n-            self.assertIsInstance(value, self.NonTrivialClass)\n+            self.assertNotIsInstance(value, self.NonTrivialClass)\n \n     def test_missing_name_dict(self):\n         with self.assertRaises(KeyError):\n",
    "message": "======================================================================\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----------------------------------------------------------------------\nRan 89 tests in 0.005s\n\nFAILED (failures=3)",
    "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_named_data.py",
        "content": "1 import ddt\n2 import unittest\n3 \n4 \n5 @ddt.ddt\n6 class TestNamedData(unittest.TestCase):\n7     class NonTrivialClass(object):\n8         pass\n9 \n10     @ddt.named_data(\n11         ['Single', 0, 1]\n12     )\n13     def test_single_named_value(self, value1, value2):\n14         self.assertGreater(value1, value2) \n15 \n16     @ddt.named_data(\n17         ['1st', 1, 2],\n18         ('2nd', 3, 4)\n19     )\n20     def test_multiple_named_value_seqs(self, value1, value2):\n21         self.assertGreater(value2, value1)\n22 \n23     @ddt.named_data(\n24         dict(name='1st', value2=1, value1=0),\n25         {'name': '2nd', 'value2': 1, 'value1': 0}\n26     )\n27     def test_multiple_named_value_dicts(self, value1, value2):\n28         self.assertGreater(value2, value1)\n29 \n30     @ddt.named_data(\n31         dict(name='1st', value2=1, value1=0),\n32         ('2nd', 0, 1)\n33     )\n34     def test_multiple_named_value_mixed(self, value1, value2):\n35         self.assertGreater(value2, value1)\n36 \n37     @ddt.named_data(\n38         ['Passes', NonTrivialClass(), True],\n39         ('Fails', 1, False)\n40     )\n41     def test_seq_with_nontrivial_type(self, value, passes):\n42         if passes:\n43             self.assertIsInstance(value, self.NonTrivialClass)\n44         else:\n45             self.assertIsInstance(value, self.NonTrivialClass)\n46 \n47     @ddt.named_data(\n48         {'name': 'Passes', 'value': NonTrivialClass(), 'passes': True},\n49         {'name': 'Fails', 'value': 1, 'passes': False}\n50     )\n51     def test_dict_with_nontrivial_type(self, value, passes):\n52         if passes:\n53             self.assertIsInstance(value, self.NonTrivialClass)\n54         else:\n55             self.assertIsInstance(value, self.NonTrivialClass)\n56 \n57     def test_missing_name_dict(self):\n58         with self.assertRaises(KeyError):\n59             @ddt.named_data(\n60                 {'not_a_name': 'oops', 'value': 1}\n61             )\n62             def _internal_test(value):\n63                 pass"
      },
      {
        "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 __i(...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  (...truncated)"
      },
      {
        "path": "datadriventests_ddt/docs/example.rst",
        "content": "1 Example usage\n2 =============\n3 \n4 DDT consists of a class decorator ``ddt`` (for your ``TestCase`` subclass)\n5 and two method decorators (for your tests that want to be multiplied):\n6 \n7 * ``data``: contai(...truncated)"
      }
    ],
    "CommitSHA": "5b4fec6152fd6be880c42f01213685a1a835720a"
  },
  "Score": {
    "Difficulty": "Medium",
    "issue_origin": {
      "Title": 6,
      "Description": 5,
      "Reproducibility": 4,
      "Relevance": 6,
      "Explanation": 8,
      "Overall": 6
    },
    "issue_message": {
      "Title": 5,
      "Description": 6,
      "Reproducibility": 4,
      "Relevance": 7,
      "Explanation": 6,
      "Overall": 6
    },
    "issue_ground": {
      "Title": 9,
      "Description": 7,
      "Reproducibility": 6,
      "Relevance": 8,
      "Explanation": 8,
      "Overall": 8
    },
    "issue_ground_truth": {
      "title": "Inaccurate Assertions in Test Cases for Named Data",
      "description": "### Description\nThere are inaccurate assertions in the test cases for named data, which lead to incorrect test results. Specifically, two test cases are using 'assertIsInstance' to verify instances of a class where 'assertNotIsInstance' should be used. Furthermore, the comparison logic in another test case is reversed, potentially causing false positives.\n\n### Issues Detected\n1. **test_single_named_value Method:** The comparison logic is reversed, potentially leading to inaccurate results. It asserts `self.assertGreater(value1, value2)` when it should assert the opposite.\n2. **test_seq_with_nontrivial_type and test_dict_with_nontrivial_type Methods:** These tests verify class instances incorrectly using `assertIsInstance` in both branches of an if-else statement, causing incorrect pass/fail results.\n\n### Impact\nThese issues result in misleading test outcomes, where tests may pass or fail incorrectly based on flawed assertions. Accurate testing is crucial for maintaining the robustness and reliability of the codebase.\n\n### Proposed Solution\n- Reverse the comparison in the `test_single_named_value` method to correctly evaluate `self.assertGreater(value2, value1)`.\n- Update the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to correctly use `assertNotIsInstance` in the 'else' clauses.\n\nResolving these issues will ensure that the test cases accurately validate the code under test, leading to more reliable and meaningful test results.",
      "explanation": "### Summary of the Issue\nThe issue centers around inaccurate assertions in the test cases for named data in the `datadriventests_ddt` codebase. Specifically, there are two main problems:\n1. **Reversed Comparison Logic:** In the `test_single_named_value` method, the comparison logic is reversed, leading to incorrect results.\n2. **Incorrect Instance Verification:** In the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, the test assertions incorrectly use `assertIsInstance` in both branches of an if-else statement, which results in misleading test outcomes.\n\n### Summary of the Commit\nThe commit addresses the issue by making specific changes to the test file `tests/test_named_data.py` to correct the assertions:\n1. **Correcting the Comparison Logic:** The comparison logic in the `test_single_named_value` method is corrected to ensure that the values are compared correctly.\n2. **Fixing Instance Verification:** The logic for verifying class instances is corrected in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods. The correct assertion `assertNotIsInstance` is used when verifying values that should not be instances of a specific class.\n\n### Explanation of the Solution\n#### Problem 1: Incorrect Comparison Logic\nThe `test_single_named_value` method previously had a comparison that was reversed. This means it was checking if `value1` was greater than `value2` when it should have been doing the opposite.\n\n**Cause**: The reversed comparison led to potentially incorrect test results, causing the test to pass or fail incorrectly based on flawed logic.\n\n**Solution**: The commit corrects the comparison so that the method now accurately checks if `value2` is greater than `value1`. This ensures that the test reflects the intended logic and produces accurate results. By swapping the positions of the values being compared, the test can now correctly determine the relationship between them.\n\n#### Problem 2: Incorrect Instance Verification\nIn the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods, assertions for verifying instance types were incorrectly using the same assertion (`assertIsInstance`) in both the `if` and `else` branches of conditionals. This led to incorrect verification of instances, causing misleading results.\n\n**Cause**: Using `assertIsInstance` in both branches meant that the tests could not correctly differentiate between cases where the value should be an instance of a specific class and cases where it should not. This led to incorrect test passes or failures.\n\n**Solution**: The commit changes the assertion in the `else` branch from `assertIsInstance` to `assertNotIsInstance`. This ensures that when the condition is not met (`passes` is `False`), the test correctly verifies that the value is not an instance of the specified class (`NonTrivialClass`). By making this change, the tests can now accurately check the instance type based on the condition, leading to reliable and meaningful test results.\n\n### Conclusion\nThe commit effectively addresses and resolves the identified issues by:\n1. Correcting the comparison logic in the `test_single_named_value` method to ensure accurate test results.\n2. Adjusting the instance verification logic in the `test_seq_with_nontrivial_type` and `test_dict_with_nontrivial_type` methods to use the correct assertion type (`assertNotIsInstance`).\n\nThese changes ensure that the tests can accurately and reliably validate the code under test, maintaining the robustness and reliability of the overall codebase."
    }
  }
}