Introduction to Query Testing#

Intro#

We are using pytest as a testing framework. If you are not familiar with it you can view the small example by the link above. The reason why pytest framework was chosen:

  • easy to read and write test

  • auto discovery feature, that allows you to execute all available tests using only one command, because it finds every test starts with test_ prefix in every subfolder.

  • many useful plugins, we are suing some of them to evaluate memory consumption, time of execution, coverage and mocking.

Constructing Ticks#

Onetick python library (otp) has many sources that allow you to work with data. Ticks - is one of the most important in terms of testing. This source allows you to generate tick flow. Let’s consider an example:

ticks = otp.Ticks({'PRICE': [13.5, 13.6, 13.3],
                   'QRY'  : [ 100,  200,  150]})

# .to_dataframe() executes the query and converts ticks into pandas DataFrame
print(ticks.to_dataframe())

This code will print the following data:

                     Time  PRICE  QRY
0 2003-12-01 00:00:00.000  13.5   100
1 2003-12-01 00:00:00.001  13.6   200
2 2003-12-01 00:00:00.002  13.3   150

The first field Time is created automatically. It defines the timestamp of the tick. We will describe how the one can change the default value later. PRICE and QRY are user-defined fields. String, float, int as well as milliseconds and nanoseconds datetimes are supported for now.

Using sessions#

Every onetick.py code should be run inside a otp.Session. Session is a special singleton-object, in technical terms it is a wrapper for the OneTickLib library, that is responsible for the integration with OneTick database and keeping different config files.

Warning

It is allowed to have only one alive instance in the process.

Every code that works with OneTick through OneTick python API, onetick-py or tests should be in scope of Session.

Note

The only one case is exception, when ONE_TICK_CONFIG environment variable is set; for that case Session object declaration is ignored. In the most cases it is not related to tests, but It’s very important thing to know: make sure that ONE_TICK_CONFIG environment is not set when you run tests.

onetick.py.session.Session class allows to manage config files, locator files, acl files and licenses.

The simplest session is the following:

import onetick.py as otp
s = otp.Session()  # All required configs will be automatically generated.
s.close()

To simplify session cleanup process otp.Session class implements context manager protocol.