
Research
npm Malware Targets Telegram Bot Developers with Persistent SSH Backdoors
Malicious npm packages posing as Telegram bot libraries install SSH backdoors and exfiltrate data from Linux developer machines.
.. image:: https://img.shields.io/pypi/v/pytest-mock-server.svg :target: https://pypi.org/project/pytest-mock-server :alt: PyPI version
.. image:: https://img.shields.io/pypi/pyversions/pytest-mock-server.svg :target: https://pypi.org/project/pytest-mock-server :alt: Python versions
.. image:: https://travis-ci.org/AndreyErmilov/pytest-mock-server.svg?branch=master :target: https://travis-ci.org/AndreyErmilov/pytest-mock-server :alt: See Build Status on Travis CI
Mock server plugin for pytest
You can install "pytest-mock-server" via pip
_ from PyPI
_::
$ pip install pytest-mock-server
One handler
.. code-block:: python
import pytest
import requests
@pytest.mark.server(url='/v1/books/', response=[{'id': 1}], method='GET')
def test_handler_responses():
response = requests.get('http://localhost:5000/v1/books/')
assert response.status_code == 200
assert response.json() == [{'id': 1}]
More than one handlers
.. code-block:: python
import pytest import requests
@pytest.mark.server(url='/v1/books/', response=[{'id': 1}], method='GET') @pytest.mark.server(url='/v1/books/<book_id>/', response={'id': 1}, method='GET') def test_handler_responses(): response = requests.get('http://localhost:5000/v1/books/') assert response.status_code == 200 assert response.json() == [{'id': 1}] response = requests.get('http://localhost:5000/v1/books/1/') assert response.status_code == 200 assert response.json() == {'id': 1}
Callback executes before response returns
.. code-block:: python
import pytest
import requests
import time
def sleep_two(*args, **kwargs):
time.sleep(2)
@pytest.mark.server(url='/v1/books/', response={}, callback=sleep_two)
def test_handler_responses():
"""Ensures Timeouts works"""
with pytest.raises(requests.exceptions.Timeout):
response = requests.get('http://localhost:5000/v1/books/', timeout=1)
Custom settings for server
.. code-block:: python
import pytest import requests
@pytest.mark.server(url='/v1/books/', response={}) @pytest.mark.server_settings(port=8000) def test_handler_responses(): response = requests.get('http://localhost:8000/v1/books/') assert response.status_code == 200 assert response.json() == {}
Contributions are very welcome. Tests can be run with tox
_, please ensure
the coverage at least stays the same before you submit a pull request.
Distributed under the terms of the MIT
_ license, "pytest-mock-server" is free and open source software
If you encounter any problems, please file an issue
_ along with a detailed description.
.. _MIT
: http://opensource.org/licenses/MIT
.. _file an issue
: https://github.com/AndreyErmilov/pytest-mock-server/issues
.. _tox
: https://tox.readthedocs.io/en/latest/
.. _pip
: https://pypi.org/project/pip/
.. _PyPI
: https://pypi.org/project
FAQs
Mock server plugin for pytest
We found that pytest-mock-server demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Malicious npm packages posing as Telegram bot libraries install SSH backdoors and exfiltrate data from Linux developer machines.
Security News
pip, PDM, pip-audit, and the packaging library are already adding support for Python’s new lock file format.
Product
Socket's Go support is now generally available, bringing automatic scanning and deep code analysis to all users with Go projects.