6
0
mirror of https://github.com/FirebirdSQL/firebird-qa.git synced 2025-01-22 21:43:06 +01:00
Python tools used for Firebird QA This is a mirror - read only access!
Go to file
2022-06-08 12:58:06 +02:00
backups Removed unneeded .fbk 2022-03-23 20:11:42 +03:00
databases database files used by tests 2021-04-26 20:04:53 +02:00
docs Update documentation 2022-06-08 12:57:40 +02:00
files Added compressed .fbk file that is needed for functional/tabloid/test_eqc_306263.py 2022-05-26 12:00:25 +03:00
firebird/qa Add encryption marker, add required psutils, release 0.15.1 2022-06-07 19:18:51 +02:00
tests Added/Updated bugs\core_5664_test.py: Adapted for firebird-qa plugin. Checked on 4.0.1.2692, 5.0.0.509 - both Windows and Linux 2022-06-08 11:36:27 +03:00
.gitignore pytest plugin for Firebird QA 2021-04-26 20:02:48 +02:00
.readthedocs.yml readthedocs configuration 2022-02-24 19:31:41 +01:00
firebird-driver.conf Adjusted output to fresh FB-5.x snashot 2022-02-14 11:49:12 +03:00
LICENSE Initial commit 2020-09-15 11:41:24 +02:00
pyproject.toml Bump version 2021-10-21 19:28:33 +02:00
pytest.ini Added declaration of 'encryption' marker which will be used in all tests which deal with encryption. 2022-06-06 20:41:07 +03:00
README.rst README 2022-02-24 19:21:45 +01:00
setup.cfg Add encryption marker, add required psutils, release 0.15.1 2022-06-07 19:18:51 +02:00
setup.py pytest plugin for Firebird QA 2021-04-26 20:02:48 +02:00

===========
Firebird QA
===========

This package contains:

- pytest plugin that provides support for testing the Firebird engine. It uses new Python
  driver for Firebird (firebird-driver).
- tests for Firebird engine (directory 'tests')
- files needed by tests (directories 'databases', 'files', 'backups')

Requirements: Python 3.8+, Firebird 3+

You should definitelly read the `QA suite documanetation`_ !

Quickstart
----------

1. Clone the git repository

2. Install the plugin and required dependencies by running next command from repo. directory::

   pip install -e .

3. Adjust Firebird server configuration.

   Firebird 3::

     # Required
     ExternalFileAccess = Full
     AuthServer = Srp, Legacy_Auth
     UserManager = Srp, Legacy_UserManager
     WireCrypt = Enabled

     # Recommended
     DefaultDbCachePages = 10000
     MaxUnflushedWrites = -1
     MaxUnflushedWriteTime = -1
     BugcheckAbort = 1

   Firebird 4+::

     # Required
     ExternalFileAccess = Full
     AuthServer = Srp256, Legacy_auth
     UserManager = Srp, Legacy_UserManager
     ReadConsistency = 0
     WireCrypt = Enabled
     ExtConnPoolSize = 10
     ExtConnPoolLifeTime = 10

     # Recommended
     DefaultDbCachePages = 10000
     MaxUnflushedWrites = -1
     MaxUnflushedWriteTime = -1
     BugcheckAbort = 1

3. Use pytest to run tests.

   The plugin adds next options to pytest::

      Firebird server:
         --server=SERVER       Server configuration name
         --bin-dir=PATH        Path to directory with Firebird utilities
         --protocol={xnet,inet,inet4,wnet}
                               Network protocol used for database attachments
         --runslow             Run slow tests
         --save-output         Save test std[out|err] output to files
         --skip-deselected={platform,version,any}
                               SKIP tests instead deselection
         --extend-xml          Extend XML JUnit report with additional information
         --install-terminal    Use our own terminal reporter

   To run all tests (except slow ones) against local server use next command::

      pytest --server local ./tests

  Note: If plugin fails to determine the directory with Firebird utilities (isql, gbak etc.),
        use `--bin-dir` option to specify it.

.. _QA suite documanetation: https://firebird-qa.readthedocs.io