pytest-localftpserver
pytest-localftpserver copied to clipboard
A PyTest plugin which gives you a local ftp server for your tests
PyTest FTP Server
.. image:: https://img.shields.io/pypi/v/pytest_localftpserver.svg :target: https://pypi.org/project/pytest-localftpserver/
.. image:: https://camo.githubusercontent.com/89b9f56d30241e30f546daf9f43653f08e920f16/68747470733a2f2f696d672e736869656c64732e696f2f636f6e64612f766e2f636f6e64612d666f7267652f7079746573742d6c6f63616c6674707365727665722e737667 :target: https://anaconda.org/conda-forge/pytest-localftpserver
.. image:: https://img.shields.io/pypi/pyversions/pytest_localftpserver.svg :target: https://pypi.org/project/pytest/
.. image:: https://github.com/oz123/pytest-localftpserver/workflows/Tests/badge.svg :target: https://github.com/oz123/pytest-localftpserver/actions?query=workflow%3ATests
.. image:: https://readthedocs.org/projects/pytest-localftpserver/badge/?version=latest :target: https://pytest-localftpserver.readthedocs.io/en/latest/?badge=latest :alt: Documentation Status
.. image:: https://coveralls.io/repos/github/oz123/pytest-localftpserver/badge.svg :target: https://coveralls.io/github/oz123/pytest-localftpserver :alt: Coverage
A PyTest plugin which provides an FTP fixture for your tests
- Free software: MIT license
- Documentation: https://pytest-localftpserver.readthedocs.io/en/latest/index.html
Attention!
As of version 1.0.0 the support for python 2.7 and 3.4 was dropped.
If you need to support those versions you should pin the version to 0.6.0,
i.e. add the following lines to your "requirements_dev.txt"::
# pytest_localftpserver==0.6.0
https://github.com/oz123/pytest-localftpserver/archive/v0.6.0.zip
Usage Quickstart:
This Plugin provides the fixtures ftpserver and ftpserver_TLS,
which are threaded instances of a FTP server, with which you can upload files and test FTP
functionality. It can be configured using the following environment variables:
===================== =============================================================================
Environment variable Usage
===================== =============================================================================
FTP_USER Username of the registered user.
FTP_PASS Password of the registered user.
FTP_PORT Port for the normal ftp server to run on.
FTP_HOME Home folder (host system) of the registered user.
FTP_FIXTURE_SCOPE Scope/lifetime of the fixture.
FTP_PORT_TLS Port for the TLS ftp server to run on.
FTP_HOME_TLS Home folder (host system) of the registered user, used by the TLS ftp server.
FTP_CERTFILE Certificate (host system) to be used by the TLS ftp server.
===================== =============================================================================
See the tests directory <https://github.com/oz123/pytest-localftpserver/tree/master/tests>_
or the
documentation <https://pytest-localftpserver.readthedocs.io/en/latest/usage.html>_
for examples.
You can either set environment variables on a system level or use tools such as
pytest-env <https://pypi.org/project/pytest-env/>_ or
tox <https://pypi.org/project/tox/>_, to change the default settings of this plugin.
Sample config for pytest-cov::
$ cat pytest.ini
[pytest]
env =
FTP_USER=benz
FTP_PASS=erni1
FTP_HOME = /home/ftp_test
FTP_PORT=31175
FTP_FIXTURE_SCOPE=function
# only affects ftpserver_TLS
FTP_PORT_TLS = 31176
FTP_HOME_TLS = /home/ftp_test_TLS
FTP_CERTFILE = ./tests/test_keycert.pem
Sample config for Tox::
$ cat tox.ini
[tox]
envlist = py{36,37,38,39,310}
[testenv]
setenv =
FTP_USER=benz
FTP_PASS=erni1
FTP_HOME = {envtmpdir}
FTP_PORT=31175
FTP_FIXTURE_SCOPE=function
# only affects ftpserver_TLS
FTP_PORT_TLS = 31176
FTP_HOME_TLS = /home/ftp_test_TLS
FTP_CERTFILE = {toxinidir}/tests/test_keycert.pem
commands =
pytest tests
Credits
This package was inspired by, https://pypi.org/project/pytest-localserver/ made by Sebastian Rahlf, which lacks an FTP server.
This package was created with Cookiecutter_ and the audreyr/cookiecutter-pypackage_ project template.
.. _Cookiecutter: https://github.com/cookiecutter/cookiecutter
.. _audreyr/cookiecutter-pypackage: https://github.com/audreyr/cookiecutter-pypackage