「dbtモデルのユニットテストを実装するためのシンプル(かつ効果的な)アプローチ」

Simple (and effective) approach for implementing unit tests for dbt models.

dbtモデルのユニットテストは、dbtエコシステムの最も重要な欠落部分の1つでした。この記事では、標準とdbtのベストプラクティスに依存する新しいユニットテストのアプローチを提案しています。

Fabio Ballasina氏の写真(Unsplashより)

dbtがソフトウェアエンジニアリングのベストプラクティスをデータエンジニアリングの領域に導入して以来、その機能とその周辺のエコシステムは、データ変換のさらなる領域をカバーするために拡大し続けています。

しかし、「ソフトウェアエンジニアリングのベストプラクティスを用いたデータエンジニアリング」のパズルの中で、重要な一部であるユニットテストは未解決の問題のままです。

ユニットテストの重要性、それが「本番用に準備ができた」と呼ばれる前のコードのすべての行に対してなぜ重要であり、dbtのテストやデータ品質テストとは異なるのかについては、すでに見事に取り組まれて説明されています。しかし、1分間のエレベーターピッチでその重要性を要約するなら、次のようになります:

データエンジニアリングでは、一般的に2つの異なる要素をテストしたいと考えています:データとコードです。dbtのテスト(および他のデータ品質システム/ツール)はデータをテストすることを可能にし、ユニットテストはコードをテストすることを可能にします。

上記を考慮すると、コミュニティによるdbtのオープンソースのユニットテスト機能の向上(Equal Expertsのdbt Unit TestingパッケージやGoDataDrivenのdbtに特化したPytestプラグインなど)の試みが複数ありました。しかし、これらのパッケージは機能が制限されており、学習曲線が急です。

この記事では、よりシンプルでエレガントな異なるアプローチを紹介し、スケーラブルで信頼性のあるユニットテストプロセスを実装するために標準とdbtのベストプラクティスに依存しています。

モデルのユニットテスト vs. CTEs

アプローチに入る前に、ユニットテストを実行するレベルを定義しましょう。答えるべき質問は…

We will continue to update VoAGI; if you have any questions or suggestions, please contact us!

Share:

Was this article helpful?

93 out of 132 found this helpful

Discover more

人工知能

キャルレールの最高製品責任者、ライアン・ジョンソンへのインタビューシリーズ

ライアンは、初期のスタートアップからフォーチュン100の組織まで、多様なテクノロジーと製品開発のリーダーシップ経験を15年...

人工知能

「ジャスティン・マクギル、Content at Scaleの創設者兼CEO - インタビューシリーズ」

ジャスティンは2008年以来、起業家、イノベーター、マーケターとして活動しています彼は15年以上にわたりSEOマーケティングを...

人工知能

「シフトのCEOであるクリス・ナーゲル – インタビューシリーズ」

クリスはSiftの最高経営責任者です彼は、Ping Identityを含むベンチャー支援および公開SaaS企業のシニアリーダーシップポジシ...

人工知能

「ナレ・ヴァンダニャン、Ntropyの共同創設者兼CEO- インタビューシリーズ」

Ntropyの共同創設者兼CEOであるナレ・ヴァンダニアンは、開発者が100ミリ秒未満で超人的な精度で金融取引を解析することを可...

人工知能

「サティスファイラボのCEO兼共同創設者、ドニー・ホワイト- インタビューシリーズ」

2016年に設立されたSatisfi Labsは、会話型AI企業のリーディングカンパニーです早期の成功は、ニューヨーク・メッツ、メイシ...

人工知能

ファイデムのチーフ・プロダクト・オフィサー、アルパー・テキン-インタビューシリーズ

アルパー・テキンは、FindemというAI人材の獲得と管理プラットフォームの最高製品責任者(CPO)ですFindemのTalent Data Clou...