iOSを担当している高です。
開発しているとそれっぽいテストデータが欲しいってことが結構あります。今までは各々がローカルで都度スクリプト書いてるような状態で、僕の場合はトレタアプリの中に直接書いて都度書き捨ててる感じでした。 これは相当効率が悪いですし、自分用に書いたものは人にも共有しづらいという問題があったのでこれを機にツールを作ってみることにしました。
開発上の課題
iOS開発をする上でこの様な課題がありました。
- パフォーマンス確認のために大量データが欲しい
- テーブル数などの設定をかんたんに変えたい
- 外部連携が必要なテストデータが欲しい。けれどE2Eで作るのはちょっと大変
大量データは文字のごとくです。通信時間やアプリ上での描画パフォーマンスを確認するために想定される最大のデータを用意したい。データ作成が1回だけで良ければ手で作ってもいいのですが、トレタの場合日付が軸になるので次の日には過去データになってしまいます。そうならないように未来データとして作ると今度は毎回そこまで行くのが面倒という本末転倒なことになります。
テーブル数も現状アプリからは1テーブルずつでしか追加と削除が出来ません。これはユーザが使う分には問題無いのですが、テストで多様なデータを用意する場合には結構手間な作業になります。消すのも同様です。
外部連携が必要なテストデータに関してはアプリ上ではまずは表示の確認がしたいだけのことが多いです。charlesでレスポンスを書き換えたりしていたのですが、結構手間なこともあり、あまり実用的ではありませんでした。
octokit
言わずと知れたGitHubのAPIツールです。 https://octokit.github.io
コマンドラインからちょっとしたことをやりたい時なんかにoctokit.rb
を使ったりしますよね。こんな感じでトレタのAPIも触れるといいなぁと思いました。
toretakit
ということでtoretakit inspired by octokit
を作ってみました。
octokit.rb
と同じようにgemとして作っています。
予約データを作る
トレタで予約を作るために必要な最低限の情報はこれらになります。
- 予約日時
- 氏名(漢字)
- 氏名(よみがな)
- 電話番号
- 人数
氏名や電話番号にはfakerというgemを使いました。結構有名なgemなのでご存じの方も多いと思います。ただ、氏名に関してはfakerはふりがなに対応していないので、gimeiというgemを使いました。 gimeiの説明をREADMEから引用します。
gimei は、日本人の名前や、日本の住所をランダムに返すライブラリです。テストの時などに使います。似たようなライブラリにfakerがあります。fakerはとても優れたライブラリで、多言語対応もしていますが、ふりがな(フリガナ)は流石に対応していません。gimei はふりがな(及びフリガナ)に対応しています。
出現率の異なるランダム値が欲しい
テストデータを作るときに同じデータばかり作ってもしかたがないのである程度ランダムで作りたいことがあります。
例えばトレタの場合だと予約するときの人数はランダムで決めたい、みたいな感じです。ただこの時に本当に単純なランダムにしてしまうと2人の予約と10人の予約が同じ回数だけ出てくるという現実離れしたデータになってしまいます。
実際のデータではところどころ山があると思いますが、そこまで忠実に再現するのは既存データを洗ったりしないといけなくてちょっと大変なので簡単に大きい数字の方が出にくいようにしたいと思いました。
なんか良いアルゴリズムが無いかなと探したのですが見つからず、とりいそぎベタにこんな感じで対応してみました。数字の間隔はなんとなくです。
def rand_count() r = rand(100) case r when 99..100 then 10 when 96..99 then 9 when 93..96 then 8 when 90..93 then 7 when 85..90 then 6 when 80..85 then 5 when 70..80 then 4 when 60..70 then 3 when 50..60 then 2 when 0..50 then 1 end end
何か良いアルゴリズムがあったら是非教えてほしいです!
どんなことが出来るようになったか
こんな感じでテーブル数が100の設定で、2回転しているデータ(かなりの繁盛店!)をそれっぽく作る、みたいなことが簡単にできるようになりました。
(人数が固定になってますが、先ほどのランダムロジックはここではまだ使ってなくて他のところで使ってます)
また、他のPJでも使ってもらえるようになりました。
今後の展望
現状toretakit
はAPI通信とデータ生成が一緒くたになっているのでのちのち別gemとして切り出したいなと思ってます。
将来的には複数店舗さんのシミュレーションデータ生成ロジックを用意して、コマンド一発でそれっぽいデータが用意できるようにしたいなと思っています。
まとめ
僕は普段はSwift、たまにObjective-C(既存コード)という生活を送ってるのですが、こういったツール系で普段と違う言語・環境で開発するのも楽しいものですね。
引き続きエンジニアは募集中ですので興味のある方はチェックしてみてください!