“マイクロソフト 再始動する最強企業”を読んだ

数ヶ月前なのですが、マイクロソフト 再始動する最強企業 を読みました。 読んだ背景には色々とあるのですが、書いている内容が私の知っている最近の感じのものと同じ感じで良いものだったのでここに載せておこうと思いました。 GitHubのことなど、だいぶ新しいことも載っており、日本語として今のMicrosoftを読むには良い本かなと。More

[Android]Androidテスト全書は是非手にとって読んでほしい1冊

Androidテスト全書が発売されましたね! とてもめでたい。 私はアーリーアクセスの段階で野次馬のようにいくつかコメントさせていただいたりしました。また、推薦コメントとしてトップにも記載していただいて、大変ありがとうございます。 個人的には、このような書籍が私の学び始めの頃にあればとても知の高速道路を走れたのでは感が満載のものだと感じます。”テスト”という一言で丸っと全体を包むのではなく、いくつかレイヤーも分けつつ分解しているのもとても良いですよね。様々なレイヤーで目的に合わせながらテストの実行環境が整っていく(であろう)これからの市場ですが、それらを利用するにあたり基礎となるものだと感じています。 なおここでいう”テスト”は、一律、開発者テストやテストエンジニアによりテストコードを書いていくという範囲での話に焦点を当てます。 2, 3章 多くは実装やアーキテクチャに依存することも多い話ですね。この書籍では、巷でみる(最近)よく使われるライブラリを使ったテストの書き方のほか、テストタブルの考え方まで踏み込んだ箇所があります。そのため、単なるツールの使い方ではなく、その必要性や用途などまで学ぶことができるのではないでしょうか。それらはAndroidというものに限らないところも多いので、iOSやそのほかのWeb系の話に流れたとしても、転用のきく知識となるかと思います。 ここはコードも多く出るので、読みながら写経しながら進めることが一番良いと感じています。 4, 5, 6章 UIテストのEspresso, Appiumを使った話。 これら、結構比較構造で紹介される場面も見ますね。同じ”UIテスト”という言葉として。ただ、多少はカバーする分野がかぶってますが、私は全く対立するものではないと思っています。(Appium自体、Espresso/uiautomator2を経由して色々とした操作を実現していますし。) そこらへんも説明されたり、具体的な実装の話まで踏み込まれています。 最近だと AppiumのAIによる要素セレクタを試してみたら、自動テストの未来を感じた でも取り上げられましたが、Appiumをモバイルアプリ操作のフレームワークとしてツール群の間に挟むことで、それよりも上のレイヤで様々な取り組みを実施できるなどもあります。これもEspressoだけを中心とした形式で、test.ai のような企業が独立して取り組むには難しい面もありますね。 Espressoの方がとても良い場面も多くあります。そのため、私は Test automation design for Cookpad’s global Android app というブログを、クックパッドの海外事業部のページに投稿しました。そこでは、EspressoもAppiumも(後者は将来的に、ですが)使う流れを載せています。 適材適所で使おう、という話ですね。個人的な日本・世界での活動をベースにすると、両方を行き来できる人は非常に限られていて、そういう人がいる組織は方針の選択など含めてとても強いのだと感じました。私が見た世界の中では、純粋なAndroid開発者だけしかいない(開発者人数も限られている)ところは大体はEspressoですが、Test/QAエンジニアをもつところは大体はAppiumを利用しているようです。その両方を行き来できる人は選択しているぽいです。ただ、Agodaのように色々と判断を倒しているようなところもいくつかあるようですね。 いずれも、Espressoを使うところは単機能(or 1つのView)における実装の確実さを担保していきたいというモチベーションが大きいように思えます。私たちもそんな感じでした。ユーザのシナリオや、実環境に近しいところを対象にしようとしたらAppiumの比率が高くなるという感じでしょう。HeadSpinのように、物理的にもよりユーザに近しいところのテストを世界各国で実施できる環境では、Appiumの方が多数のようです。 7章 JUnit5の話ですね!私もいくつか触ったことがありますが、まだJUnit5を少なくとも10人以上でガシガシ開発しているような組織にはほいそれと導入はできなかったですが。。(JUnit4 のRuleを使ったものもそれなりに持っているプロジェクトですし) JUnit5のいくつかのアノテーションなどは個人的にも導入して行きたいと思っていたものです。なので、JUnit5が成熟して、Androidの標準ライブラリ周辺でも特に壁なく利用できるところまでいくと良いなと思います。 Jetpackとして丸っとした開発ツールの公式化が進みましたし、その中にJUnit5が入り始めるとガッと世界は進みそうだと感じます。 8章 CI/CD環境はモバイルの場合は特に、最近も頭を抱えますね…CircleCIは鉄板だと思います。OSSでしか触れてはないのですが、最近だと性能改善もだいぶ見られるようですね。 私は、1000件程度のnon-UIテスト、40件行かないくらいのEspressoによるUIテストを実装していたプロジェクトにおいて、lint, 全テストをPush毎に、10分以内で全てを終わらせるためにx3 Speed Up Android CI at Cookpadという構成を取っていました。その結果、多くの場合は6分~7分程度で、テストなど含めて開発のフィードバックサイクルを回せるようにしていました。この書籍でいう、”コミットステージ”でEspressoによるUIテストも含めて完了させていた、という感じです。ただ、その環境はAWS上で動作するJenkin環境でした。 それとは別に、将来的には定期的にUIテストの、ユーザ受け入れレベルのものを実施したいとも思っていました。(が、そこらへんは環境の成熟など含めてまだ手軽ではないですね。。。)これにより、手動テストステージの多くは省ける + パフォーマンス系のあたいもここで取得できる状態には持っていけると思います。 先にも書きましたが、これからは用途に応じたテスト実行環境が成熟していく時期だと思うので、読者の皆様は待っておいてもらえると良さそう。(私はそういうところで少しの間、時間を使うことにしました。) 余談 いくつか私も情報の整理のためにAndroid向けの砂場repository とか、iOS向けの砂場repository…More

Read “Are Your Lights On?”

Are Your Lights On? by Gerald M Weinberg and Donald C Gause. I reread the book since he has gone. The book remembers us we must consider many things and perspectives whenever we face defects, etc. Through the book, below sentences probably stay in your brain. They will remain there. They help you when you…More

“プロフェッショナル IPv6″を読んだ

Read Professional IPv6 を読んだ。 少し読みかじってただけなのですが、主には出張中の飛行機の中で読みました。 内容は、IPv6をベースとした、原理に近い話。大学の頃だとv4の知識がメインで、その後、私はv6は聞きかじる程度でした。なので、この書籍のように全体を把握し、必要な時に詳細を見ることができる書籍はありがたいものでした。 内容としては、大学でちゃんと学ぶような感じのものから、序盤は誰でもとっつきやすいようにわかりやすい言葉を使ったりしていましたね。 パケットの中身まで正確には把握していなかったのですが、そこらへんまで詳しく書かれていたことに驚きました。ただ、パケットを解析する何かとか作らない限り、このレベルのものが100%必要になる、という類のものでもないですね。 そういえば、恥ずかしながらエニーキャストという言葉を知らなかった。ブロード/ユニ/マルチはよく聞くし、大学ででも学んでいたよくあるものなのですが。ただ、読んでるとなるほどという感じ。DNSサーバ間とか。 あと、トンネルの話とか、最後の巻末付録ではNTTさんの実際の話があったりと、良い感じでした。面白かったです。 全体を読んで、これはざっと知ったあとは、必要な時に参照する辞書/参考書に近いものになる良い本棚と思いました。More

Read “INSPIRED”

Read INSPIRED: How to Create Tech Products Customers Love. A product owner heavily talked roles based on this book. Thus, I also read this book to understand him and make easy to communicate with high context. My impression of the book is excellent to learn definitions of each role to develop products. Of course, we…More

read “しぐさの日本文化”

しぐさの日本文化を読んだ 精神科医のとある方が長年読んでいるという話をきき、どういう内容なのか気になったのでKindle版で購入して読んでみた。 日本文化を様々な”しぐさ”から分析していくというもの。 例えば、”頑張る”という言葉は、本来は”我意を固執して譲らないこと”という意味。あまりよくない意味として使われる言葉であった。共同体の成員の中で、風変わりな主張をすることを背景にもつ。 “へだたり”という言葉。この言葉は距離感からきている。日本人に置ける”距離感”、西洋に置ける、など、様々な文化を”へだたり”という観点から論じている。 “触れる”という仕草。触れることへの神経さを、日本、西洋など、いくつか事例をのせながら”触れる”に関する言葉なども。心に触れる、身体に触れる。 “なじむ”。”幼なじみ”など。 はたまた、ヨーロッパにあって日本に移植されなかったしぐさに関しても論じている箇所がある。論理と雄弁。当時の、雄弁の目的である”説得”という行為の必要さの違いなど。身体を使った感情表現もこの雄弁の一部である。ここから”一人称の呼び方の多様さ”も日本文化として非常に面白いものだという話にも広がっている。 確かに、勤労・OSSの世界などで日本文化以外の人とコミュニケーションをとると(さらには直接)、身振りなんかは非常に大事な要素になることを実感している。自分の状態を相手に伝える為に。また、英語だと表現として一番伝えたいことを文章の前に持っていく、とか。 いずれにせよ、久しぶりに精神科医の世界の文書を読んだ気がする。日本以外の文化を経験した後に読むと、なおのこと、色々と納得いったり経験と照らし合わせることができて面白いですね。More

Read “Continuous Delivery with Spinnaker”

I read Continuous Delivery with Spinnaker to catch up with Spinnaker and the bases. Recent my profession is mobile, but I have some experience/knowledge of distributed systems since I studied the Byzantine General Problems in my university. And I also has caught up with network/tools/fundamentals associated with it. (Especially testing and monitoring topics.) You can…More

Read “A Practical Guide to Testing in DevOps”

A couple of weeks ago, I read A Practical Guide to Testing in DevOps The book explained and described DevOps x Testing with many references and keywords. you can see why people struggle to understand where testing fits in a model that doesn’t mention it at all. For me, testing fits at each and every…More