Skip to content

Commit

Permalink
Resolved merge conflicts from master
Browse files Browse the repository at this point in the history
  • Loading branch information
wjdecorte committed Aug 13, 2019
2 parents 896fbb4 + 80cf6fe commit 55efe33
Show file tree
Hide file tree
Showing 16 changed files with 703 additions and 571 deletions.
22 changes: 22 additions & 0 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
repos:
- repo: https://github.com/ambv/black
rev: stable
hooks:
- id: black
language_version: python3

- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v2.2.3
hooks:
- id: trailing-whitespace
- id: end-of-file-fixer
- id: check-docstring-first
- id: check-json
- id: check-added-large-files
- id: check-yaml
- id: debug-statements

- repo: https://gitlab.com/pycqa/flake8
rev: 3.7.1
hooks:
- id: flake8
12 changes: 11 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -279,4 +279,14 @@ increasing the performance of the query especially for large data sets.
from pydruid.client import PyDruid

query = PyDruid(druid_url_goes_here, 'druid/v2', extra_headers={"Accept-Encoding": "gzip"})
```
```


# Contributing

Contributions are welcomed of course. We like to use `black` and `flake8`.

```bash
pip install -r requirements-dev.txt # installs useful dev deps
pre-commit install # installs useful commit hooks
```
14 changes: 9 additions & 5 deletions pydruid/async_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
from tornado import gen
from tornado.httpclient import AsyncHTTPClient, HTTPError
except ImportError:
print('Warning: unable to import Tornado. The asynchronous client will not work.')
print("Warning: unable to import Tornado. The asynchronous client will not work.")


class AsyncPyDruid(BaseDruidClient):
Expand Down Expand Up @@ -110,7 +110,8 @@ def _post(self, query):
try:
headers, querystr, url = self._prepare_url_headers_and_body(query)
response = yield http_client.fetch(
url, method='POST', headers=headers, body=querystr)
url, method="POST", headers=headers, body=querystr
)
except HTTPError as e:
self.__handle_http_error(e, query)
else:
Expand All @@ -127,9 +128,12 @@ def __handle_http_error(e, query):
except ValueError:
pass
else:
err = err.get('error', None)
raise IOError('{0} \n Druid Error: {1} \n Query is: {2}'.format(
e, err, json.dumps(query.query_dict, indent=4)))
err = err.get("error", None)
raise IOError(
"{0} \n Druid Error: {1} \n Query is: {2}".format(
e, err, json.dumps(query.query_dict, indent=4)
)
)

@gen.coroutine
def topn(self, **kwargs):
Expand Down
32 changes: 20 additions & 12 deletions pydruid/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ def decompress(data):


# extract error from the <PRE> tag inside the HTML response
HTML_ERROR = re.compile('<pre>\s*(.*?)\s*</pre>', re.IGNORECASE)
HTML_ERROR = re.compile("<pre>\\s*(.*?)\\s*</pre>", re.IGNORECASE)


class BaseDruidClient(object):
Expand All @@ -66,18 +66,18 @@ def set_proxies(self, proxies):
urllib.request.install_opener(opener)

def _prepare_url_headers_and_body(self, query):
querystr = json.dumps(query.query_dict).encode('utf-8')
if self.url.endswith('/'):
querystr = json.dumps(query.query_dict).encode("utf-8")
if self.url.endswith("/"):
url = self.url + self.endpoint
else:
url = self.url + '/' + self.endpoint
headers = {'Content-Type': 'application/json'}
url = self.url + "/" + self.endpoint
headers = {"Content-Type": "application/json"}
if self.extra_headers and isinstance(self.extra_headers, dict):
headers.update(self.extra_headers)
if (self.username is not None) and (self.password is not None):
authstring = '{}:{}'.format(self.username, self.password)
authstring = "{}:{}".format(self.username, self.password)
b64string = b64encode(authstring.encode()).decode()
headers['Authorization'] = 'Basic {}'.format(b64string)
headers["Authorization"] = "Basic {}".format(b64string)

return headers, querystr, url

Expand Down Expand Up @@ -468,7 +468,8 @@ def export_tsv(self, dest_path):
"""
if self.query_builder.last_query is None:
raise AttributeError(
"There was no query executed by this client yet. Can't export!")
"There was no query executed by this client yet. Can't export!"
)
else:
return self.query_builder.last_query.export_tsv(dest_path)

Expand All @@ -481,7 +482,8 @@ def export_pandas(self):
"""
if self.query_builder.last_query is None:
raise AttributeError(
"There was no query executed by this client yet. Can't export!")
"There was no query executed by this client yet. Can't export!"
)
else:
return self.query_builder.last_query.export_pandas()

Expand Down Expand Up @@ -586,12 +588,18 @@ def _post(self, query):
except (ValueError, AttributeError, KeyError):
pass

raise IOError('{0} \n Druid Error: {1} \n Query is: {2}'.format(
e, err, json.dumps(
raise IOError(
"{0} \n Druid Error: {1} \n Query is: {2}".format(
e,
err,
json.dumps(
query.query_dict,
indent=4,
sort_keys=True,
separators=(',', ': '))))
separators=(",", ": "),
),
)
)
else:
query.parse(data)
return query
Expand Down
Loading

0 comments on commit 55efe33

Please sign in to comment.