ZIPCODA API を使って、郵便番号の逆引きをした

概要 住所の一覧から郵便番号をまとめて逆引きしたかったので、 ZIPCODA API を使って実現してみた。 CSV ファイルから住所を読み込んで、結果も同じく CSV ファイルに書き込むだけ。 github.com ZIPCODA を使った理由 たぶんサービス等で定常的に利用するな…

「プロを目指す人のためのRuby入門」を読んだ #ruby #チェリー本

プロを目指す人のためのRuby入門[改訂2版] 言語仕様からテスト駆動開発・デバッグ技法まで Software Design plus作者:伊藤 淳一技術評論社Amazon 今の会社に出戻ってから Ruby On Rails をやることになり、まずは Ruby について学びたいなと思って手に取っ…

Ruby で nil の場合に別の値を入れる #ruby

まとめ ぼっち演算子と or 演算子を使うといい感じに書ける。 result = hoge&.value || "default" 愚直に書く if hoge== nil result = "default" else result = hoge.value end nil? を使う Object クラスにレシーバーが nil の場合に真偽値を返すメソッドが…

ridgepole で MySQL の TEXT 型を後から Not Null にするとエラーになる #Rails #MySQL #ridgepole

概要 Rails で DB の構成管理に ridgepole を使っているんだけれど、 MySQL の TEXT 型に後から Not Null 制約を付けるとエラーになってしまう。 github.com 原因 例えば下記の用に定義していたとする。 # 最初は null: true で作成 t.text "my_text", null:…

importmap で特定のページでだけ使う js を作る #rails

概要 importmap-rails を使っている場合に、特定のページだけで使う js ファイルを作る方法をまとめる。 github.com js ファイルを用意する 任意のファイル名と実装内容で良いが、ここでは下記のようにする。 app/javascript/foo/special.js import 可能にす…

factory_bot_rails 6.3.0 から PK に対する sequence はエラーになる #rails

概要 factory_bot_rails 6.3.0 から Active Record の PK カラムに対して sequence を指定するとエラーになるようになったようだ。 指定した場合、 FactoryBot::AttributeDefinitionError が発生する。 github.com FactoryBot.define do factory :hoge do # …

転職し(てい)ました

表題の通りなんですが、3月いっぱいでコネヒトを退職して、4月からエス・エム・エスという会社で働いています。 試用期間が終わったくらいにブログでも書こうかなと思ってたら、半年以上過ぎてるわ年末が目前だわで、時の早さを自分の怠惰の言い訳にしたくな…

Rails の collection_check_boxes をカスタマイズする #rails

概要 検索フォームのような、チェックボックスによる複数条件を指定する UI を作ろうとしたときに、 collection_check_boxes を使うとよさそう。 collection_check_boxes | Railsドキュメント しかし、collection_check_boxes のオプションだけだと input の…

Rails でトランザクション完了後に更新内容を取得する #rails

概要 トランザクションとは分離したいが、保存した内容によって事後処理を行いたい場合がある。 changed? や hoge_changed? あたりは save 後には false になってしまうため、更新内容を取得できない。 ApplicationRecord.transaction do if foo.name_change…

Rails + Puma は cluster mode だと RubyMine でデバッグできない #Rails #RubyMine

Rails + Docker な開発環境で RubyMine のリモートデバッグを行う場合、下記を参考にすればできるようになる。 www.jetbrains.com ところが、 Puma を利用していた際にデバッグモードでエラーが発生し起動できなくなってしまった。 Exception: Connection re…

「詳解Go言語Webアプリケーション開発」を読んだ #golang

Go

詳解Go言語Webアプリケーション開発作者:清水陽一郎シーアンドアール研究所Amazon 仕事では中々 Go を書く機会がないので、手を動かしながら学べる本がないかなと手に取った。 初心者向けの入門書かな、くらいの気持ちだったのだけれど、いい意味で期待を裏…

GitHub Actions で service のコンテナにリポジトリのファイルをマウントしようとするとエラーになる #GitHub #Actions

概要 GitHub Actions では、ジョブのサービスとして MySQL や Redis が使える。 volumes ( jobs.<job_id>.services.<service_id>.volumes ) を指定することで、サービス間やステップ間でデータを共有できる。 ただソースコードは通常 actions/checkout を利用すると思うが、リポ</service_id></job_id>…

GitHub Actions 上で MySQL のシステム変数をカスタマイズする #GitHub #Actions #MySQL

概要 GitHub Actions の Workflow では、 Services として MySQL が利用できる。 character_set_server などのシステム変数を変更する方法についてまとめる。 採用した方法: SQL ファイルでグローバル変数を書き換える Workflow で使う MySQL は基本使い捨て…

DataGrip で sql_mode に STRICT_TRANS_TABLES が適用される #mysql

概要 DataGrip で MySQL に接続すると、 sql_mode を別途設定しているにも関わらず、STRICT_TRANS_TABLES が勝手に適用されていた。 グローバルの設定を確認すると、意図したものが設定されているが、セッションの設定は STRICT_TRANS_TABLES になってしまう…

Goland で Docker を使った開発環境を作成する #golang #goland

概要 ネットに十分な情報はあるのだが、なんやかんや毎回詰まったりちょこちょこ調べたりしているので自分用にまとめておく。 Goland を使う Docker で動かす Web アプリケーション air でホットリロード delve でリモートデバッグ テストも Docker 経由でデ…

「プロフェッショナルWebプログラミング Laravel」を読んだ #Laravel

プロフェッショナルWebプログラミング Laravel作者:久保田賢二朗,荒井和平,大橋佑太エムディエヌコーポレーション(MdN)Amazon 現職だと Web アプリのフレームワークは CakePHP を利用してるんだけど、Laravel もう少し知っておきたいな〜、と思って読んで…

CakePHP の BelongsToMany でdependent は default が true になっている #CakePHP

アソシエーションの dependant CakePHP のモデルのアソシエーションには dependant というキーが用意されており、 true に設定することで削除のときに関連付けたモデルのレコードもまとめて削除することができる。 book.cakephp.org belongsToMany だけデフ…

FakerPHP/Faker で \Faker\Generator::image が使えない #php #laravel

概要 Laravel の Factory で画像のテストデータを作ろうとして $this->faker->image(storage_path('app/public/images')) とかやっても、画像ファイルがうまく生成されず、画像ファイル名も 0 とかで生成されてしまう。 v1.20.0 で非推奨になっており、 Fake…

人間をリソースと呼ばない方がいいと思う

社内に投下したポエムを一部修正してリポスト。 「リソース」っていう表現が嫌い 表題の通りなんですが、僕は人間をリソースと呼ばないほうがいいと思っていて、何ならとても嫌いな表現なんです。 文脈上使わざるを得ないときもありますが。 よく聞くような…

phpunit-snapshot-assertions にコントリビュートした #php

PHP

スナップショットテストをやりたいなと思って spatie/phpunit-snapshot-assertions を導入してみた。 github.com ところが PHPUnit でデータプロバイダをつかったパラメータライズドテストをやっていると、どうもうまくいかない。 原因は、データセット名に…

Laravel Sail 環境を PHPStorm でデバッグする #Laravel #PHPStorm

前提 Laravel v9.17.0 Sail v1.14.10 環境変数を定義 .env で xdebug を有効化し、設定を変更する SAIL_XDEBUG_MODE=develop,debug SAIL_XDEBUG_CONFIG="client_host=host.docker.internal idekey=PHPSTORM start_with_request=yes" ブラウザ拡張を使う方法…

Laravel の補完を PHPStorm で使いやすくする #Laravel #PHPStorm

概要 Laravel のモデルでクエリを組み立てようとすると、 Method 'where' not found と言われてしまう。 このせいで PHPStorm の補完が効かなかったり、警告が出てしまったりする。 first(); // query() をかませると平気なんだけれども、面倒 MyModel::quer…

Google Domains のドメインのサブドメインを Amazon Route53 で利用する #terraform

Route53 でパプリックホストゾーンを作成 terraform だとこんな感じ。 resource "aws_route53_zone" "sample" { name = "sample.mydomain.dev" } パブリックホストゾーンを作成すると、NS レコードと SOA レコードは自動作成される。 Google Domains で NS …

Fixture Factories で Faker が日本語にならなかった #CakePHP

問題 CakePHP に Fixture Factories を導入しようとしていた。 Faker が利用できるので、日本語化しようと思ったがどうもうまくいかない。 原因と解決 defaultLocale がハイフン区切りの ja-JP になっていた。 アンダースコア区切りの ja_JP を指定すること…

Android 開発に入門してみた #Android

なんかやったことないことやってみたいな〜、と思って Android 開発を少しだけやってみた。 特に Android 自体に強いこだわりがあったわけじゃないんだけれど、 Java や Kotlin を久しぶりに触りたいなって気持ちがあった。 どうやって入門したか 主に2冊の…

僕らはいつもスプリントレビューをしていた

久々の出社、とある機能の実装が一段落し、Dev環境にデプロイした。 隣の席のプロダクトマネージャーにふと「見ます〜?」と言ったら「見る見る!」となった。 そしたら隣の島にいた別の人が「私も見たい!」となって覗きに来る。 なので実機(スマホアプリ…

Android で「Requested internal only, but not enough space」というエラー #Android

Android Studio のエミュレータでアプリを起動しようとしたらエラーが発生してしまった。 java.io.IOException: Requested internal only, but not enough space 単純にエミューレータのデバイスで空きサイズが無いということらしい。 ストレージ容量を増や…

TravisCI で PHP7 のビルドがエラーになる #TravisCI #php

(2022/03/17 追記) フォーラムで話題になっており、サポートからも連携されたようなので、そのうち直りそう。 travis-ci.community 問題 php7.4 で TravisCI が突然コケるようになってしまった。 php: error while loading shared libraries: libargon2.so.1…

AWS SDK for PHP を Mock する #php

AWS SDK を使って Amazon SNS 使用箇所のテストを書こうとしていたところ、 PHPUnit の Mock を無邪気に使ったら怒られてしまった。 phpunit Trying to configure method "publish" which cannot be configured because it does not exist, has not been spe…

Goland でファイル名が main じゃないとブレークポイントが貼れない? #Goland #golang

Go

問題 docker-compose を使って Goland でリモートデバッグを試していた。 エントリポイント (main関数) のあるファイルだけブレークポイントを貼れない。 Cannot find debugger path for /path/to/server.go みたいなメッセージが出て、ブレークポイントが無…