Make "certifi" optional on py34.
This commit is contained in:
parent
dcd1ef81df
commit
fe9037a189
8
setup.py
8
setup.py
|
@ -35,6 +35,7 @@ from distutils.core import Extension
|
|||
# no compiler is available.
|
||||
from distutils.command.build_ext import build_ext
|
||||
|
||||
|
||||
class custom_build_ext(build_ext):
|
||||
"""Allow C extension building to fail.
|
||||
|
||||
|
@ -120,9 +121,14 @@ if (platform.python_implementation() == 'CPython' and
|
|||
|
||||
if setuptools is not None:
|
||||
# If setuptools is not available, you're on your own for dependencies.
|
||||
install_requires = ['certifi']
|
||||
install_requires = []
|
||||
if sys.version_info < (3, 2):
|
||||
install_requires.append('backports.ssl_match_hostname')
|
||||
if sys.version_info < (3, 4):
|
||||
# Certifi is also optional on 2.7.9+, although making our dependencies
|
||||
# conditional on micro version numbers seems like a bad idea
|
||||
# until we have more declarative metadata.
|
||||
install_requires.append('certifi')
|
||||
kwargs['install_requires'] = install_requires
|
||||
|
||||
setup(
|
||||
|
|
|
@ -18,7 +18,6 @@
|
|||
|
||||
from __future__ import absolute_import, division, print_function, with_statement
|
||||
|
||||
import certifi
|
||||
import errno
|
||||
import os
|
||||
import sys
|
||||
|
@ -36,6 +35,14 @@ except ImportError:
|
|||
# ssl is not available on Google App Engine
|
||||
ssl = None
|
||||
|
||||
try:
|
||||
import certifi
|
||||
except ImportError:
|
||||
# certifi is optional as long as we have ssl.create_default_context.
|
||||
if not hasattr(ssl, 'create_default_context'):
|
||||
raise
|
||||
certifi = None
|
||||
|
||||
try:
|
||||
xrange # py2
|
||||
except NameError:
|
||||
|
|
|
@ -234,7 +234,10 @@ class _HTTPConnection(httputil.HTTPMessageDelegate):
|
|||
ssl_options["cert_reqs"] = ssl.CERT_REQUIRED
|
||||
if self.request.ca_certs is not None:
|
||||
ssl_options["ca_certs"] = self.request.ca_certs
|
||||
else:
|
||||
elif not hasattr(ssl, 'create_default_context'):
|
||||
# When create_default_context is present,
|
||||
# we can omit the "ca_certs" parameter entirely,
|
||||
# which avoids the dependency on "certifi" for py34.
|
||||
ssl_options["ca_certs"] = _default_ca_certs()
|
||||
if self.request.client_key is not None:
|
||||
ssl_options["keyfile"] = self.request.client_key
|
||||
|
|
|
@ -10,7 +10,6 @@ from tornado.stack_context import NullContext
|
|||
from tornado.testing import AsyncHTTPTestCase, AsyncHTTPSTestCase, AsyncTestCase, bind_unused_port, ExpectLog, gen_test
|
||||
from tornado.test.util import unittest, skipIfNonUnix, refusing_port
|
||||
from tornado.web import RequestHandler, Application
|
||||
import certifi
|
||||
import errno
|
||||
import logging
|
||||
import os
|
||||
|
|
|
@ -192,9 +192,6 @@ class SimpleHTTPClientTestMixin(object):
|
|||
response = self.wait()
|
||||
response.rethrow()
|
||||
|
||||
def test_default_certificates_exist(self):
|
||||
open(_default_ca_certs()).close()
|
||||
|
||||
def test_gzip(self):
|
||||
# All the tests in this file should be using gzip, but this test
|
||||
# ensures that it is in fact getting compressed.
|
||||
|
|
Loading…
Reference in New Issue