Implementing quality checks to maintain data integrity¶
In this section, you’ll learn how to implement quality checks for input data before building a Data Product. These quality checks help ensure that the data is accurate, complete, and ready for reliable analysis.
Scenario¶
As a data engineer, you’re working with datasets and exploring them on Workbench and Metis. Before using this data to create a Data Product, you need to validate its quality. Your task is to set up quality checks that verify the data's accuracy, completeness, and consistency, ensuring it meets the necessary standards for consumer use.
Define service level objectives (SLOs)¶
In the build stage, you and other stakeholders must have defined SLOs for your Data Product. These are measurable quality goals for the data that define what 'good quality' means for your Data Product.
Suppose the following are the SLOs you and other stakeholders have decided:
- Accuracy: 99% of data points must be accurate.
- Completeness: No more than 1% of records can have missing values.
- Freshness: Data must be updated within the last 24 hours.
- Schema: 100% of records must adhere to the expected schema.
- Uniqueness: 0.5% of records should be duplicated at maximum.
- Validity: 95% of records must meet all domain-specific rules.
Create a quality directory structure¶
Once your SLOs are defined, you can organize your quality check workflows. Create a quality directory to ensure that your Data Product's input meets the SLOs' requirements. Inside this folder, you'll organize your quality checks by creating subdirectories named 'input'. Each subdirectory will contain the specific Soda check workflows for each input dataset (e.g., customer.yml
, product.yml
, purchase.yml
).
Here’s an example of how your folder might look:
This structure helps you keep your quality checks organized and aligned with the defined SLOs for each input dataset.
Define quality checks with Soda¶
With your SLOs in place, the next step is to define the quality checks to ensure your data meets the established standards. These quality checks are essential to monitor and maintain the quality of your data. Below are the key quality checks available to you:
- Accuracy: Ensures the data values are correct and fall within expected ranges.
- Completeness: Checks for missing values or incomplete records, ensuring no critical data is omitted.
- Freshness: Verifies that the dataset is up to date, maintaining the reliability and timeliness of the data.
- Schema: Ensures the data's structure matches the expected formats, such as correct data types and column names.
- Uniqueness: Checks for duplicate records, ensuring each data point is unique within the dataset.
- Validity: Ensures the data meets business rules or domain-specific constraints, confirming that it aligns with predefined logic.
Each check will display the status of the last five runs, helping you track the data's ongoing compliance with your SLOs.
These quality checks will be implemented using the Soda framework and defined in YAML files for each dataset. After specifying these checks, they will be displayed on platforms like Metis and Data Product Hub, where data consumers can view the status of the quality checks and align them with their analytical needs.
For example, if you’re defining quality checks for a 'customer' dataset, your YAML file might include the following checks:
- Schema: The data type of birth year should be an integer.
- Accuracy: The average length of a country is more than 6.
- Completeness: Customer ID should not be zero.
- Validity: Customer ID should not be null.
- Uniqueness: Customer ID should be unique.
For the above quality checks, the Soda workflow yaml manifest file will look like as follows:
name: soda-customer-quality
version: v1
type: workflow
tags:
- workflow
- soda-checks
description: Applying quality checks for the customer data
workspace: public
workflow:
# schedule:
# cron: '00 08 * * *'
# # endOn: '2023-12-12T22:00:00Z'
# concurrencyPolicy: Forbid
dag:
- name: soda-customer-quality
spec:
stack: soda+python:1.0
compute: runnable-default
resources:
requests:
cpu: 1000m
memory: 250Mi
limits:
cpu: 1000m
memory: 250Mi
logLevel: INFO # WARNING, ERROR, DEBUG
stackSpec:
inputs:
- dataset: dataos://icebase:customer_relationship_management/customer
options:
engine: minerva
clusterName: system
profile:
columns:
- include *
checks:
- schema:
name: Data type of birth year should be integer
fail:
when wrong column type:
birth_year: string
attributes:
category: Schema
- invalid_count(customer_id) = 0 :
name: Customer Id should not be null
valid min: 1
attributes:
category: Validity
- missing_count(customer_id) = 0:
name: Customer Id should not be zero
attributes:
category: Completeness
- duplicate_count(customer_id) = 0:
name: Customer Id should not be duplicated
attributes:
category: Uniqueness
- avg_length(country) > 6:
name: Average length of country more than 6
attributes:
category: Accuracy
The quality checks are displayed in Metis as defined in the Soda YAML manifest file, including their descriptions, as shown in the image below.
Similarly, these quality checks are also populated on the Data Products Hub, as shown in the example below.
The Quality checks populating in the Quality tab of the Data Product Hub
Similarly, you define the following quality checks for the Purchase table:
- Freshness: This check ensures the 'purchase_date' is within the last 2 days. If the data is older than 2 days, this check will fail, indicating that the dataset is stale and may need to be refreshed.
- Schema: The schema check ensures that the 'recency' column has the correct data type (integer). If it's mistakenly typed as a string, the check will fail.
- Validity: This check ensures that the count of invalid entries in the 'mntwines' column is within a specified range (between 0 and 1). The check will flag the dataset as invalid if the count falls outside this range.
name: soda-purchase-quality
version: v1
type: workflow
tags:
- workflow
- soda-checks
description: Applying quality checks for the purchase data
workspace: public
workflow:
dag:
- name: soda-purchase-quality-job
spec:
stack: soda+python:1.0
compute: runnable-default
resources:
requests:
cpu: 1000m
memory: 250Mi
limits:
cpu: 1000m
memory: 250Mi
logLevel: INFO # WARNING, ERROR, DEBUG
stackSpec:
inputs:
- dataset: dataos://icebase:customer_relationship_management/purchase
options:
engine: minerva
clusterName: system
profile:
columns:
- include *
checks:
- freshness(purchase_date) < 2d:
name: If data is older than 2 days
attributes:
category: Freshness
- schema:
name: Data type of recency should be integer
fail:
when wrong column type:
recency: string
attributes:
category: Schema
- invalid_count(mntwines) < 0:
valid min: 0
valid max: 1
attributes:
category: Validity
title: Invalid count of mntwines