diff --git a/attachments/models.py b/attachments/models.py index 10ec080..8062bdf 100644 --- a/attachments/models.py +++ b/attachments/models.py @@ -47,7 +47,7 @@ class Attachment(models.Model): if self.id is None: super().save(*args, **kwargs) try: - image = Image.open(self.original_file.path) + Image.open(self.original_file.path) except IOError: return super().save(*args, **kwargs) diff --git a/attachments/tests/__init__.py b/attachments/tests/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/attachments/tests/cassettes/test_models/test_attachment_is_processed_by_shortpixel.yaml b/attachments/tests/cassettes/test_models/test_attachment_is_processed_by_shortpixel.yaml new file mode 100644 index 0000000..10e745c --- /dev/null +++ b/attachments/tests/cassettes/test_models/test_attachment_is_processed_by_shortpixel.yaml @@ -0,0 +1,99 @@ +interactions: +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + Content-Length: + - '2309' + Content-Type: + - multipart/form-data; boundary=db4d499839441a0f66c79bbf8317b966 + User-Agent: + - python-requests/2.25.0 + method: POST + uri: https://api.shortpixel.com/v2/post-reducer.php + response: + body: + string: !!binary | + H4sIAAAAAAAAA61TXW+bQBB8z6+IeK59H2ADfnMaVbHixKRubKlVFJ2PPfsiMIQ7rJAo/73HSdjE + wm0q9R4Q7Mzuzu4xv87OzXmzz/o4c810qZxRK2bjX7MYTNShzpc92QI3oBRbW2xecm6+nD3h/cB1 + ZoVcyy1L7r9Pa+5G63yEEMtlX22yQufyBZI+z1JUossLuXy+CN1LuWB3oc5nV9HL/WB5/XMnJxVf + LkQ+e3pNtOYojmPPDzgfxK4HvljROGAioAK4gCHwVT/frluCnWmmVGIk/lWEQG4QYN8bYsqCcIh9 + jkXAXZ8KsqLCxWzYVbr6D3V7idFYHVdfwio6En87bk/WEBoJH9HxYvLtj+kNoTu9ubu5fLUXTUjo + da21wUOPHMFQb/00rKoTWHvuhtI5+IcGnYxDj9O76W6xX043/EOmYGyT5tYfmOIeoT3snlN3hMmI + uu1VRFBw2OpJmhfZDlLzapNIn4Rt2jVUdbwAlZUmQSGZGo89jiOgxe308eivTjLOkojpTZ2DSlUg + G0FKxb24kDtAB4v9g7kGHvmcwazf388efgN919avTQQAAA== + headers: + Access-Control-Allow-Origin: + - '*' + Content-Encoding: + - gzip + Content-Type: + - text/html; charset=UTF-8 + Date: + - Thu, 03 Dec 2020 22:01:24 GMT + Server: + - nginx/1.15.2 + Set-Cookie: + - ShortPixel=ShortPixel_ns71; path=/ + Transfer-Encoding: + - chunked + Vary: + - Accept-Encoding + status: + code: 200 + message: OK +- request: + body: null + headers: + Accept: + - '*/*' + Accept-Encoding: + - gzip, deflate + Connection: + - keep-alive + User-Agent: + - python-requests/2.25.0 + method: GET + uri: http://api.shortpixel.com/f/388074602a89607c0f8c372f1b2f30a6-lossy.png + response: + body: + string: !!binary | + iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAACc1BMVEXf39/n5+ft7e3v7+/w8PDw + 8O/u7u7r6+vm5ubh2trg4ODr6+vq6urg4ODi4uHt7e3r6+vh4eHh4eHt7Ozo6eng39/c0tLb6enp + 6enRh4eTWFjd3d3n5+esX1/c3Nzl5OSyfXy/b2/b29ri4uFvbGuXenvZ2dng4N+kpKbr7OzX19bf + 3t3W1dXd3dzW1tXc29vZ2NfV1dTV1NTa2tnY19bV1NTU1NPX1tbX1tXT09LW1dXS0dDU09LR0M/Q + yMjQ0M/V1dTY19a6ubmmpqbBwcHR0NDX1tXW1dXU09LPz87Qz87w8PDx8fH29fXy8vLv7/D09PTz + 8/P19fXv7+/p6enY2Nnk5OTm5ubg4ODq6urb29zj4+Pa2tvn5+fm5+fr6+vl5eXr7Ozv8PDd3d3V + 1dXX19fc3NzOz8/f19bnzc3j4+Li4uLa2trb29vf39/g4eHNzs/hu7z1n5/g39/e3t3Z2dnOz9DP + yr/CvauytsPQoKTjiIjd3NzU1NPU1NTIycne3t7X2NnLx7vdtkvnvT2trJeemZrKysro5+fo6Oni + 3dHqxFr8xyL+0DnYrzyShmnX1tbb2trm5uXp6Ofk5OXZ1MnnwFb8xiH+0Tzsuy3IlxqUglbR0NDP + z8/S0tLRzMHatUv7xR/+0Trtuy7KmR6chk61s7HS0tG6urrGxcXFxcfLtHr7xCL/0DiTfEShoJ/Z + 2djQz8+/vr7Oy8fgxpD3zWXtuSzMmyGeh0+vrq3DwsLBwMDMy8y/uKnjx47WuX2/nVGdiFO1tLHe + 3d3g397c29vOzczY19bY19eRkI2Sh2+ek4CemZK6ubja2dnd3Nva2di8i5n6AAAAS3RSTlMGqvfz + 8/Pz96sHBrKzBwayswcGsrMHswey0SUGspAGsvBkBrK8DAayswcGsrMHBrKzBwayswcGsrMHBrKz + Bwar+fX19fX19fX5rQfYmwlAAAAAnklEQVQYGQXBQUrDQAAF0HnJD50kBUEFhW7qzgMU3Iln8Vje + RPAe7noA0W2I2CG+p6CwbaWUHiYvKHAZyrvEaOtwGWjRJaW2tlv+pjYMY5LVvq+zFlfoZLlfbtvO + sQO97pAhN2v9qbXWWl/79B6sB4/AWxLdeP49ASJx7QlAJPYFgEjMwGIiEpOvO0x8fkdidAScfEjs + ASxzeEYBNvgHumshAGNFansAAAAASUVORK5CYII= + headers: + Access-Control-Allow-Origin: + - '*' + Content-Length: + - '941' + Content-Type: + - image/png + Date: + - Thu, 03 Dec 2020 22:01:24 GMT + Server: + - nginx/1.15.2 + Set-Cookie: + - ShortPixel=ShortPixel_ns71; path=/ + status: + code: 200 + message: OK +version: 1 diff --git a/attachments/tests/conftest.py b/attachments/tests/conftest.py new file mode 100644 index 0000000..f532ffb --- /dev/null +++ b/attachments/tests/conftest.py @@ -0,0 +1,13 @@ +import pytest + + +def replace_post_body(request): + request.body = None + return request + + +@pytest.fixture(scope="module") +def vcr_config(): + return { + "before_record_request": replace_post_body, + } diff --git a/attachments/tests/resources/image.png b/attachments/tests/resources/image.png new file mode 100644 index 0000000..ac617bc Binary files /dev/null and b/attachments/tests/resources/image.png differ diff --git a/attachments/tests/test_models.py b/attachments/tests/test_models.py new file mode 100644 index 0000000..b6435ab --- /dev/null +++ b/attachments/tests/test_models.py @@ -0,0 +1,20 @@ +from pathlib import Path + +import pytest +from django.core.files import File + +from attachments.models import Attachment + + +@pytest.mark.block_network +@pytest.mark.vcr +@pytest.mark.django_db +def test_attachment_is_processed_by_shortpixel(): + # This path manipulation is required to make the test run from this directory + # or from upper in the hierarchy (e.g.: settings.BASE_DIR) + img_path = Path(__file__).parent / "resources" / "image.png" + img_path = img_path.relative_to(Path.cwd()) + with open(img_path, "rb") as f: + img_file = File(f) + attachment = Attachment(description="test attachment", original_file=img_file) + attachment.save() diff --git a/poetry.lock b/poetry.lock index d3c2742..b7dba83 100644 --- a/poetry.lock +++ b/poetry.lock @@ -211,6 +211,14 @@ python-versions = "*" [package.dependencies] django = ">=1.11.0" +[[package]] +name = "multidict" +version = "5.1.0" +description = "multidict implementation" +category = "dev" +optional = false +python-versions = ">=3.6" + [[package]] name = "nodeenv" version = "1.5.0" @@ -341,6 +349,19 @@ pytest = ">=3.6" docs = ["sphinx", "sphinx-rtd-theme"] testing = ["django", "django-configurations (>=2.0)", "six"] +[[package]] +name = "pytest-recording" +version = "0.11.0" +description = "A pytest plugin that allows you recording of network interactions via VCR.py" +category = "dev" +optional = false +python-versions = ">=3.5" + +[package.dependencies] +attrs = "*" +pytest = ">=3.5.0" +vcrpy = ">=2.0.1" + [[package]] name = "pytz" version = "2020.4" @@ -412,6 +433,20 @@ brotli = ["brotlipy (>=0.6.0)"] secure = ["pyOpenSSL (>=0.14)", "cryptography (>=1.3.4)", "idna (>=2.0.0)", "certifi", "ipaddress"] socks = ["PySocks (>=1.5.6,!=1.5.7,<2.0)"] +[[package]] +name = "vcrpy" +version = "4.1.1" +description = "Automatically mock your HTTP interactions to simplify and speed up testing" +category = "dev" +optional = false +python-versions = ">=3.5" + +[package.dependencies] +PyYAML = "*" +six = ">=1.5" +wrapt = "*" +yarl = {version = "*", markers = "python_version >= \"3.6\""} + [[package]] name = "virtualenv" version = "20.2.1" @@ -430,10 +465,30 @@ six = ">=1.9.0,<2" docs = ["proselint (>=0.10.2)", "sphinx (>=3)", "sphinx-argparse (>=0.2.5)", "sphinx-rtd-theme (>=0.4.3)", "towncrier (>=19.9.0rc1)"] testing = ["coverage (>=4)", "coverage-enable-subprocess (>=1)", "flaky (>=3)", "pytest (>=4)", "pytest-env (>=0.6.2)", "pytest-freezegun (>=0.4.1)", "pytest-mock (>=2)", "pytest-randomly (>=1)", "pytest-timeout (>=1)", "pytest-xdist (>=1.31.0)", "packaging (>=20.0)", "xonsh (>=0.9.16)"] +[[package]] +name = "wrapt" +version = "1.12.1" +description = "Module for decorators, wrappers and monkey patching." +category = "dev" +optional = false +python-versions = "*" + +[[package]] +name = "yarl" +version = "1.6.3" +description = "Yet another URL library" +category = "dev" +optional = false +python-versions = ">=3.6" + +[package.dependencies] +idna = ">=2.0" +multidict = ">=4.0" + [metadata] lock-version = "1.1" python-versions = "^3.8" -content-hash = "e88fcdca6b5b64a4d985a4bef92567c01efac3982ded00c5d9886f5573ea785d" +content-hash = "e1764fd2910c5b113fe5346db1e5d5a14c554e716990ab57c2c7618f43a511db" [metadata.files] appdirs = [ @@ -552,6 +607,45 @@ model-bakery = [ {file = "model_bakery-1.2.1-py2.py3-none-any.whl", hash = "sha256:d3260bd055c25998b54eda2082a507ba7fd113fe071156bdad065da426b14851"}, {file = "model_bakery-1.2.1.tar.gz", hash = "sha256:c2b3521a866b2b25ee0b5f953bfa385ef7d27ad75f30abf5e2de6dd61160c404"}, ] +multidict = [ + {file = "multidict-5.1.0-cp36-cp36m-macosx_10_14_x86_64.whl", hash = "sha256:b7993704f1a4b204e71debe6095150d43b2ee6150fa4f44d6d966ec356a8d61f"}, + {file = "multidict-5.1.0-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:9dd6e9b1a913d096ac95d0399bd737e00f2af1e1594a787e00f7975778c8b2bf"}, + {file = "multidict-5.1.0-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:f21756997ad8ef815d8ef3d34edd98804ab5ea337feedcd62fb52d22bf531281"}, + {file = "multidict-5.1.0-cp36-cp36m-manylinux2014_i686.whl", hash = "sha256:1ab820665e67373de5802acae069a6a05567ae234ddb129f31d290fc3d1aa56d"}, + {file = "multidict-5.1.0-cp36-cp36m-manylinux2014_ppc64le.whl", hash = "sha256:9436dc58c123f07b230383083855593550c4d301d2532045a17ccf6eca505f6d"}, + {file = "multidict-5.1.0-cp36-cp36m-manylinux2014_s390x.whl", hash = "sha256:830f57206cc96ed0ccf68304141fec9481a096c4d2e2831f311bde1c404401da"}, + {file = "multidict-5.1.0-cp36-cp36m-manylinux2014_x86_64.whl", hash = "sha256:2e68965192c4ea61fff1b81c14ff712fc7dc15d2bd120602e4a3494ea6584224"}, + {file = "multidict-5.1.0-cp36-cp36m-win32.whl", hash = "sha256:2f1a132f1c88724674271d636e6b7351477c27722f2ed789f719f9e3545a3d26"}, + {file = "multidict-5.1.0-cp36-cp36m-win_amd64.whl", hash = "sha256:3a4f32116f8f72ecf2a29dabfb27b23ab7cdc0ba807e8459e59a93a9be9506f6"}, + {file = "multidict-5.1.0-cp37-cp37m-macosx_10_14_x86_64.whl", hash = "sha256:46c73e09ad374a6d876c599f2328161bcd95e280f84d2060cf57991dec5cfe76"}, + {file = "multidict-5.1.0-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:018132dbd8688c7a69ad89c4a3f39ea2f9f33302ebe567a879da8f4ca73f0d0a"}, + {file = "multidict-5.1.0-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:4b186eb7d6ae7c06eb4392411189469e6a820da81447f46c0072a41c748ab73f"}, + {file = "multidict-5.1.0-cp37-cp37m-manylinux2014_i686.whl", hash = "sha256:3a041b76d13706b7fff23b9fc83117c7b8fe8d5fe9e6be45eee72b9baa75f348"}, + {file = "multidict-5.1.0-cp37-cp37m-manylinux2014_ppc64le.whl", hash = "sha256:051012ccee979b2b06be928a6150d237aec75dd6bf2d1eeeb190baf2b05abc93"}, + {file = "multidict-5.1.0-cp37-cp37m-manylinux2014_s390x.whl", hash = "sha256:6a4d5ce640e37b0efcc8441caeea8f43a06addace2335bd11151bc02d2ee31f9"}, + {file = "multidict-5.1.0-cp37-cp37m-manylinux2014_x86_64.whl", hash = "sha256:5cf3443199b83ed9e955f511b5b241fd3ae004e3cb81c58ec10f4fe47c7dce37"}, + {file = "multidict-5.1.0-cp37-cp37m-win32.whl", hash = "sha256:f200755768dc19c6f4e2b672421e0ebb3dd54c38d5a4f262b872d8cfcc9e93b5"}, + {file = "multidict-5.1.0-cp37-cp37m-win_amd64.whl", hash = "sha256:05c20b68e512166fddba59a918773ba002fdd77800cad9f55b59790030bab632"}, + {file = "multidict-5.1.0-cp38-cp38-macosx_10_14_x86_64.whl", hash = "sha256:54fd1e83a184e19c598d5e70ba508196fd0bbdd676ce159feb412a4a6664f952"}, + {file = "multidict-5.1.0-cp38-cp38-manylinux1_i686.whl", hash = "sha256:0e3c84e6c67eba89c2dbcee08504ba8644ab4284863452450520dad8f1e89b79"}, + {file = "multidict-5.1.0-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:dc862056f76443a0db4509116c5cd480fe1b6a2d45512a653f9a855cc0517456"}, + {file = "multidict-5.1.0-cp38-cp38-manylinux2014_i686.whl", hash = "sha256:0e929169f9c090dae0646a011c8b058e5e5fb391466016b39d21745b48817fd7"}, + {file = "multidict-5.1.0-cp38-cp38-manylinux2014_ppc64le.whl", hash = "sha256:d81eddcb12d608cc08081fa88d046c78afb1bf8107e6feab5d43503fea74a635"}, + {file = "multidict-5.1.0-cp38-cp38-manylinux2014_s390x.whl", hash = "sha256:585fd452dd7782130d112f7ddf3473ffdd521414674c33876187e101b588738a"}, + {file = "multidict-5.1.0-cp38-cp38-manylinux2014_x86_64.whl", hash = "sha256:37e5438e1c78931df5d3c0c78ae049092877e5e9c02dd1ff5abb9cf27a5914ea"}, + {file = "multidict-5.1.0-cp38-cp38-win32.whl", hash = "sha256:07b42215124aedecc6083f1ce6b7e5ec5b50047afa701f3442054373a6deb656"}, + {file = "multidict-5.1.0-cp38-cp38-win_amd64.whl", hash = "sha256:929006d3c2d923788ba153ad0de8ed2e5ed39fdbe8e7be21e2f22ed06c6783d3"}, + {file = "multidict-5.1.0-cp39-cp39-macosx_10_14_x86_64.whl", hash = "sha256:b797515be8743b771aa868f83563f789bbd4b236659ba52243b735d80b29ed93"}, + {file = "multidict-5.1.0-cp39-cp39-manylinux1_i686.whl", hash = "sha256:d5c65bdf4484872c4af3150aeebe101ba560dcfb34488d9a8ff8dbcd21079647"}, + {file = "multidict-5.1.0-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:b47a43177a5e65b771b80db71e7be76c0ba23cc8aa73eeeb089ed5219cdbe27d"}, + {file = "multidict-5.1.0-cp39-cp39-manylinux2014_i686.whl", hash = "sha256:806068d4f86cb06af37cd65821554f98240a19ce646d3cd24e1c33587f313eb8"}, + {file = "multidict-5.1.0-cp39-cp39-manylinux2014_ppc64le.whl", hash = "sha256:46dd362c2f045095c920162e9307de5ffd0a1bfbba0a6e990b344366f55a30c1"}, + {file = "multidict-5.1.0-cp39-cp39-manylinux2014_s390x.whl", hash = "sha256:ace010325c787c378afd7f7c1ac66b26313b3344628652eacd149bdd23c68841"}, + {file = "multidict-5.1.0-cp39-cp39-manylinux2014_x86_64.whl", hash = "sha256:ecc771ab628ea281517e24fd2c52e8f31c41e66652d07599ad8818abaad38cda"}, + {file = "multidict-5.1.0-cp39-cp39-win32.whl", hash = "sha256:fc13a9524bc18b6fb6e0dbec3533ba0496bbed167c56d0aabefd965584557d80"}, + {file = "multidict-5.1.0-cp39-cp39-win_amd64.whl", hash = "sha256:7df80d07818b385f3129180369079bd6934cf70469f99daaebfac89dca288359"}, + {file = "multidict-5.1.0.tar.gz", hash = "sha256:25b4e5f22d3a37ddf3effc0710ba692cfc792c2b9edfb9c05aefe823256e84d5"}, +] nodeenv = [ {file = "nodeenv-1.5.0-py2.py3-none-any.whl", hash = "sha256:5304d424c529c997bc888453aeaa6362d242b6b4631e90f3d4bf1b290f1c84a9"}, {file = "nodeenv-1.5.0.tar.gz", hash = "sha256:ab45090ae383b716c4ef89e690c41ff8c2b257b85b309f01f3654df3d084bd7c"}, @@ -622,6 +716,10 @@ pytest-django = [ {file = "pytest-django-3.10.0.tar.gz", hash = "sha256:4de6dbd077ed8606616958f77655fed0d5e3ee45159475671c7fa67596c6dba6"}, {file = "pytest_django-3.10.0-py2.py3-none-any.whl", hash = "sha256:c33e3d3da14d8409b125d825d4e74da17bb252191bf6fc3da6856e27a8b73ea4"}, ] +pytest-recording = [ + {file = "pytest-recording-0.11.0.tar.gz", hash = "sha256:deea1ae6a129c9d8f8669ed7d12539748f00c8f9ef4de4f563055263e47bed08"}, + {file = "pytest_recording-0.11.0-py3-none-any.whl", hash = "sha256:c2cc321f93ceffb2146ead0c51198e4ce86986723265ce6d4a87d3b16071eb85"}, +] pytz = [ {file = "pytz-2020.4-py2.py3-none-any.whl", hash = "sha256:5c55e189b682d420be27c6995ba6edce0c0a77dd67bfbe2ae6607134d5851ffd"}, {file = "pytz-2020.4.tar.gz", hash = "sha256:3e6b7dd2d1e0a59084bcee14a17af60c5c562cdc16d828e8eba2e683d3a7e268"}, @@ -659,7 +757,53 @@ urllib3 = [ {file = "urllib3-1.26.2-py2.py3-none-any.whl", hash = "sha256:d8ff90d979214d7b4f8ce956e80f4028fc6860e4431f731ea4a8c08f23f99473"}, {file = "urllib3-1.26.2.tar.gz", hash = "sha256:19188f96923873c92ccb987120ec4acaa12f0461fa9ce5d3d0772bc965a39e08"}, ] +vcrpy = [ + {file = "vcrpy-4.1.1-py2.py3-none-any.whl", hash = "sha256:12c3fcdae7b88ecf11fc0d3e6d77586549d4575a2ceee18e82eee75c1f626162"}, + {file = "vcrpy-4.1.1.tar.gz", hash = "sha256:57095bf22fc0a2d99ee9674cdafebed0f3ba763018582450706f7d3a74fff599"}, +] virtualenv = [ {file = "virtualenv-20.2.1-py2.py3-none-any.whl", hash = "sha256:07cff122e9d343140366055f31be4dcd61fd598c69d11cd33a9d9c8df4546dd7"}, {file = "virtualenv-20.2.1.tar.gz", hash = "sha256:e0aac7525e880a429764cefd3aaaff54afb5d9f25c82627563603f5d7de5a6e5"}, ] +wrapt = [ + {file = "wrapt-1.12.1.tar.gz", hash = "sha256:b62ffa81fb85f4332a4f609cab4ac40709470da05643a082ec1eb88e6d9b97d7"}, +] +yarl = [ + {file = "yarl-1.6.3-cp36-cp36m-macosx_10_14_x86_64.whl", hash = "sha256:0355a701b3998dcd832d0dc47cc5dedf3874f966ac7f870e0f3a6788d802d434"}, + {file = "yarl-1.6.3-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:bafb450deef6861815ed579c7a6113a879a6ef58aed4c3a4be54400ae8871478"}, + {file = "yarl-1.6.3-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:547f7665ad50fa8563150ed079f8e805e63dd85def6674c97efd78eed6c224a6"}, + {file = "yarl-1.6.3-cp36-cp36m-manylinux2014_i686.whl", hash = "sha256:63f90b20ca654b3ecc7a8d62c03ffa46999595f0167d6450fa8383bab252987e"}, + {file = "yarl-1.6.3-cp36-cp36m-manylinux2014_ppc64le.whl", hash = "sha256:97b5bdc450d63c3ba30a127d018b866ea94e65655efaf889ebeabc20f7d12406"}, + {file = "yarl-1.6.3-cp36-cp36m-manylinux2014_s390x.whl", hash = "sha256:d8d07d102f17b68966e2de0e07bfd6e139c7c02ef06d3a0f8d2f0f055e13bb76"}, + {file = "yarl-1.6.3-cp36-cp36m-manylinux2014_x86_64.whl", hash = "sha256:15263c3b0b47968c1d90daa89f21fcc889bb4b1aac5555580d74565de6836366"}, + {file = "yarl-1.6.3-cp36-cp36m-win32.whl", hash = "sha256:b5dfc9a40c198334f4f3f55880ecf910adebdcb2a0b9a9c23c9345faa9185721"}, + {file = "yarl-1.6.3-cp36-cp36m-win_amd64.whl", hash = "sha256:b2e9a456c121e26d13c29251f8267541bd75e6a1ccf9e859179701c36a078643"}, + {file = "yarl-1.6.3-cp37-cp37m-macosx_10_14_x86_64.whl", hash = "sha256:ce3beb46a72d9f2190f9e1027886bfc513702d748047b548b05dab7dfb584d2e"}, + {file = "yarl-1.6.3-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:2ce4c621d21326a4a5500c25031e102af589edb50c09b321049e388b3934eec3"}, + {file = "yarl-1.6.3-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:d26608cf178efb8faa5ff0f2d2e77c208f471c5a3709e577a7b3fd0445703ac8"}, + {file = "yarl-1.6.3-cp37-cp37m-manylinux2014_i686.whl", hash = "sha256:4c5bcfc3ed226bf6419f7a33982fb4b8ec2e45785a0561eb99274ebbf09fdd6a"}, + {file = "yarl-1.6.3-cp37-cp37m-manylinux2014_ppc64le.whl", hash = "sha256:4736eaee5626db8d9cda9eb5282028cc834e2aeb194e0d8b50217d707e98bb5c"}, + {file = "yarl-1.6.3-cp37-cp37m-manylinux2014_s390x.whl", hash = "sha256:68dc568889b1c13f1e4745c96b931cc94fdd0defe92a72c2b8ce01091b22e35f"}, + {file = "yarl-1.6.3-cp37-cp37m-manylinux2014_x86_64.whl", hash = "sha256:7356644cbed76119d0b6bd32ffba704d30d747e0c217109d7979a7bc36c4d970"}, + {file = "yarl-1.6.3-cp37-cp37m-win32.whl", hash = "sha256:00d7ad91b6583602eb9c1d085a2cf281ada267e9a197e8b7cae487dadbfa293e"}, + {file = "yarl-1.6.3-cp37-cp37m-win_amd64.whl", hash = "sha256:69ee97c71fee1f63d04c945f56d5d726483c4762845400a6795a3b75d56b6c50"}, + {file = "yarl-1.6.3-cp38-cp38-macosx_10_14_x86_64.whl", hash = "sha256:e46fba844f4895b36f4c398c5af062a9808d1f26b2999c58909517384d5deda2"}, + {file = "yarl-1.6.3-cp38-cp38-manylinux1_i686.whl", hash = "sha256:31ede6e8c4329fb81c86706ba8f6bf661a924b53ba191b27aa5fcee5714d18ec"}, + {file = "yarl-1.6.3-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:fcbb48a93e8699eae920f8d92f7160c03567b421bc17362a9ffbbd706a816f71"}, + {file = "yarl-1.6.3-cp38-cp38-manylinux2014_i686.whl", hash = "sha256:72a660bdd24497e3e84f5519e57a9ee9220b6f3ac4d45056961bf22838ce20cc"}, + {file = "yarl-1.6.3-cp38-cp38-manylinux2014_ppc64le.whl", hash = "sha256:324ba3d3c6fee56e2e0b0d09bf5c73824b9f08234339d2b788af65e60040c959"}, + {file = "yarl-1.6.3-cp38-cp38-manylinux2014_s390x.whl", hash = "sha256:e6b5460dc5ad42ad2b36cca524491dfcaffbfd9c8df50508bddc354e787b8dc2"}, + {file = "yarl-1.6.3-cp38-cp38-manylinux2014_x86_64.whl", hash = "sha256:6d6283d8e0631b617edf0fd726353cb76630b83a089a40933043894e7f6721e2"}, + {file = "yarl-1.6.3-cp38-cp38-win32.whl", hash = "sha256:9ede61b0854e267fd565e7527e2f2eb3ef8858b301319be0604177690e1a3896"}, + {file = "yarl-1.6.3-cp38-cp38-win_amd64.whl", hash = "sha256:f0b059678fd549c66b89bed03efcabb009075bd131c248ecdf087bdb6faba24a"}, + {file = "yarl-1.6.3-cp39-cp39-macosx_10_14_x86_64.whl", hash = "sha256:329412812ecfc94a57cd37c9d547579510a9e83c516bc069470db5f75684629e"}, + {file = "yarl-1.6.3-cp39-cp39-manylinux1_i686.whl", hash = "sha256:c49ff66d479d38ab863c50f7bb27dee97c6627c5fe60697de15529da9c3de724"}, + {file = "yarl-1.6.3-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:f040bcc6725c821a4c0665f3aa96a4d0805a7aaf2caf266d256b8ed71b9f041c"}, + {file = "yarl-1.6.3-cp39-cp39-manylinux2014_i686.whl", hash = "sha256:d5c32c82990e4ac4d8150fd7652b972216b204de4e83a122546dce571c1bdf25"}, + {file = "yarl-1.6.3-cp39-cp39-manylinux2014_ppc64le.whl", hash = "sha256:d597767fcd2c3dc49d6eea360c458b65643d1e4dbed91361cf5e36e53c1f8c96"}, + {file = "yarl-1.6.3-cp39-cp39-manylinux2014_s390x.whl", hash = "sha256:8aa3decd5e0e852dc68335abf5478a518b41bf2ab2f330fe44916399efedfae0"}, + {file = "yarl-1.6.3-cp39-cp39-manylinux2014_x86_64.whl", hash = "sha256:73494d5b71099ae8cb8754f1df131c11d433b387efab7b51849e7e1e851f07a4"}, + {file = "yarl-1.6.3-cp39-cp39-win32.whl", hash = "sha256:5b883e458058f8d6099e4420f0cc2567989032b5f34b271c0827de9f1079a424"}, + {file = "yarl-1.6.3-cp39-cp39-win_amd64.whl", hash = "sha256:4953fb0b4fdb7e08b2f3b3be80a00d28c5c8a2056bb066169de00e6501b986b6"}, + {file = "yarl-1.6.3.tar.gz", hash = "sha256:8a9066529240171b68893d60dca86a763eae2139dd42f42106b03cf4b426bf10"}, +] diff --git a/pyproject.toml b/pyproject.toml index fcfe458..727bfa3 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -10,6 +10,7 @@ DJANGO_SETTINGS_MODULE = "blog.settings" testpaths = [ "articles", "blog", + "attachments", ] [tool.poetry] @@ -37,6 +38,7 @@ pytest = "^6.0" pytest-django = "^3.9" model-bakery = "^1.1" pytest-cov = "^2.10.1" +pytest-recording = "^0.11.0" [build-system] requires = ["poetry-core>=1.0.0"]