こんにちは。あすかです。Housmartでは普段Swiftで開発していることもあり、 try! Swift TOKYOというSwiftのカンファレンスに参加して来ました!
try! Swiftは世界中のSwiftディベロッパーが一堂に会し、Swiftに関する知見を共有するカンファレンスです。参加人数は、昨年の約1.5倍の733人だったそうですごい熱気に包まれていました!会期は2017年3月2日-4日の3日間、うち2日、3日は招待講演とライトニングトーク、4日はハッカソンが開催されました。
今回参加の目的
HousmartはReTech(不動産テック)スタートアップで、中古マンション売買サービス「カウル」をメインのサービスとして運営しています。このサービスを使うことで中古マンション売買の際、ユーザーの方が自分でマンションデータベースから中古マンション物件情報、相場、新築価格、売買事例、間取りを確認し、見学に行くことができます。
また、メインのサービス以外にも、ユーザがマンションの情報を検索できるカウルライブラリー、マンション購入のノウハウを載せたマンションジャーナルというメディアの運営をしています。
これらのサービスでアプリ開発を行っており、①開発で使っている言語のトレンドを知りたい、②面白い発表から学びたいと思いカンファレンスに参加しました。
今回は、カンファレンスにて気になった発表を3つ紹介させていただきます。
try! Swift全体の構成
まず、全体の構成についてです。カンファレンスでの発表は全部で約32個で、内容は以下のような構成でした。
サーバーサイドSwiftや機械学習・DeepLearningの話が結構でてきた印象でした。プロダクト作り全体のドラマティックな話、ReactNative開発のメリット・デメリット比較、Swift on Android話などもあり、Swiftだけでない話題も豊富でした。
気になった発表3つ
①Client-Side Deep Learning by Shuichi Tsutsumi
堤(@Shu223)さんのクライアントサイドで行うディープラーニングのプレゼンが印象的でした。
ディープラーニングは強力なコンピューティングパワーが必要なので、従来はモバイルデバイスでやるものではなかったのですが、iOS 10でMetal Performance Shadersフレームワークに追加された畳み込みニューラルネットワーク(CNN)のAPIにより、クライアントサイドのGPUで学習済みCNNの計算を行えるようになったというお話でした。
つまり「ユーザの手元で」「オフラインでも」昨今の進化がめざましいディープラーニングの成果を利用できるようになったということでカウルアプリでも使えると面白いなと思いピックアップさせていただきました。堤さんのLTでは実装のオーバービューと、デモを見せていただきました。
②Realmを使ってコラボレーションアプリを作る by Marius Rackwitz
このプレゼンでいうコラボレーションアプリというのは、Google Docs/Slack/JIRA等の複数のユーザーが同時進行で作業をすることができるアプリのことでした。
-
Realmの利点
・オブジェクト思考で書け、クラスを実装するように書ける
・React NativeやXamarinにも対応しているので、クロスプラットフォーム
・すべての環境で同じデータを使いまわせるので、バックアップがとれる
・トランザクション管理をしているので、リアルタイムの共同編集ができる
・サーバー、モバイルの両方でRealmを採用すれば、アプリからJSONを排除することが可能 -
Realmの通知機能
・プロパティの変更、オブジェクトの変更、コレクションの変更、ファイルの変更など、様々な変更に対して通知を行える
・イベントハンドリング -
アクセス権の管理
・Admin Realm, Management Realm, Permission Realmなどの特別なRealmを使えば、アクセス権の管理が可能
とのことで、3の内容が特に興味深かったです。
③クックパッドアプリのテストを味わう by KazuCocoa
クックパッドでは、テストの項目でUIテストが一番多くなってしまうらしく、UIテストを自動化することでクラッシュレート減少に成功したという事例について紹介いただき大変参考になりました。
-
Cookpadアプリの状況
グローバルアプリと日本アプリの2つがあり、統合はまだしておらず、UIコンポーネントは複数大きく変えているそうで、だいたい10万行ぐらい。以前は2週間、最近は1ヶ月毎にアップデートしている状況。 -
kano-model という品質モデル
・Attractive – Must-be Qualityの2つのパラメータ
・Diachronic Quality for mobile -
UIテストのやり方
まず、テストを書いてからリファクタリングを行うそうです。マニュアルテストは簡単に出来ますが、ユニットテストは時間がかかります。しかし、理想はその逆です。
そこで、Cookpadでは2015年-2017年にかけてUIテストの自動化を行い、クラッシュ率を下げ続けたそうです。 -
UIテストの書き方
①シナリオを書く
②シナリオをRubyコードに変換
③Appiumで実行
XPathはOSのフレームワークにかなり依存していて、テストをUIレベルからメソッドレベルに移動することが大事とのことでした。
クックパッドでは、数ヶ月前にSwiftを実装し始めたらしく、テストがあるので安心してSwiftの実装出来るようになったそうです。このような工夫でクラッシュ率の低い安定したサービスを提供していきたいと思いました。
参加して感じたこと
① Twitter(@tryswift)投稿やSlackが活発で、発表の後に会場外でも登壇者へのQAコーナが用意されていて、とても交流しやすい雰囲気でした。
(@k_katsumiさん、運営者のみなさんありがとうございます!)
②最前列で聞き起こしをして登壇もしているniwatakoさんのコミュニティへの貢献度がすごいと思いました。(niwatakoさんありがとうございます!)
③電源が各テーブルになく、バッテリーが必要だったので常に電源が気になりました。
④同時通訳の方の熱がこもっていて応援したくなりました。(トランシーバーが2台戻っていないそうなので、間違えて持って帰ってしまった方は@tryswift運営の方へ連絡しましょう。)
⑤お弁当の種類を選べ、コーヒーやジュースがいつでも飲めて快適でした。
最後に
Swiftの盛り上がりを体感し、Swiftディベロッパーの方々と交流を深める良い機会となりました!参加者の皆さん、運営の皆さんありがとうございました!