Skip to main content

Hypothesis strategies for Awkward Array

Project description

hypothesis-awkward

Hypothesis strategies for Awkward Arrays.

pypi-badge pypi-python-badge

test-badge codecov-badge

Hypothesis is a property-based testing library. Its strategies are Python functions that strategically generate test data that can fail test cases in pytest and other testing frameworks. Once a test fails, Hypothesis searches for the simplest sample that causes the same error. Hypothesis automatically explores edge cases; developers do not need to craft test data manually.

Property-based testing is useful for finding edge cases in array libraries and in code that uses them. In fact, Hypothesis strategies for NumPy and pandas data types are included in Hypothesis itself. Xarray provides strategies for its data structure. The Apache Arrow codebase has strategies for PyArrow, which are not officially documented in its API reference.

This package, hypothesis-awkward, is a collection of Hypothesis strategies for Awkward Array, which can represent a wide variety of layouts of nested, variable-length, and mixed-type data. The current version of this package includes strategies that generate samples with certain types of layouts. The goal is to develop strategies that can generate fully general Awkward Arrays with multiple options to control the layout, data types, missing values, masks, and other array attributes. These strategies can help close in on edge cases in tools that use Awkward Array, and Awkward Array itself.

[!NOTE]

This package is early work in progress and still experimental. The APIs may change over time.

Installation

You can install the package from PyPI using pip:

pip install hypothesis-awkward

This also installs Hypothesis and Awkward Array as dependencies unless they are already installed.

The strategy arrays()

The function arrays() is the main strategy. It is currently experimental and developed in strategies/constructors/. The plan is to have arrays() generate fully general Awkward Arrays with many options to control the output arrays.

Sample outputs of arrays()

You can see sample outputs of the current version of arrays() in the test case:

from hypothesis import given

import awkward as ak
import hypothesis_awkward.strategies as st_ak


@given(array=st_ak.constructors.arrays())
def test_array(array: ak.Array) -> None:
    print(f'{array=!r}')

For example, this might print:

array=<Array [] type='0 * bool'>
array=<Array [0] type='1 * int16'>
array=<Array [1.72e-11, -3.4e+38, -3.4e+38, -4.05e+15] type='4 * float32'>
array=<Array [[], [], [], []] type='4 * var * 2 * timedelta64[W]'>
array=<Array ['', "e\U00034a9e'"] type='2 * string'>
array=<Array [[], ['char']] type='2 * var * string'>
array=<Array [[b'\xd7']] type='1 * var * bytes'>
array=<Array [[[], []], [[]], [], []] type='5 * var * var * 4 * unknown'>
array=<Array [] type='0 * unknown'>
array=<Array [{Rd: []}] type='1 * {Rd: var * datetime64[s]}'>
array=<Array [(''), (..., ...), ..., (..., ...), ('\U0005f041')] type='6 * (string)'>
array=<Array [False] type='1 * union[bytes, bool]'>
array=<Array [36, [b'\x92\xa7\x0b']] type='2 * union[int8, 1 * bytes, unknown]'>
array=<Array [b'5f\x18\xbc', ..., b'5f\x18\xbc'] type='3 * union[string, bytes]'>
array=<Array [0, 0, -5.53e+16] type='3 * union[float32, unknown]'>
array=<Array [??, ??, ??] type='3 * uint32'>
array=<Array [(??, ??)] type='1 * (bytes, union[timedelta64[M], bytes])'>
array=<Array [??, ??, ??, ??, ??] type='5 * var * var * (uint64, bytes)'>

The current version generates arrays with NumpyArray, EmptyArray, string, and bytestring as leaf contents that can be nested multiple levels deep in RegularArray, ListOffsetArray, ListArray, RecordArray, and UnionArray. Arrays might be virtual, shown as ?? in the output.

The API of arrays()

def arrays(
    *,
    dtypes: st.SearchStrategy[np.dtype] | None = None,
    max_size: int = 10,
    allow_nan: bool = False,
    allow_numpy: bool = True,
    allow_empty: bool = True,
    allow_string: bool = True,
    allow_bytestring: bool = True,
    allow_regular: bool = True,
    allow_list_offset: bool = True,
    allow_list: bool = True,
    allow_record: bool = True,
    allow_union: bool = True,
    max_depth: int = 5,
    max_length: int | None = None,
    allow_virtual: bool = True,
):
Parameter Description
dtypes A strategy for NumPy scalar dtypes used in NumpyArray. If None, the default strategy that generates any scalar dtype supported by Awkward Array is used. Does not affect string or bytestring content.
max_size Maximum total number of elements in the generated array. Each numerical value counts as one. Each string and bytestring (not character or byte) counts as one.
allow_nan No NaN/NaT values are generated if False.
allow_numpy No NumpyArray is generated if False.
allow_empty No EmptyArray is generated if False.
allow_string No string content is generated if False. Each string (not character) counts toward max_size. String layers do not count toward max_depth. Unaffected by dtypes and allow_nan.
allow_bytestring No bytestring content is generated if False. Each bytestring (not byte) counts toward max_size. Bytestring layers do not count toward max_depth. Unaffected by dtypes and allow_nan.
allow_regular No RegularArray is generated if False.
allow_list_offset No ListOffsetArray is generated if False.
allow_list No ListArray is generated if False.
allow_record No RecordArray is generated if False.
allow_union No UnionArray is generated if False.
max_depth Maximum nesting depth. Each RegularArray, ListOffsetArray, ListArray, RecordArray, and UnionArray layer adds one level, excluding those that form string or bytestring content.
max_length Maximum len() of the generated array. No constraint when None (the default).
allow_virtual No virtual arrays are generated if False.

Other strategies

In addition to arrays() mentioned above, this package includes other strategies that generate Awkward Arrays and related data types.

NumPy

These strategies are related to the section of Awkward Array User Guide "How to convert to/from NumPy".

Strategy Data type
from_numpy Awkward Arrays created from NumPy arrays
numpy_arrays NumPy arrays that can be converted to Awkward Array
numpy_dtypes NumPy dtypes (simple or array) supported by Awkward Array
supported_dtypes NumPy dtypes (simple only) supported by Awkward Array
supported_dtype_names Names of NumPy dtypes (simple only) supported by Awkward Array

Python lists

These strategies are related to the section of Awkward Array User Guide "How to convert to/from Python objects".

Strategy Data type
from_list Awkward Arrays created from Python lists
lists Nested Python lists for which Awkward Arrays can be created
items_from_dtype Python built-in type values for a given NumPy dtype
builtin_safe_dtypes NumPy dtypes with corresponding Python built-in types
builtin_safe_dtype_names Names of NumPy dtypes with corresponding Python built-in types

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hypothesis_awkward-0.7.2.tar.gz (125.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hypothesis_awkward-0.7.2-py3-none-any.whl (39.4 kB view details)

Uploaded Python 3

File details

Details for the file hypothesis_awkward-0.7.2.tar.gz.

File metadata

  • Download URL: hypothesis_awkward-0.7.2.tar.gz
  • Upload date:
  • Size: 125.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hypothesis_awkward-0.7.2.tar.gz
Algorithm Hash digest
SHA256 bafcbdee6bd948639da82cc533e102aac0cbd6bb9051c1038704f57cedfa6fd9
MD5 121b5b85279e151bc02dc3b02f1bb6a6
BLAKE2b-256 527a17f9956e791b35ebf9b0cd3383e165684ba4b63ac17294e9f9b64d5328b4

See more details on using hashes here.

Provenance

The following attestation bundles were made for hypothesis_awkward-0.7.2.tar.gz:

Publisher: pypi.yml on scikit-hep/hypothesis-awkward

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file hypothesis_awkward-0.7.2-py3-none-any.whl.

File metadata

File hashes

Hashes for hypothesis_awkward-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5a65e6d61420df36a983cba3e724fb46f5cd4f0dfae7e2723fa7bb34be8304cd
MD5 6258e87af3fb9e6e8f9ea2e8946f023a
BLAKE2b-256 9f1dcd6ad38cb78e03590172d30cce9ee2640c0fa7c2505c2e3fee59d6bfb37c

See more details on using hashes here.

Provenance

The following attestation bundles were made for hypothesis_awkward-0.7.2-py3-none-any.whl:

Publisher: pypi.yml on scikit-hep/hypothesis-awkward

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page