brew install mysql
なんか mysql_install_db --tmpdir=/tmp
とかしないとうまく行かなかったメモ。
$ brew install mysql
$ mysql_install_db --tmpdir=/tmp
$ mysql.server start
TheSchwartzのテストが通らなくてあせった件
TheSchwartzをインストールしようとしたらテストが通らなかった。
テストが通らなくても、原因を見ると失敗していても影響ないような失敗をしていることが多いので気軽にソースをのぞいて見たところどうもそんな気楽な感じでもなくて普通にエラーっててどうしたもんかと思った。
具体的には
$ prove -bv t/unique.t
t/unique....
1..12
ok 1 - made first feed major job
ok 2 - The object isa TheSchwartz::JobHandle
ok 3 - made another feed major job
ok 4 - no handle
ok 5 - made scratch major job
not ok 6 - The object isa TheSchwartz::JobHandle
# Failed test 'The object isa TheSchwartz::JobHandle'
# at t/unique.t line 44.
# The object isn't defined
ok 7 - made first feed major job
ok 8 - The object isa TheSchwartz::JobHandle
ok 9 - made another feed major job
ok 10 - no handle
ok 11 - made scratch major job
ok 12 - The object isa TheSchwartz::JobHandle
# Looks like you failed 1 test of 12.
Dubious, test returned 1 (wstat 256, 0x100)
Failed 1/12 subtests
Test Summary Report
-------------------
t/unique (Wstat: 256 Tests: 12 Failed: 1)
Failed test: 6
Non-zero exit status: 1
Files=1, Tests=12, 0 wallclock secs ( 0.02 usr 0.01 sys + 0.14 cusr 0.03 csys = 0.20 CPU)
Result: FAIL
こんな感じ。
$client->insert
が正しく JobHandle オブジェクトを返していないということは job を insert できてないってことなのでこれは問題である。
しょうがないのでもう少し追うと、このテストは3回 insert をしていて2回目の insert はわざと失敗させている。TheSchwartz はこの失敗した場合にエラーコード 1062 だけを特別扱いし、それ以外の場合はそのDBが死んだと判断して mark_as_dead
する。
Data::ObjectDriver::Driver::DBI
の last_error
とか Data::ObjectDriver::Driver::DBD::mysql
の map_error_code
あたりを参照のこと。
1062 というのはこの DOD::DBD::mysql
にハードコードされていて、MySQL の Duplicate entry '%s' for key %d
とかいうエラー。
この辺の実装もどうかと思うが、ここで僕の環境では 1582 というエラーコードが帰ってきていたため、DBが mark_as_dead
されてしまい、次のinsertも失敗するということになっていたようだ。
ちなみにエラーコードは違ったけれども Duplicate entry '1-major' for key 'funcid_2'
という期待するエラーが返ってきていた。
この環境の MySQL はずいぶん前に入れた 5.1beta (5.1.18-beta) で、ほかの5.0なマシンではテストとおるので、5.1 になってエラーコード変わったのかなぁと思ってマニュアル見てみたけど変わってないので、よくわからないけどとりあえずMySQLを最新(5.1rc)にしてみたらテストとおるようになってしまった。
古い5.1は罠だということかなー。
MySQLのダブルクオートとsqlt
MySQLのsqlにダブルクオートが含まれてるとsqltがこける。
なんだろう。シングルクオートに置換すると通る。
とはいえ、便利すなぁ。sqlt。
VARCHAR
charset=utf8 だと短く感じるなぁ。
感覚的に日本語は2バイト換算で考えてしまうので、村瀬 大輔
は楽勝ではいるのに Daisuke Murase
は Mu までしかはいらないとか、エェってなる。