Skip to content

Commit

Permalink
DEVELOP-1339 - update codebase to be python 3.6-compatible, updating …
Browse files Browse the repository at this point in the history
…some vulnerable packages and implement mocking of the Redis client along the way
  • Loading branch information
mariya committed Oct 4, 2021
1 parent 2c0fbe1 commit b599b4d
Show file tree
Hide file tree
Showing 14 changed files with 427 additions and 139 deletions.
1 change: 1 addition & 0 deletions .python-version
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
3.6.12
2 changes: 1 addition & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
language: python

python:
- "3.5"
- "3.6.12"

before_install:
- sudo python -m pip install pipenv
Expand Down
7 changes: 4 additions & 3 deletions Pipfile
Original file line number Diff line number Diff line change
Expand Up @@ -9,16 +9,17 @@ python_version = "3.6"

[packages]

aiohttp = "==2.3.7"
aiohttp = "==3.7.4"
rq = "==0.10.0"
redis = "==2.10.6"
aiodns = "==1.1.1"
cchardet = "==2.1.1"
pyyaml = "==3.12"
yarl = "==0.18.0"
pyyaml = "==5.4"
yarl = "==1.6.3"


[dev-packages]

mock = "*"
nose = "*"
fakeredis = "*"
479 changes: 360 additions & 119 deletions Pipfile.lock

Large diffs are not rendered by default.

14 changes: 13 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,24 @@ The web service enqueues certain job functions in the RQ/Redis queue, where they

The downloaded files are deleted on successful verification, and retained if any error occurs.

Pre-requisites
--------------
You will need python 3.6 and redis.

Install redis with:

apt-get install redis-server

And start it with:

redis-server


Trying it out
-------------

python3 -m pip install pipenv
pipenv install --deploy
apt-get install redis-server

Try running it:

Expand Down
2 changes: 1 addition & 1 deletion archive_verify/__init__.py
Original file line number Diff line number Diff line change
@@ -1 +1 @@
__version__ = "1.0.0"
__version__ = "1.0.5"
7 changes: 3 additions & 4 deletions archive_verify/handlers.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
import json
import logging
import os

from aiohttp import web
from redis import Redis
import archive_verify.redis_client as redis_client
from rq import Queue

from archive_verify.workers import verify_archive
Expand Down Expand Up @@ -31,7 +30,7 @@ async def verify(request):
# use a supplied path if available, otherwise construct it from the src_root and archive
archive_path = path or os.path.join(src_root, archive)

redis_conn = Redis()
redis_conn = redis_client.get_redis_instance()
q = Queue(connection=redis_conn)

# Enqueue the verify_archive function with the user supplied input parameters.
Expand Down Expand Up @@ -63,7 +62,7 @@ async def status(request):
"""
job_id = str(request.match_info['job_id'])

redis_conn = Redis()
redis_conn = redis_client.get_redis_instance()
q = Queue(connection=redis_conn)
job = q.fetch_job(job_id)

Expand Down
5 changes: 5 additions & 0 deletions archive_verify/redis_client.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
from redis import Redis


def get_redis_instance():
return Redis()
Empty file added logs/.gitkeep
Empty file.
30 changes: 26 additions & 4 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -1,6 +1,28 @@
aiohttp==2.3.7
aiodns==1.1.1
pyyaml==3.12
rq==0.10.0
aiohttp==3.7.4
async-timeout==3.0.1
attrs==21.2.0
cchardet==2.1.1
yarl==0.18.0
cffi==1.14.6
chardet==3.0.4
click==8.0.1
fakeredis==1.6.1
idna==3.2
idna-ssl==1.1.0
importlib-metadata==4.8.1
mock==4.0.3
multidict==5.2.0
nose==1.3.7
packaging==21.0
pbr==5.1.1
pycares==4.0.0
pycparser==2.20
pyparsing==2.4.7
PyYAML==5.4
redis==2.10.6
rq==0.10.0
six==1.16.0
sortedcontainers==2.4.0
typing-extensions==3.10.0.2
yarl==1.6.3
zipp==3.6.0
4 changes: 4 additions & 0 deletions tests/mock_redis_client.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
import fakeredis

def get_redis_instance():
return fakeredis.FakeStrictRedis()
11 changes: 7 additions & 4 deletions tests/test_handlers.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,21 +3,24 @@
from aiohttp.test_utils import AioHTTPTestCase, unittest_run_loop
from aiohttp import web

from archive_verify.app import setup_routes
import archive_verify.app as app_setup
import mock_redis_client


class HandlerTestCase(AioHTTPTestCase):

BASE_URL = ""

def _load_config(self):
with open("tests/test_config.yaml") as config:
return yaml.load(config)
return yaml.safe_load(config)

async def get_application(self):
app = web.Application()
app["config"] = self._load_config()
self.BASE_URL = app["config"]["base_url"]
setup_routes(app)
app_setup.handlers.redis_client = mock_redis_client
app_setup.setup_routes(app)
return app

@unittest_run_loop
Expand All @@ -28,7 +31,7 @@ async def test_root(self):
assert "not found" in text.lower()

@unittest_run_loop
async def test_basic_verify(self):
async def test_basic_verify(self):
url = self.BASE_URL + "/verify"
payload = {"host": "testbox", "archive": "test_archive", "description": "test-description"}
request = await self.client.request("POST", url, json=payload)
Expand Down
2 changes: 1 addition & 1 deletion tests/test_pdc_client.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ class TestPdcClient(unittest.TestCase):

def setUp(self):
with open("tests/test_config.yaml") as config:
self.config = yaml.load(config)
self.config = yaml.safe_load(config)

def getPdcClient(self):
return PdcClient("archive", "path", "descr", "1234", self.config)
Expand Down
2 changes: 1 addition & 1 deletion tests/test_workers.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
class TestWorkers(unittest.TestCase):
def setUp(self):
with open("tests/test_config.yaml") as config:
self.config = yaml.load(config)
self.config = yaml.safe_load(config)

def test_pdc_client_is_default(self):
pdc_client_class = pdc_client_factory(self.config)
Expand Down

0 comments on commit b599b4d

Please sign in to comment.