Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Enumを自動で網羅的にテストしてみた
Search
estie | エスティ
December 26, 2022
Programming
0
2.2k
Enumを自動で網羅的にテストしてみた
estie | エスティ
December 26, 2022
Tweet
Share
More Decks by estie | エスティ
See All by estie | エスティ
PMとデザイナーが協働してプロダクトを最速で立ち上げるための一つのメソッド
estie
0
9
GraphQLでいい感じの検索APIを作りたい
estie
0
200
GraphQLにおけるページネーションベストプラクティス
estie
0
230
不動産 x AIことはじめ~データの真価を拓くために
estie
0
230
Snowflakeで眠ったデータを起こそう!
estie
0
360
会社説明資料|株式会社estie / company profile
estie
9
180k
SnowflakeをRustで使おう!
estie
0
240
コアデータを起点にした商業用不動産の未来を導くマルチプロダクト戦略
estie
0
970
async_graphqlのguardが便利だった話
estie
0
740
Other Decks in Programming
See All in Programming
Pythonによるイベントソーシングへの挑戦と現状に対する考察 / Challenging Event Sourcing with Python and Reflections on the Current State
nrslib
3
1.3k
XP2024 っていう国際会議に行ってきたよの記
bonotake
4
240
Jakarta EE as Seen Trough the Lens of the ASF
ivargrimstad
0
120
Real-time message handling and notifications with API Platform and Symfony
alli83
1
110
MLOps in Mercari Group’s Trust and Safety ML Team
cjhj
1
120
実践Dash - 手を抜きながら本気で作るデータApplicationの基本と応用 / Dash for Python and Baseball
shinyorke
2
380
App Router 悲喜交々
quramy
7
380
2024-10-01 dev2next - Observability for Modern JVM Applications
jonatan_ivanov
0
120
ECS向けのドリフト検知機構を実装してみた
tkikuc
0
290
Why I Choose NetBeans for Jakarta EE
ivargrimstad
0
120
Quarto Clean Theme
nicetak
0
220
フロントエンドの現在地とこれから
koba04
10
4.5k
Featured
See All Featured
Why You Should Never Use an ORM
jnunemaker
PRO
53
9k
Building Adaptive Systems
keathley
38
2.2k
The Brand Is Dead. Long Live the Brand.
mthomps
53
38k
In The Pink: A Labor of Love
frogandcode
139
22k
Producing Creativity
orderedlist
PRO
341
39k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
PRO
7
580
Thoughts on Productivity
jonyablonski
67
4.2k
GitHub's CSS Performance
jonrohan
1030
450k
Into the Great Unknown - MozCon
thekraken
31
1.4k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
31
2.6k
ParisWeb 2013: Learning to Love: Crash Course in Emotional UX Design
dotmariusz
110
6.9k
WebSockets: Embracing the real-time Web
robhawkes
59
7.3k
Transcript
Enumを自動で網羅的にテストしてみた 2022/11/28 Rust、何もわからない….vol5 riano_ @riano_17
riano_です。 • 2022年8月からestieに参加 • estieではデータ管理サービスを作っています • Rustはestie入社から使い始めました • 趣味で競技プログラミングをしています 1
2 1. データサービスを作る上での不安 2. 楽に網羅的にテストしたい 3. やってみた:3行書き換えればOKになった 4. できなかったこと:1行書けばOKにはできなかった 5.
まとめ 今日の内容
データが壊れたらやばい! (あたりまえ)
4 データを変換しなければ、 入力された文字列をそのままバケツリレーすれば、 よほどのことがない限りミスはない しかし、複雑な不動産データをシンプルに扱うためにはそれではいけない 坪99999円、月1,999,999円、88888円 ... データをシンプルに扱うために(非自明な)構造化が必要
5 データのパターン化をおこなっている (空調設備の例) バックエンドでの構造化の例 バックエンド DB
6 複数回のデータ変換を行う 特に、データベース(MySQL)への書き込み時に符号化を行っている 書き込みと読み取りの順番を間違えて実装してしまったら? 変換を行うからこそ、ミスが生じる可能性がある
7 • エラーが起きることもない • 知らないうちにデータが壊れていく • (まさに立ち上げ中のサービスなので) データ列の追加もあれば、項目の追加もある • 全パターンのテストを書く
... ? ミスが起きてしまったら、取り返しがつかない→どうするか?
楽に網羅的にテストしたい!!
9 全てをテストしたいわけではない APIテストなどで全ケース網羅するのはコストが高い 結合テストは重要な挙動を、単体テストはリスクに応じた網羅度で データベースへの読み書きはリスクが高そうな部分 その正しさを保証しながら、開発スピードを維持できる方法はないか? 正しさの保証と、開発スピードを両立させたい
10 例えば、for ループのように書けてしまえば、 定型文を書くだけ&項目が増えても自動的にテストが対応してくれる 例えばこんなことができればいいな
やってみる
12 使ったもの • 既存の開発環境(sqlx, MySQL) • every_variantというcrate (https://github.com/TotalKrill/every_variant) crateを1つ導入してやってみた
(再掲:EveryVariantマクロを定義しておく) 13 Enum型への実装例
テストの例: Building構造体の中で 空調のパターンを 全てテストしている 14 Enum型への実装例
テスト結果: 15 Enum型への実装例
16 実は類似の機能を持つクレートが他にもあったが、選んだ理由 • 数値や文字列を持つenumに対応している • enumやoptionを含む構造体にも適用できる このcrateを選んだ理由、メリットについて
メンバーにEnum型を持つやや複雑な構造体にも適用可能 17 やや複雑な構造体でやってみる
同じようにテスト可能 18 1つ上位の構造体でやってみる
テスト結果: 19 1つ上位の構造体でやってみる
20 ちなみに、どんな原理でやっているの? →Enumを構文解析して、vectorにpushするマクロを生成 (マクロを生成する関数の先頭部分) 原理を調べてみる
21 • proc_macroによる生成について(実例あり) https://qiita.com/yagince/items/546d86588aaa3fdb3c94 • もう少し詳しめに、synクレートやquoteクレートも紹介 https://techracho.bpsinc.jp/yoshi/2020_12_24/102304 参考文献の紹介
22 • 構造体の名前を返す関数をマクロで作成 ちょっと手を動かしてみる
23 • フィールド名と その型を取得 ちょっと手を動かしてみる
24 • このように動作する →これをめちゃめちゃ 発展させると、 Every_variantになる ちょっと手を動かしてみる
コピペして3行書き換えれば テスト完了!!
26 関数に構造体を渡せば1行でテスト完了!なら理想 ... 構造体をテンプレート化することはできる フィールド名を変数として扱うにはマクロが必要そうだが、 マクロに別の箇所で定義した関数を盛り込むのが難しそう... 何もわからないので、教えてください! 関数化して1行で書けるようにできれば理想だった
安心感と省力化を追い風に 開発を加速させます! (やることは無限にあるので)
estieではチームメンバーを募集しています!