From 8242bed8de51935105db53ad7c9b68bcc1b32aff Mon Sep 17 00:00:00 2001 From: Jon Banafato Date: Fri, 29 Jan 2016 08:03:02 -0500 Subject: [PATCH] Add coverage to tox Add the ``coverage`` plugin to ``nosetests`` commands run by ``tox``. References #277. Additionally, add a few more compatibility imports. --- dev-only.txt | 1 + hyde/_compat.py | 4 ++++ hyde/ext/publishers/pypi.py | 16 +++++++--------- tox.ini | 2 +- 4 files changed, 13 insertions(+), 10 deletions(-) diff --git a/dev-only.txt b/dev-only.txt index 082d587..0a5af65 100644 --- a/dev-only.txt +++ b/dev-only.txt @@ -1,3 +1,4 @@ +coverage>=4.0.3, <5.0 pyquery>=1.2.9, <2.0 docutils>=0.12, <1.0 mock>=1.0.1, <2.0 diff --git a/hyde/_compat.py b/hyde/_compat.py index 60d7f62..8ec03e4 100644 --- a/hyde/_compat.py +++ b/hyde/_compat.py @@ -12,7 +12,9 @@ PY3 = sys.version_info.major == 3 if PY3: # Imports that have moved. from collections import UserDict # NOQA + import configparser # NOQA from functools import reduce # NOQA + from http.client import HTTPConnection, HTTPSConnection # NOQA from http.server import HTTPServer, SimpleHTTPRequestHandler # NOQA from io import StringIO # NOQA from urllib import parse # NOQA @@ -43,7 +45,9 @@ if PY3: else: # Imports that have moved. from itertools import ifilter as filter, izip as zip # NOQA + import ConfigParser as configparser # NOQA reduce = reduce + from httplib import HTTPConnection, HTTPSConnection # NOQA from BaseHTTPServer import HTTPServer # NOQA from SimpleHTTPServer import SimpleHTTPRequestHandler # NOQA from cStringIO import StringIO # NOQA diff --git a/hyde/ext/publishers/pypi.py b/hyde/ext/publishers/pypi.py index d3bb2f8..ed0f60c 100644 --- a/hyde/ext/publishers/pypi.py +++ b/hyde/ext/publishers/pypi.py @@ -8,12 +8,10 @@ import os import getpass import zipfile import tempfile -import httplib -import urlparse from base64 import standard_b64encode -import ConfigParser -from hyde._compat import input +from hyde._compat import (configparser, input, HTTPConnection, HTTPSConnection, + parse) from hyde.publisher import Publisher from commando.util import getLoggerWithNullHandler @@ -35,10 +33,10 @@ class PyPI(Publisher): if not os.path.isfile(pypirc_file): pypirc = None else: - pypirc = ConfigParser.RawConfigParser() + pypirc = configparser.Rawconfigparser() pypirc.read([pypirc_file]) missing_errs = ( - ConfigParser.NoSectionError, ConfigParser.NoOptionError) + configparser.NoSectionError, configparser.NoOptionError) # Try to find username in .pypirc if self.username is None: if pypirc is not None: @@ -104,11 +102,11 @@ class PyPI(Publisher): content_length = len(body_prefix) + tf.tell() + len(body_suffix) # POST it up to PyPI logger.info("uploading to PyPI") - url = urlparse.urlparse(self.url) + url = parse.urlparse(self.url) if url.scheme == "https": - con = httplib.HTTPSConnection(url.netloc) + con = HTTPSConnection(url.netloc) else: - con = httplib.HTTPConnection(url.netloc) + con = HTTPConnection(url.netloc) con.connect() try: con.putrequest("POST", self.url) diff --git a/tox.ini b/tox.ini index 71d358d..ad25265 100644 --- a/tox.ini +++ b/tox.ini @@ -8,7 +8,7 @@ sitepackages = True # Needed for asciidoc passenv = PYTHONPATH deps = -r{toxinidir}/dev-req.txt -commands = nosetests {posargs} +commands = nosetests --with-coverage --cover-package=hyde --cover-erase {posargs} [testenv:pep8] deps = flake8