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.3k
Enumを自動で網羅的にテストしてみた
estie | エスティ
December 26, 2022
Tweet
Share
More Decks by estie | エスティ
See All by estie | エスティ
Snowflake ML モデルを dbt データパイプラインに組み込む
estie
0
150
ユーザー価値を最大化するための爆速開発
estie
0
97
10年PMをやって気付いた4つのPMタイプ
estie
0
200
自動と手動の両輪で開発するデータクレンジング
estie
2
280
第1回 国土交通省 データコンペ参加者向け勉強会③- Snowflake x estie編 -
estie
0
280
PMとデザイナーが協働してプロダクトを最速で立ち上げるための一つのメソッド
estie
0
100
GraphQLでいい感じの検索APIを作りたい
estie
0
480
GraphQLにおけるページネーションベストプラクティス
estie
0
980
不動産 x AIことはじめ~データの真価を拓くために
estie
0
450
Other Decks in Programming
See All in Programming
아직도 SOLID 를 '글'로만 알고 계신가요?
sh1mj1
0
360
パスキーのすべて / 20250324 iddance Lesson.5
kuralab
0
130
PHPでお金を扱う時、終わりのない 謎の1円調査の旅にでなくて済む方法
nakka
3
1.2k
Kubernetesで実現できるPlatform Engineering の現在地
nwiizo
2
1.7k
goにおける コネクションプールの仕組み を軽く掘って見た
aronokuyama
0
140
GDG Super.init(version=6) - From Where to Wear : 모바일 개발자가 워치에서 발견한 인사이트
haeti2
0
560
RubyKaigiで手に入れた HHKB Studioのための HIDRawドライバ
iberianpig
0
1k
新卒から4年間、20年もののWebサービスと 向き合って学んだソフトウェア考古学
oguri
8
6.8k
SQL Server ベクトル検索
odashinsuke
0
120
Devin , 正しい付き合い方と使い方 / Living and Working with Devin
yukinagae
1
530
リアクティブシステムの変遷から理解するalien-signals / Learning alien-signals from the evolution of reactive systems
yamanoku
2
1k
プログラミング教育のコスパの話
superkinoko
0
120
Featured
See All Featured
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
Fantastic passwords and where to find them - at NoRuKo
philnash
51
3.1k
Stop Working from a Prison Cell
hatefulcrawdad
268
20k
Reflections from 52 weeks, 52 projects
jeffersonlam
349
20k
The Cost Of JavaScript in 2023
addyosmani
48
7.6k
The Art of Programming - Codeland 2020
erikaheidi
53
13k
Six Lessons from altMBA
skipperchong
27
3.7k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
30
2.3k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
28
1.6k
Keith and Marios Guide to Fast Websites
keithpitt
411
22k
BBQ
matthewcrist
88
9.5k
Rebuilding a faster, lazier Slack
samanthasiow
80
8.9k
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ではチームメンバーを募集しています!