Import only modules and update tox.ini
As stated in the OpenStack Hacking Guidelines, it is prefered that only modules should be imported. Also updated tox.ini to ignore opestack/common among others. Change-Id: I2f0a603c31052eadee581c11880c0ec6bd392829
This commit is contained in:
parent
71d8528364
commit
997c12d3ab
@ -23,7 +23,7 @@ from oslo_utils import importutils
|
|||||||
from oslo_utils import netutils
|
from oslo_utils import netutils
|
||||||
import requests
|
import requests
|
||||||
try:
|
try:
|
||||||
from requests.packages.urllib3.exceptions import ProtocolError
|
ProtocolError = requests.packages.urllib3.exceptions.ProtocolError
|
||||||
except ImportError:
|
except ImportError:
|
||||||
ProtocolError = requests.exceptions.ConnectionError
|
ProtocolError = requests.exceptions.ConnectionError
|
||||||
import six
|
import six
|
||||||
@ -42,7 +42,7 @@ if not hasattr(parse, 'parse_qsl'):
|
|||||||
from oslo_utils import encodeutils
|
from oslo_utils import encodeutils
|
||||||
|
|
||||||
from glanceclient.common import https
|
from glanceclient.common import https
|
||||||
from glanceclient.common.utils import safe_header
|
from glanceclient.common import utils
|
||||||
from glanceclient import exc
|
from glanceclient import exc
|
||||||
|
|
||||||
osprofiler_web = importutils.try_import("osprofiler.web")
|
osprofiler_web = importutils.try_import("osprofiler.web")
|
||||||
@ -167,7 +167,7 @@ class HTTPClient(_BaseHTTPClient):
|
|||||||
headers.update(self.session.headers)
|
headers.update(self.session.headers)
|
||||||
|
|
||||||
for (key, value) in six.iteritems(headers):
|
for (key, value) in six.iteritems(headers):
|
||||||
header = '-H \'%s: %s\'' % safe_header(key, value)
|
header = '-H \'%s: %s\'' % utils.safe_header(key, value)
|
||||||
curl.append(header)
|
curl.append(header)
|
||||||
|
|
||||||
if not self.session.verify:
|
if not self.session.verify:
|
||||||
@ -193,7 +193,7 @@ class HTTPClient(_BaseHTTPClient):
|
|||||||
status = (resp.raw.version / 10.0, resp.status_code, resp.reason)
|
status = (resp.raw.version / 10.0, resp.status_code, resp.reason)
|
||||||
dump = ['\nHTTP/%.1f %s %s' % status]
|
dump = ['\nHTTP/%.1f %s %s' % status]
|
||||||
headers = resp.headers.items()
|
headers = resp.headers.items()
|
||||||
dump.extend(['%s: %s' % safe_header(k, v) for k, v in headers])
|
dump.extend(['%s: %s' % utils.safe_header(k, v) for k, v in headers])
|
||||||
dump.append('')
|
dump.append('')
|
||||||
content_type = resp.headers.get('Content-Type')
|
content_type = resp.headers.get('Content-Type')
|
||||||
|
|
||||||
|
@ -47,11 +47,10 @@ try:
|
|||||||
else:
|
else:
|
||||||
raise ImportError
|
raise ImportError
|
||||||
except ImportError:
|
except ImportError:
|
||||||
try:
|
from OpenSSL import SSL
|
||||||
from httplib import HTTPSConnection
|
from six.moves import http_client
|
||||||
except ImportError:
|
HTTPSConnection = http_client.HTTPSConnection
|
||||||
from http.client import HTTPSConnection
|
Connection = SSL.Connection
|
||||||
from OpenSSL.SSL import Connection as Connection
|
|
||||||
|
|
||||||
|
|
||||||
from glanceclient import exc
|
from glanceclient import exc
|
||||||
|
@ -25,7 +25,6 @@ import getpass
|
|||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
from os.path import expanduser
|
|
||||||
import sys
|
import sys
|
||||||
import traceback
|
import traceback
|
||||||
|
|
||||||
@ -551,7 +550,7 @@ class OpenStackImagesShell(object):
|
|||||||
return client
|
return client
|
||||||
|
|
||||||
def _cache_schemas(self, options, home_dir='~/.glanceclient'):
|
def _cache_schemas(self, options, home_dir='~/.glanceclient'):
|
||||||
homedir = expanduser(home_dir)
|
homedir = os.path.expanduser(home_dir)
|
||||||
if not os.path.exists(homedir):
|
if not os.path.exists(homedir):
|
||||||
try:
|
try:
|
||||||
os.makedirs(homedir)
|
os.makedirs(homedir)
|
||||||
|
@ -16,8 +16,8 @@
|
|||||||
import testtools
|
import testtools
|
||||||
|
|
||||||
from glanceclient import client
|
from glanceclient import client
|
||||||
from glanceclient.v1 import client as v1
|
from glanceclient import v1
|
||||||
from glanceclient.v2 import client as v2
|
from glanceclient import v2
|
||||||
|
|
||||||
|
|
||||||
class ClientTest(testtools.TestCase):
|
class ClientTest(testtools.TestCase):
|
||||||
@ -28,19 +28,19 @@ class ClientTest(testtools.TestCase):
|
|||||||
def test_endpoint(self):
|
def test_endpoint(self):
|
||||||
gc = client.Client(1, "http://example.com")
|
gc = client.Client(1, "http://example.com")
|
||||||
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
||||||
self.assertIsInstance(gc, v1.Client)
|
self.assertIsInstance(gc, v1.client.Client)
|
||||||
|
|
||||||
def test_versioned_endpoint(self):
|
def test_versioned_endpoint(self):
|
||||||
gc = client.Client(1, "http://example.com/v2")
|
gc = client.Client(1, "http://example.com/v2")
|
||||||
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
||||||
self.assertIsInstance(gc, v1.Client)
|
self.assertIsInstance(gc, v1.client.Client)
|
||||||
|
|
||||||
def test_versioned_endpoint_no_version(self):
|
def test_versioned_endpoint_no_version(self):
|
||||||
gc = client.Client(endpoint="http://example.com/v2")
|
gc = client.Client(endpoint="http://example.com/v2")
|
||||||
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
||||||
self.assertIsInstance(gc, v2.Client)
|
self.assertIsInstance(gc, v2.client.Client)
|
||||||
|
|
||||||
def test_versioned_endpoint_with_minor_revision(self):
|
def test_versioned_endpoint_with_minor_revision(self):
|
||||||
gc = client.Client(2.2, "http://example.com/v2.1")
|
gc = client.Client(2.2, "http://example.com/v2.1")
|
||||||
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
self.assertEqual("http://example.com", gc.http_client.endpoint)
|
||||||
self.assertIsInstance(gc, v2.Client)
|
self.assertIsInstance(gc, v2.client.Client)
|
||||||
|
@ -29,8 +29,9 @@ import threading
|
|||||||
from glanceclient.common import http
|
from glanceclient.common import http
|
||||||
from glanceclient.common import https
|
from glanceclient.common import https
|
||||||
|
|
||||||
from glanceclient import Client
|
|
||||||
from glanceclient import exc
|
from glanceclient import exc
|
||||||
|
from glanceclient import v1
|
||||||
|
from glanceclient import v2
|
||||||
|
|
||||||
if six.PY3 is True:
|
if six.PY3 is True:
|
||||||
import socketserver
|
import socketserver
|
||||||
@ -90,9 +91,9 @@ class TestHTTPSVerifyCert(testtools.TestCase):
|
|||||||
url = 'https://0.0.0.0:%d' % port
|
url = 'https://0.0.0.0:%d' % port
|
||||||
|
|
||||||
try:
|
try:
|
||||||
client = Client('1', url,
|
client = v1.client.Client(url,
|
||||||
insecure=False,
|
insecure=False,
|
||||||
ssl_compression=True)
|
ssl_compression=True)
|
||||||
client.images.get('image123')
|
client.images.get('image123')
|
||||||
self.fail('No SSL exception raised')
|
self.fail('No SSL exception raised')
|
||||||
except exc.CommunicationError as e:
|
except exc.CommunicationError as e:
|
||||||
@ -107,9 +108,9 @@ class TestHTTPSVerifyCert(testtools.TestCase):
|
|||||||
url = 'https://0.0.0.0:%d' % port
|
url = 'https://0.0.0.0:%d' % port
|
||||||
|
|
||||||
try:
|
try:
|
||||||
client = Client('1', url,
|
client = v1.client.Client(url,
|
||||||
insecure=False,
|
insecure=False,
|
||||||
ssl_compression=False)
|
ssl_compression=False)
|
||||||
client.images.get('image123')
|
client.images.get('image123')
|
||||||
self.fail('No SSL exception raised')
|
self.fail('No SSL exception raised')
|
||||||
except SSL.Error as e:
|
except SSL.Error as e:
|
||||||
@ -124,9 +125,9 @@ class TestHTTPSVerifyCert(testtools.TestCase):
|
|||||||
url = 'https://0.0.0.0:%d' % port
|
url = 'https://0.0.0.0:%d' % port
|
||||||
|
|
||||||
try:
|
try:
|
||||||
gc = Client('2', url,
|
gc = v2.client.Client(url,
|
||||||
insecure=False,
|
insecure=False,
|
||||||
ssl_compression=True)
|
ssl_compression=True)
|
||||||
gc.images.get('image123')
|
gc.images.get('image123')
|
||||||
self.fail('No SSL exception raised')
|
self.fail('No SSL exception raised')
|
||||||
except exc.CommunicationError as e:
|
except exc.CommunicationError as e:
|
||||||
@ -141,9 +142,9 @@ class TestHTTPSVerifyCert(testtools.TestCase):
|
|||||||
url = 'https://0.0.0.0:%d' % port
|
url = 'https://0.0.0.0:%d' % port
|
||||||
|
|
||||||
try:
|
try:
|
||||||
gc = Client('2', url,
|
gc = v2.client.Client(url,
|
||||||
insecure=False,
|
insecure=False,
|
||||||
ssl_compression=False)
|
ssl_compression=False)
|
||||||
gc.images.get('image123')
|
gc.images.get('image123')
|
||||||
self.fail('No SSL exception raised')
|
self.fail('No SSL exception raised')
|
||||||
except SSL.Error as e:
|
except SSL.Error as e:
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
from jsonpatch import JsonPatch
|
import jsonpatch
|
||||||
import testtools
|
import testtools
|
||||||
import warlock
|
import warlock
|
||||||
|
|
||||||
@ -61,7 +61,8 @@ _SCHEMA = schemas.Schema({
|
|||||||
|
|
||||||
def compare_json_patches(a, b):
|
def compare_json_patches(a, b):
|
||||||
"""Return 0 if a and b describe the same JSON patch."""
|
"""Return 0 if a and b describe the same JSON patch."""
|
||||||
return JsonPatch.from_string(a) == JsonPatch.from_string(b)
|
return(jsonpatch.JsonPatch.from_string(a) ==
|
||||||
|
jsonpatch.JsonPatch.from_string(b))
|
||||||
|
|
||||||
|
|
||||||
class TestSchemaProperty(testtools.TestCase):
|
class TestSchemaProperty(testtools.TestCase):
|
||||||
|
@ -19,7 +19,7 @@ import six
|
|||||||
import six.moves.urllib.parse as urlparse
|
import six.moves.urllib.parse as urlparse
|
||||||
import testtools
|
import testtools
|
||||||
|
|
||||||
from glanceclient.v2.schemas import Schema
|
from glanceclient.v2 import schemas
|
||||||
|
|
||||||
|
|
||||||
class FakeAPI(object):
|
class FakeAPI(object):
|
||||||
@ -68,7 +68,7 @@ class FakeAPI(object):
|
|||||||
class FakeSchemaAPI(FakeAPI):
|
class FakeSchemaAPI(FakeAPI):
|
||||||
def get(self, *args, **kwargs):
|
def get(self, *args, **kwargs):
|
||||||
_, raw_schema = self._request('GET', *args, **kwargs)
|
_, raw_schema = self._request('GET', *args, **kwargs)
|
||||||
return Schema(raw_schema)
|
return schemas.Schema(raw_schema)
|
||||||
|
|
||||||
|
|
||||||
class RawRequest(object):
|
class RawRequest(object):
|
||||||
|
@ -15,8 +15,8 @@
|
|||||||
|
|
||||||
from glanceclient.common import http
|
from glanceclient.common import http
|
||||||
from glanceclient.common import utils
|
from glanceclient.common import utils
|
||||||
from glanceclient.v1.image_members import ImageMemberManager
|
from glanceclient.v1 import image_members
|
||||||
from glanceclient.v1.images import ImageManager
|
from glanceclient.v1 import images
|
||||||
|
|
||||||
|
|
||||||
class Client(object):
|
class Client(object):
|
||||||
@ -33,5 +33,5 @@ class Client(object):
|
|||||||
"""Initialize a new client for the Images v1 API."""
|
"""Initialize a new client for the Images v1 API."""
|
||||||
endpoint, self.version = utils.endpoint_version_from_url(endpoint, 1.0)
|
endpoint, self.version = utils.endpoint_version_from_url(endpoint, 1.0)
|
||||||
self.http_client = http.get_http_client(endpoint=endpoint, **kwargs)
|
self.http_client = http.get_http_client(endpoint=endpoint, **kwargs)
|
||||||
self.images = ImageManager(self.http_client)
|
self.images = images.ImageManager(self.http_client)
|
||||||
self.image_members = ImageMemberManager(self.http_client)
|
self.image_members = image_members.ImageMemberManager(self.http_client)
|
||||||
|
@ -18,20 +18,20 @@ import sys
|
|||||||
from glanceclient.common import progressbar
|
from glanceclient.common import progressbar
|
||||||
from glanceclient.common import utils
|
from glanceclient.common import utils
|
||||||
from glanceclient import exc
|
from glanceclient import exc
|
||||||
from glanceclient.v2.image_members import MEMBER_STATUS_VALUES
|
from glanceclient.v2 import image_members
|
||||||
from glanceclient.v2 import images
|
from glanceclient.v2 import images
|
||||||
from glanceclient.v2 import tasks
|
from glanceclient.v2 import tasks
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
from os.path import expanduser
|
|
||||||
|
|
||||||
|
MEMBER_STATUS_VALUES = image_members.MEMBER_STATUS_VALUES
|
||||||
IMAGE_SCHEMA = None
|
IMAGE_SCHEMA = None
|
||||||
|
|
||||||
|
|
||||||
def get_image_schema():
|
def get_image_schema():
|
||||||
global IMAGE_SCHEMA
|
global IMAGE_SCHEMA
|
||||||
if IMAGE_SCHEMA is None:
|
if IMAGE_SCHEMA is None:
|
||||||
schema_path = expanduser("~/.glanceclient/image_schema.json")
|
schema_path = os.path.expanduser("~/.glanceclient/image_schema.json")
|
||||||
if os.path.isfile(schema_path):
|
if os.path.isfile(schema_path):
|
||||||
with open(schema_path, "r") as f:
|
with open(schema_path, "r") as f:
|
||||||
schema_raw = f.read()
|
schema_raw = f.read()
|
||||||
@ -394,7 +394,8 @@ NAMESPACE_SCHEMA = None
|
|||||||
def get_namespace_schema():
|
def get_namespace_schema():
|
||||||
global NAMESPACE_SCHEMA
|
global NAMESPACE_SCHEMA
|
||||||
if NAMESPACE_SCHEMA is None:
|
if NAMESPACE_SCHEMA is None:
|
||||||
schema_path = expanduser("~/.glanceclient/namespace_schema.json")
|
schema_path = os.path.expanduser("~/.glanceclient/"
|
||||||
|
"namespace_schema.json")
|
||||||
if os.path.isfile(schema_path):
|
if os.path.isfile(schema_path):
|
||||||
with open(schema_path, "r") as f:
|
with open(schema_path, "r") as f:
|
||||||
schema_raw = f.read()
|
schema_raw = f.read()
|
||||||
@ -533,7 +534,8 @@ RESOURCE_TYPE_SCHEMA = None
|
|||||||
def get_resource_type_schema():
|
def get_resource_type_schema():
|
||||||
global RESOURCE_TYPE_SCHEMA
|
global RESOURCE_TYPE_SCHEMA
|
||||||
if RESOURCE_TYPE_SCHEMA is None:
|
if RESOURCE_TYPE_SCHEMA is None:
|
||||||
schema_path = expanduser("~/.glanceclient/resource_type_schema.json")
|
schema_path = os.path.expanduser("~/.glanceclient/"
|
||||||
|
"resource_type_schema.json")
|
||||||
if os.path.isfile(schema_path):
|
if os.path.isfile(schema_path):
|
||||||
with open(schema_path, "r") as f:
|
with open(schema_path, "r") as f:
|
||||||
schema_raw = f.read()
|
schema_raw = f.read()
|
||||||
|
8
tox.ini
8
tox.ini
@ -37,7 +37,6 @@ downloadcache = ~/cache/pip
|
|||||||
|
|
||||||
[flake8]
|
[flake8]
|
||||||
# H233 Python 3.x incompatible use of print operator
|
# H233 Python 3.x incompatible use of print operator
|
||||||
# H302 import only modules
|
|
||||||
# H303 no wildcard import
|
# H303 no wildcard import
|
||||||
# H404 multi line docstring should start with a summary
|
# H404 multi line docstring should start with a summary
|
||||||
|
|
||||||
@ -49,6 +48,9 @@ downloadcache = ~/cache/pip
|
|||||||
# H238 old style class declaration, use new style (inherit from `object`)
|
# H238 old style class declaration, use new style (inherit from `object`)
|
||||||
# E128 continuation line under-indented for visual indent
|
# E128 continuation line under-indented for visual indent
|
||||||
|
|
||||||
ignore = F403,F812,F821,H233,H302,H303,H404,E265,H405,E123,H238,E128
|
ignore = F403,F812,F821,H233,H303,H404,E265,H405,E123,H238,E128
|
||||||
show-source = True
|
show-source = True
|
||||||
exclude = .venv,.tox,dist,*egg,build
|
exclude = .venv*,.tox,dist,*egg,build,.git,doc,*openstack/common*,*lib/python*,.update-venv
|
||||||
|
|
||||||
|
[hacking]
|
||||||
|
import_exceptions = six.moves
|
||||||
|
Loading…
x
Reference in New Issue
Block a user