yhara.jp

Recent Posts

Gitのpost-checkoutフックを使ってみた

2018-10-18
Tech

Gitのpost-checkoutフックを使って、ブランチを切り替えたときにWIPコミットがあればメッセージを出すようにしてみたという話。

WIPコミットとは

WIPコミットというのは個人的な名称だが、全ての変更を仮コミットにまとめたものをそう呼んでいる。例えばブランチで新機能を開発している最中にバグを見つけてmasterを触らないといけなくなった時は、git commit -am 'WIP'でWIPコミットを作ったあとmasterに移動する。

バグ修正を終えてmasterから戻ってきたあとは、git reset HEAD^ とするとWIPコミットが削除され、作業中の状態に戻すことができる。

作業状態の保存はgit stashでもできるが、stashの場合は「このブランチにはWIPがある」ということは自分で覚えておかないといけない。一方WIPコミットはブランチに紐づくので、ブランチをcheckoutしたあとgit logすればWIPがあったことを思い出せる。

(more...)

APIのエラー出力をw3mで見る

2018-10-09
Tech

RubyでAPIサーバを作っていると、Rack::ShowExceptionsとかでエラーレスポンスがHTMLになることがある。通常はこれはデバッグに役立つけれど、APIサーバの場合はcurlで動作確認してたりするので、ターミナルにHTMLがだーっと出力されるとあんまり嬉しくない。

対処法としてはいったん.htmlに保存してブラウザで開くという手があるけど何回もやるのはちょっと面倒。こんなときはw3mを使うと直接見ることができて楽。-Tを付けると標準入力をHTMLとして表示することができる。

curl http://localhost:9292/some_api | w3m -T text/html

Rack::ShowExceptionsの場合は冒頭だけ見ればエラーの主な情報(例外クラス名、メッセージ、発生箇所)が分かるので、以下でもいいかも。

curl http://localhost:9292/some_api | w3m -T text/html | head

DXOpal 1.3.0をリリースしました

2018-09-29
Tech

Rubyでブラウザゲームが作れるライブラリ、DXOpalの1.3.0をリリースしました。

1.3.0ではパッチをいただいて加算合成ができるようになりました。例えば炎のエフェクトを背景の上にいい感じに合成できるみたいです。かっこいいですね。

使い方

1.2.0から変わっていません。チュートリアルは以下のとおりです。

(more...)

2018年8月

2018-09-04
Tech

近況です。

Ovto, Vision

8月は自分用のTODOアプリを作っていた。繰り返しTODOまで実装できたので、そろそろ実用できそう。

これのためにフレームワークの方にも手を入れて、例えばOvto.fetchというfetch APIを叩くメソッドを追加したりした。そろそろv0.2.0としてリリースしないとなぁ(どうもその手の作業は後回しになりがち)。

(more...)


Using login_user with Sorcery gem on Rails 5.2

2018-08-29
Tech

Problem

Sorcery's Testing-Rails guide is based on Rails4 and does not work with Rails5.2.

With include Sorcery::TestHelpers::Rails::Integration, I got:

TasksControllerTest#test_should_get_index:
NameError: undefined local variable or method `page' for #<TasksControllerTest:0x00007fff19df4a10>
    test/controllers/tasks_controller_test.rb:7:in `block in <class:TasksControllerTest>'
(more...)


「fetch APIでRailsのcreateアクションを叩くとInvalidAuthenticityTokenになる」

2018-08-04
Tech

fetch APIを使ってRailsのAPIを叩くものを作っていて、GETはうまく行ったのだけど、POSTしようとしたらCSRF関連のエラー(ActionController::InvalidAuthenticityToken)になってちょっとはまった。

原因

fetch APIはGETもPOSTもできるのだけど、デフォルトではCookieをサーバに送らないという仕様になっている。

RailsのCSRF対策は「送られてきたトークンをセッションに保存されたものと比較する」というものだが、セッション情報はデフォルトではCookieに保存される(CookieStore)ので、Cookieをサーバに送らないとセッションにトークン情報がないぞということになり、InvalidAuthenticityTokenになる。

修正方法

fetch APIの第二引数に{credentials: "same-origin"}を入れてCookieをサーバに送らせることでうまく行った。


TRICK2018応募作

2018-07-05
Tech

TRICK 2018に応募した作品です。

解説はまた後ほど…

SVG Graph Generator

グラフ構造をDSLで記述すると、そのようなSVG画像を生成するプログラムです。

$n={};$e=[];class Array;def -@;self;end;def -(o);$n[self]=1
(more...)

RubyKaigi 2018 仙台に参加しました

2018-07-01
Tech

もう一月経ちますが、仙台で行われたRubyKaigi 2018に参加していました。

TRICK2018

今回はTRICKの審査員として登壇しました。登壇といっても僕がしたのは審査作業くらいです。主催のmameさんお疲れ様でした&ありがとうございました。

togetterで皆さんの悲鳴をまとめていますが、楽しんでいただけたようで良かったです。

(more...)

Posts

(more...)

Articles

(more...)

Category

Ads

About

About the author