Execute testes com pytest usando a extensão Databricks para Visual Studio Code
Este artigo descreve como executar testes usando pytest
a extensão Databricks para Visual Studio Code. Consulte O que é a extensão Databricks para Visual Studio Code?.
Você pode executar pytest em código local que não precisa de uma conexão com um cluster em um espaço de trabalho remoto do Azure Databricks. Por exemplo, você pode usar pytest
para testar suas funções que aceitam e retornam DataFrames PySpark na memória local. Para get iniciado com o pytest
e executá-lo localmente, consulte Get Iniciado na documentação do pytest
.
Para executar pytest
em código em um espaço de trabalho remoto do Azure Databricks, faça o seguinte em seu projeto do Visual Studio Code:
Etapa 1: Criar os testes
Adicione um arquivo Python com o código a seguir, que contém seus testes a serem executados. Este exemplo pressupõe que esse arquivo é nomeado spark_test.py
e está na raiz do seu projeto Visual Studio Code. Esse arquivo contém um pytest
acessório, que torna o cluster SparkSession
(o ponto de entrada para a funcionalidade do Spark no cluster) disponível para os testes. Esse arquivo contém um único teste que verifica se a célula especificada no table contém o valor especificado. Você pode adicionar seus próprios testes a este arquivo conforme necessário.
from pyspark.sql import SparkSession
import pytest
@pytest.fixture
def spark() -> SparkSession:
# Create a SparkSession (the entry point to Spark functionality) on
# the cluster in the remote Databricks workspace. Unit tests do not
# have access to this SparkSession by default.
return SparkSession.builder.getOrCreate()
# Now add your unit tests.
# For example, here is a unit test that must be run on the
# cluster in the remote Databricks workspace.
# This example determines whether the specified cell in the
# specified table contains the specified value. For example,
# the third column in the first row should contain the word "Ideal":
#
# +----+-------+-------+-------+---------+-------+-------+-------+------+-------+------+
# |_c0 | carat | cut | color | clarity | depth | table | price | x | y | z |
# +----+-------+-------+-------+---------+-------+-------+-------+------+-------+------+
# | 1 | 0.23 | Ideal | E | SI2 | 61.5 | 55 | 326 | 3.95 | 3. 98 | 2.43 |
# +----+-------+-------+-------+---------+-------+-------+-------+------+-------+------+
# ...
#
def test_spark(spark):
spark.sql('USE default')
data = spark.sql('SELECT * FROM diamonds')
assert data.collect()[0][2] == 'Ideal'
Etapa 2: Criar o corredor pytest
Adicione um arquivo Python com o código a seguir, que instrui pytest
a executar seus testes da etapa anterior. Este exemplo pressupõe que o arquivo é nomeado pytest_databricks.py
e está na raiz do seu projeto Visual Studio Code.
import pytest
import os
import sys
# Run all tests in the connected directory in the remote Databricks workspace.
# By default, pytest searches through all files with filenames ending with
# "_test.py" for tests. Within each of these files, pytest runs each function
# with a function name beginning with "test_".
# Get the path to the directory for this file in the workspace.
dir_root = os.path.dirname(os.path.realpath(__file__))
# Switch to the root directory.
os.chdir(dir_root)
# Skip writing .pyc files to the bytecode cache on the cluster.
sys.dont_write_bytecode = True
# Now run pytest from the root directory, using the
# arguments that are supplied by your custom run configuration in
# your Visual Studio Code project. In this case, the custom run
# configuration JSON must contain these unique "program" and
# "args" objects:
#
# ...
# {
# ...
# "program": "${workspaceFolder}/path/to/this/file/in/workspace",
# "args": ["/path/to/_test.py-files"]
# }
# ...
#
retcode = pytest.main(sys.argv[1:])
Etapa 3: Criar uma configuração de execução personalizada
Para instruir pytest
a executar seus testes, você deve criar uma configuração de execução personalizada. Use a configuração de execução baseada em cluster Databricks existente para criar sua própria configuração de execução personalizada, da seguinte maneira:
No menu principal, clique em Executar > Adicionar configuração.
No Command Palette, selectDatabricks.
O Visual Studio Code adiciona um
.vscode/launch.json
arquivo ao seu projeto, se esse arquivo ainda não existir.Altere a configuração de execução inicial da seguinte maneira e salve o arquivo:
- Altere o nome desta configuração de execução de
Run on Databricks
para algum nome de exibição exclusivo para esta configuração, neste exemploUnit Tests (on Databricks)
. - Mude
program
de para o caminho no projeto que contém o executor de${file}
teste, neste exemplo${workspaceFolder}/pytest_databricks.py
. - Mude
args
de[]
para o caminho no projeto que contém os arquivos com seus testes, neste exemplo["."]
.
O seu
launch.json
ficheiro deve ter o seguinte aspeto:{ // Use IntelliSense to learn about possible attributes. // Hover to view descriptions of existing attributes. // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 "version": "0.2.0", "configurations": [ { "type": "databricks", "request": "launch", "name": "Unit Tests (on Databricks)", "program": "${workspaceFolder}/pytest_databricks.py", "args": ["."], "env": {} } ] }
- Altere o nome desta configuração de execução de
Etapa 4: Executar os testes
Certifique-se de que pytest
já está instalado no cluster primeiro. Por exemplo, com a página de configurações do cluster aberta em seu espaço de trabalho do Azure Databricks, faça o seguinte:
-
Na guia Bibliotecas, se pytest estiver visível, então
pytest
já está instalado. Se pytest não estiver visível, clique em Instalar novo. - Para Library Source, clique em PyPI.
- Em Pacote, digite
pytest
. - Clique em Install (Instalar).
- Aguarde até que o Status mude de Pendente para Instalado.
Para executar os testes, faça o seguinte a partir do seu projeto Visual Studio Code:
- No menu principal, clique em Exibir > Executar.
- No Executar e Depurarlist, clique em Testes de Unidade (no Databricks), caso não esteja já selecionado.
- Clique no ícone de seta verde (Iniciar Depuração).
Os pytest
resultados são exibidos no Console de Depuração (Exibir > Console de Depuração no menu principal). Por exemplo, esses resultados mostram que pelo menos um teste foi encontrado no spark_test.py
arquivo, e um ponto (.
) significa que um único teste foi encontrado e aprovado. (Um teste com reprovação mostraria um F
.)
<date>, <time> - Creating execution context on cluster <cluster-id> ...
<date>, <time> - Synchronizing code to /Workspace/path/to/directory ...
<date>, <time> - Running /pytest_databricks.py ...
============================= test session starts ==============================
platform linux -- Python <version>, pytest-<version>, pluggy-<version>
rootdir: /Workspace/path/to/directory
collected 1 item
spark_test.py . [100%]
============================== 1 passed in 3.25s ===============================
<date>, <time> - Done (took 10818ms)