JavaScriptを使った開発で必要となるconcat, minify, lint, test といったタスクを動かすのに使うツール、最近はgruntをよく見かけるのでオレオレmakefileから移行してみた。
既存のmakefileは以下の通り。makefile + makeターゲットから呼び出される各種タスクに対応した処理を行なうプログラムという構成。make minifyと打てば圧縮版のファイルを生成、make testと打てばテストが実行される寸法だ、圧縮にはuglify.js, lintにはjshint、全てnodeモジュールを使っているのでそのまま移行できるはず。concatにはmuというテンプレートエンジンを使っていた。
grunt testでテストが実行されるし、grunt watchしてコードを編集すれば勝手にlint, concat, testしてくれるので移行はOK。 古参JSerであればRailsにアセットパイプラインが導入される前から、それ相当の機能を持つ秘伝のタレ的なMakefileやRakefileを使ってきたとは思うが、gruntはプラグインという形でタスクを共有できるので新規プロジェクトで使ってみるメリットは十分ある。少なくともCakefileよりはイケている。ライブラリでは無くWebアプリケーションの開発であればgruntを利用したyeomanの方が良さげ。
既存のmakefileは以下の通り。makefile + makeターゲットから呼び出される各種タスクに対応した処理を行なうプログラムという構成。make minifyと打てば圧縮版のファイルを生成、make testと打てばテストが実行される寸法だ、圧縮にはuglify.js, lintにはjshint、全てnodeモジュールを使っているのでそのまま移行できるはず。concatにはmuというテンプレートエンジンを使っていた。
makefileからの移行
まず、gruntの制御に必要なgrunt.jsファイルは grunt init:gruntfile して生成する。concat, lint, minify がビルトインタスクとして既に存在しているのがわかる。それらの箇所を修正して対象ファイルを指定する。gruntからシェルコマンドの実行
最初に困ったのが、gruntから npm test を実行したいが、シェルのコマンドを実行する方法がデフォルトでは存在しない事。そこで grunt-exec というgruntプラグインを発見したので利用した。最終的に次のgrunt.jsになった。grunt testでテストが実行されるし、grunt watchしてコードを編集すれば勝手にlint, concat, testしてくれるので移行はOK。 古参JSerであればRailsにアセットパイプラインが導入される前から、それ相当の機能を持つ秘伝のタレ的なMakefileやRakefileを使ってきたとは思うが、gruntはプラグインという形でタスクを共有できるので新規プロジェクトで使ってみるメリットは十分ある。少なくともCakefileよりはイケている。ライブラリでは無くWebアプリケーションの開発であればgruntを利用したyeomanの方が良さげ。