diff options
Diffstat (limited to 'setuptools/tests')
| -rw-r--r-- | setuptools/tests/test_dist.py | 1 | ||||
| -rw-r--r-- | setuptools/tests/test_easy_install.py | 83 | 
2 files changed, 78 insertions, 6 deletions
| diff --git a/setuptools/tests/test_dist.py b/setuptools/tests/test_dist.py index 435ffec0..c4c9bd03 100644 --- a/setuptools/tests/test_dist.py +++ b/setuptools/tests/test_dist.py @@ -39,6 +39,7 @@ def test_dist_fetch_build_egg(tmpdir):      '''.split()      with tmpdir.as_cwd():          dist = Distribution() +        dist.parse_config_files()          resolved_dists = [              dist.fetch_build_egg(r)              for r in reqs diff --git a/setuptools/tests/test_easy_install.py b/setuptools/tests/test_easy_install.py index 617ee489..1d3390c5 100644 --- a/setuptools/tests/test_easy_install.py +++ b/setuptools/tests/test_easy_install.py @@ -381,7 +381,15 @@ class TestSetupRequires:                  """))])              yield dist_path -    def test_setup_requires_overrides_version_conflict(self): +    use_setup_cfg = ( +        (), +        ('dependency_links',), +        ('setup_requires',), +        ('dependency_links', 'setup_requires'), +    ) + +    @pytest.mark.parametrize('use_setup_cfg', use_setup_cfg) +    def test_setup_requires_overrides_version_conflict(self, use_setup_cfg):          """          Regression test for distribution issue 323:          https://bitbucket.org/tarek/distribute/issues/323 @@ -397,7 +405,7 @@ class TestSetupRequires:          with contexts.save_pkg_resources_state():              with contexts.tempdir() as temp_dir: -                test_pkg = create_setup_requires_package(temp_dir) +                test_pkg = create_setup_requires_package(temp_dir, use_setup_cfg=use_setup_cfg)                  test_setup_py = os.path.join(test_pkg, 'setup.py')                  with contexts.quiet() as (stdout, stderr):                      # Don't even need to install the package, just @@ -408,7 +416,8 @@ class TestSetupRequires:                  assert len(lines) > 0                  assert lines[-1].strip() == 'test_pkg' -    def test_setup_requires_override_nspkg(self): +    @pytest.mark.parametrize('use_setup_cfg', use_setup_cfg) +    def test_setup_requires_override_nspkg(self, use_setup_cfg):          """          Like ``test_setup_requires_overrides_version_conflict`` but where the          ``setup_requires`` package is part of a namespace package that has @@ -446,7 +455,8 @@ class TestSetupRequires:                  """)                  test_pkg = create_setup_requires_package( -                    temp_dir, 'foo.bar', '0.2', make_nspkg_sdist, template) +                    temp_dir, 'foo.bar', '0.2', make_nspkg_sdist, template, +                    use_setup_cfg=use_setup_cfg)                  test_setup_py = os.path.join(test_pkg, 'setup.py') @@ -464,6 +474,38 @@ class TestSetupRequires:                  assert len(lines) > 0                  assert lines[-1].strip() == 'test_pkg' +    @pytest.mark.parametrize('use_setup_cfg', use_setup_cfg) +    def test_setup_requires_with_attr_version(self, use_setup_cfg): +        def make_dependency_sdist(dist_path, distname, version): +            make_sdist(dist_path, [ +                ('setup.py', +                 DALS(""" +                      import setuptools +                      setuptools.setup( +                          name={name!r}, +                          version={version!r}, +                          py_modules=[{name!r}], +                      ) +                      """.format(name=distname, version=version))), +                (distname + '.py', +                 DALS(""" +                      version = 42 +                      """ +                     ))]) +        with contexts.save_pkg_resources_state(): +            with contexts.tempdir() as temp_dir: +                test_pkg = create_setup_requires_package( +                    temp_dir, setup_attrs=dict(version='attr: foobar.version'), +                    make_package=make_dependency_sdist, +                    use_setup_cfg=use_setup_cfg+('version',), +                ) +                test_setup_py = os.path.join(test_pkg, 'setup.py') +                with contexts.quiet() as (stdout, stderr): +                    run_setup(test_setup_py, ['--version']) +                lines = stdout.readlines() +                assert len(lines) > 0 +                assert lines[-1].strip() == '42' +  def make_trivial_sdist(dist_path, distname, version):      """ @@ -532,7 +574,8 @@ def make_sdist(dist_path, files):  def create_setup_requires_package(path, distname='foobar', version='0.1',                                    make_package=make_trivial_sdist, -                                  setup_py_template=None): +                                  setup_py_template=None, setup_attrs={}, +                                  use_setup_cfg=()):      """Creates a source tree under path for a trivial test package that has a      single requirement in setup_requires--a tarball for that requirement is      also created and added to the dependency_links argument. @@ -547,11 +590,39 @@ def create_setup_requires_package(path, distname='foobar', version='0.1',          'setup_requires': ['%s==%s' % (distname, version)],          'dependency_links': [os.path.abspath(path)]      } +    test_setup_attrs.update(setup_attrs)      test_pkg = os.path.join(path, 'test_pkg') -    test_setup_py = os.path.join(test_pkg, 'setup.py')      os.mkdir(test_pkg) +    if use_setup_cfg: +        test_setup_cfg = os.path.join(test_pkg, 'setup.cfg') +        options = [] +        metadata = [] +        for name in use_setup_cfg: +            value = test_setup_attrs.pop(name) +            if name in 'name version'.split(): +                section = metadata +            else: +                section = options +            if isinstance(value, (tuple, list)): +                value = ';'.join(value) +            section.append('%s: %s' % (name, value)) +        with open(test_setup_cfg, 'w') as f: +            f.write(DALS( +                """ +                [metadata] +                {metadata} +                [options] +                {options} +                """ +            ).format( +                options='\n'.join(options), +                metadata='\n'.join(metadata), +            )) + +    test_setup_py = os.path.join(test_pkg, 'setup.py') +      if setup_py_template is None:          setup_py_template = DALS("""\              import setuptools | 
