mmag

ハマったことメモなど

MVPアーキテクチャってこうですかわかりません

世の中にはMVCやMVVMやMVPといったアーキテクチャがたくさん考えられています。そういうものに基いてアプリケーションを開発していくと、コードが整理されてメンテナンス性が上がったりテストしやすくて幸せなわけですが、本当に自分の書いているコードはこ…

新卒研修でgitについて座学をした

こんばんわ。 この度、勤務先のGMOペパボで新卒エンジニアの研修担当になりまして、その一環としてgitやGitHubについて1時間ほどお話をしました。 もっとgit from Joe_noh 手元でコミットしてプルリク出すとかはできる前提で、 コンフリクトしたときどうする…

ExUnitで不要なログを出力させないようにする

前回のエントリで、ExUnitには色々と便利なタグがあるということを書きました。 今日は、そのうちの1つcapture_logについて書きます。 使い所 例えばJWTを扱うためのライブラリjokenは、不正なトークンを与えると以下の様なログを吐きます。 21:17:51.385 [w…

ExUnitで特定のテストだけ実行・スキップする方法

特定のテストだけ実行する ファイル単位で指定して実行する mix testに引数を渡すことで、そのファイルだけテストを実行できます。 $ mix test test/my_test.exs 行番号を指定して実行する ファイル単位の指定に加えて、:5のように行番号を指定できます。 $ …

ExUnit.Caseのasyncオプションはfalseがデフォルト

直近の3エントリでは醜態を晒し、もう晒しきったと思いきや別のところで勘違いをしていたことがわかったので書いておきます。 Elixirでテストを書くときはExUnitを使うのが定石となっていまして、以下のような書き方をします。 defmodule App1Test do use Ex…

遅いと思ったときに原因を調べない奴は何をやってもダメ

昨日は遅いと思ったからといってすぐspawnするのはダメとか言っていたけど、もう少し前にやることがあるだろうがオイ、という話。 前々回のエントリで、 こんな遅かったっけ?と思いながらおもむろにspawn と書いた。「こんな遅かったっけ?」と思ったのにそ…

遅いと思ったからといってすぐspawnするのはダメ

昨日は遅いと思ったらとりあえずspawnとか言っていたのが、そうもいかなくなりましたという話。 昨日書いたやつがこれ。Rails Tutorialに沿って書いている。 ## priv/repo/seeds.exs alias PhMicroblog.{User, Repo} defmodule Helper do def insert_user!(n…

遅いと思ったらとりあえずspawn

以前にも書いたように、Rails Tutorialをphoenixでやってたやつをまたちょいちょい書いている。 その中で、seedでダミーのユーザを100人つくるというのがあった。かなり前にseedつくる用のパッケージ書いたなと思い出してメンテしてねぇやべぇとおもったけど…

Elixir 1.2.6がリリースされた

今から3、4時間前に、Elixir v1.2.6がリリースされていました。 github.com バグ修正はとりあえず置いといて、機能追加として以下があったようです。 Erlang 19のサポート RC 2まで来ているErlang/OTP 19をサポートするようになりました。 quote generated: …

はてなブログでElixirがsyntax highlightされるようになってた

さっきのエントリを書いているときに気づいたのだけれど、Elixirのコードにちゃんと色がつくようになっていた。これまでは文法やキーワードが似ているrubyを指定してお茶を濁していたのだけれど、今後はelixirと書けそう。いつからなんだろ。 比べてみるとこ…

Elixir 1.3から使える時間に関するsigil

Elixir 1.3から時間に関する構造体がいくつか定義されました。そのうちの3つ、Date, Time, NaiveDateTimeをつくるsigilが追加されています。それぞれ~D, ~T, ~Nです。 iexで~D(2016-06-04)と打っても、そのまま表示されてしまい何が作られているのかよくわか…

こういうプルリクはどうなんだろうか、という話

github.com github.com github.com github.com よいところ 読みやすくなる スペルミスが無くなる 用語が統一される よくないところ ノイズになる git blameが見づらくなる 大事なプルリクが埋もれる 誰も悪くないんだけどねぇ。 やるなら一気に1コミットで、…

ExUnitのdescribeとnamed setupについてもう少し丁寧に

今日の昼に書いたエントリはとても雑だったので、もう少し丁寧に書きます。 describe describe/2マクロを使うことで、複数のテストケースをまとめることができます。 defmodule MyAppTest do use ExUnit.Case, async: true describe "addition" do test "1 +…

ExUnitでdescribeが使えるようになった

昨日は小言を並べました。 ついさっきElixir 1.3.0-rc.0がリリースされていることを発見しました。 github.com 変更点を眺めていると、気になる一文が!! [ExUnit] Support for bundling tests together with describe/2 なんと!! 試す こんな風に使いま…

hexパッケージの名前付けについて小言を並べる

前回はvalidate_confirmationという関数のことを書きました。 今日はhexパッケージの名前はどうあるべきかについて思うトコロを書いていきます。 なんでこんなことを書こうと思ったかというと、hex.pmに"Naming your package"というセクションが設けられたか…

validate_confirmation/3 という存在を思い出した

一通り実装してから、Ecto.Changeset.validate_confirmation/3があったことを思い出してしまった。 model |> cast(...) |> validate_confirmation(:password) ってすると、passwordとpassword_confirmationの値が一致してるかチェックしてくれる。

mix test に --stale オプションが追加された

昨日は途中で寝ながらエントリを書きました。 さて、このプルリクで入った機能について書きます。 github.com mix testに--staleというオプションが追加されたよ、というものです。 --stale --staleオプションを付けると、前回のテスト以降に変更されたコー…

get_in/2 と Access.all/0 の処理を追っていく

昨日はAccessモジュールに入った便利関数についてのエントリを書きました。 今日はそれがどうやって実現されているのか読みます。今の時点での最新版はd24a263です。 Access.all/0 まずそもそもAccess.all()は何を返すのでしょうか。 def all() do &all/3 en…

Elixir 1.3に入るAccessモジュールの関数

先ほど、こんなTweetを見た。 Elixir v1.3 will have new accessors for nested data structures. Here is how to upcase all languages names in a map: pic.twitter.com/FNTTqjpDeP— Elixir Lang (@elixirlang) May 26, 2016 %{languages: [%{name: "elixi…

GenRouterってなんぞ

社内のElixir勉強会で↓のtalkを観た。 GenRouter, GenStageという新たなアイデアを検証中で、elixir-lang/gen_brokerにコードがあるとのこと。 github.com 見どころはたくさんあるけれど、今日はGenRouter。 GenRouterのmoduledocの最初の方 読んでく。 複数…

priv/repo/migrationsが無くてテストもできなかった

昨日はPhoenixアプリをちょっと書いたエントリを書きました。 そのプロジェクトは私物のPCでphoenix newして生成したものなのですが、会社のPCでgit cloneしてmix testとやったら何かエラー。 ** (Mix) Could not find migrations directory "priv/repo/migr…

npmから取ってきたBootstrapをBrunchを通してPhoenixで使ったりした

昨日は老いを感じるエントリを書きました。 懲りずにまた作り直しをちょこちょこと始めたのですが、やっぱりElixir楽しいですね、はい。 Rails Tutorialはこれで3回目くらいですが、昔やってたゲームを引っ張り出してきたような懐かしさが少しあります。 www…

そう、歴史は繰り返すのだ

今日ふと、「Rails TutorialをPhoenixでやってみてたことあったな」と思い、GitHubを漁ったところ、https://github.com/Joe-noh/ph_microblogというリポジトリが発掘されました。 github.com 最後のコミットは約1年前。phoenixのバージョンは0.9.0。 バージ…

Vector ClockとCRDTについて調べた

昨日 Vector ClockとCRDTsについて調べてるけどまだ上手く説明できない と泣き言を言った後、調べてなんとか書きました。actorの気持ちにはあんまりなってません。 言葉や概念の正確さが不安なので、詳しい方にぜひご教授頂きたいです。 Phoenix.Presence Ch…

Vector ClockとCRDTsについて調べてるけどまだ上手く説明できない

社内のElixir勉強会で↓のtalkを観た。 Phoenix Presenceを実装するためのベースになっているVector ClockとCRDTsについて調べたり議論したのだけれど、混乱して「よくわからんね」となったので宿題として調べている。色々わかってきて「こういうことかな〜」…

Elixir Meetup #2 でLTしてきた

できないことはPortで外注 from Joe_noh www.slideshare.net なんかkeynoteからPDFにしてslideshareに上げたら日本語消滅しました。 なのでpptxにしてから上げたので、フォントが意図したものじゃないのですがご勘弁ください。 自分が話したのは、Portモジュ…

Ecto 2.0.0-betaを試す (3)

今回はEcto.Multiです。 なにそれ Ecto.Multiとはそもそも何かというと、1つのトランザクション内で行われるべき複数のRepo操作をまとめるデータ構造です。DBを操作する前にどのような変更がなされるのか覗き見することができます。これの導入に伴い、before…

Ecto 2.0.0-betaを試す (2)

第2弾です。 今回はリレーションです。以前からあるhas_one, has_manyを復習し、新たに入ったmany_to_manyを試してみます。 TL;DR これ書いてる時点のコードはこちら。 github.com has_one User has_one Profile を作っていきます。Userは前回つくったので割…

Ecto 2.0.0-betaを試す (1)

はい。 Ectoはしばらく触っていなかったのですが、v2.0がもうすぐということで触ってみました第1弾。 まずはプロジェクトをセットアップして単純なinsertのテストを通すところまで。 TL;DR こちらに今日時点のコードがあるので、細かいとこは飛ばしていきま…

Poolboyメモ

社内勉強会でpoolboyで遊んでみて、いろいろ調べたのでこっちにも貼ります。 poolboyとは プロセスプールを管理してくれるErlangのライブラリ。poolboyはワーカープロセスをいくつか予め起動しておく。それらを利用したいクライアントは、poolboyに「どのプ…

テーマはFB matteをベースにしてます。作者さんに感謝を込めて。