Skip to main content

pytest plugin to run the tests with support of pyspark.

Project description

pytest plugin to run the tests with support of pyspark (Apache Spark).

This plugin will allow to specify SPARK_HOME directory in pytest.ini and thus to make “pyspark” importable in your tests which are executed by pytest.

Also it defines session scope fixture spark_context which can be used in your tests.

Install

$ pip install pytest-spark

Usage

Set Spark location

To run tests with required spark_home location just add “spark_home” value to pytest.ini in your project directory:

[pytest]
spark_home = /opt/spark

pytest-spark will try to import pyspark from specified location.

Using the spark_context fixture

Use fixture spark_context in your tests as a regular pyspark fixture. SparkContext instance will be created once and reused for the whole test session.

Example:

def test_my_case(spark_context):
    test_rdd = spark_context.parallelize([1, 2, 3, 4])
    # ...

Using the spark_session fixture (Spark 2.0 and above)

Use fixture spark_session in your tests as a regular pyspark fixture. A SparkSession instance with Hive support enabled will be created once and reused for the whole test session.

Example:

def test_spark_session_dataframe(spark_session):
    test_df = spark_session.createDataFrame([[1,3],[2,4]], "a: int, b: int")
    # ...

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

pytest-spark-0.3.0.tar.gz (3.0 kB view details)

Uploaded Source

Built Distribution

pytest_spark-0.3.0-py2.py3-none-any.whl (4.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pytest-spark-0.3.0.tar.gz.

File metadata

File hashes

Hashes for pytest-spark-0.3.0.tar.gz
Algorithm Hash digest
SHA256 fc5ef7b29ddb7aad97e99dadf102b6f316c4c65165fb139cf4ae56f00858300c
MD5 8d84aa94d8821a41594a0ab1b586873e
BLAKE2b-256 69152fad75b6a9a46fccbd372eaa790ec61a3840a97311d8fc22cbf40879e033

See more details on using hashes here.

File details

Details for the file pytest_spark-0.3.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_spark-0.3.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 6f3e7a81b494fb046f976a81946d475a64cb50a8528267d117af015d93efdabc
MD5 441f0cf15d7a2a51bda6673f37c933dd
BLAKE2b-256 816e4c3812dfe9bdc913dfb7087c2758c6e5f791a40c53a9a3fbac8ae8ebeed3

See more details on using hashes here.

Supported by

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