Rails のコマンドラインツール

このガイドの内容:

このチュートリアルは、Railsをはじめようで基本的なRailsの知識を身につけていることを前提としています。

1 コマンドラインの基礎

Railsを利用するうえで、きわめて重要なコマンドがいくつかあります。それらを利用頻度順に並べると以下のとおりです。

  • rails console
  • rails server
  • bin/rails
  • rails generate
  • rails dbconsole
  • rails new app_name

どのコマンドも-h もしくは --helpオプションを使うことで、詳細な情報をみることができます。

簡単なRailsアプリケーションをつくりながら、一つずつコマンドを実行していきましょう。

1.1 rails new

Railsをインストールしたあと、最初にやりたいことはrails newコマンドを実行して、新しいRailsアプリケーションを作成することです。

まだRailsをインストールしていない場合、gem install railsを実行してRailsをインストールできます。

$ rails new commandsapp
    create
    create README.md
    create Rakefile
    create config.ru
    create .gitignore
    create Gemfile
    create app
    ...
    create  tmp/cache
    ...
        run bundle install

このような短いコマンドをうつだけで、Railsは非常に多くのものを用意してくれます。たったこれだけで、完璧なRailsのディレクトリ構成と、アプリケーションに必要なコードがすべて手に入りました。

1.2 rails server

rails serverコマンドを実行すると、Pumaというwebサーバーが起動します(PumaはRailsに標準添付されています)。Webブラウザからアプリケーションにアクセスしたいときは、このコマンドを使います。

rails serverを実行することで、新しいRailsアプリケーションを作成後すぐにRailsアプリケーションを起動することができます。

$ cd commandsapp
$ bin/rails server
=> Booting Puma
=> Rails 5.1.0 application starting in development on http://0.0.0.0:3000
=> Run `rails server -h` for more startup options
Puma starting in single mode...
* Version 3.0.2 (ruby 2.3.0-p0), codename: Plethora of Penguin Pinatas
* Min threads: 5, max threads: 5
* Environment: development
* Listening on tcp://localhost:3000
Use Ctrl-C to stop

わずか3つのコマンドで、Railsサーバーを3000番ポートで起動しました。ブラウザを立ち上げて、http://localhost:3000を開いてみてください。Railsアプリケーションが動作していることが分かります。

サーバーを起動する際にはrails sのように"s"というエイリアスが使えます。

-p オプションを使うことで、待ち受けるポートを指定できます。サーバーの環境は -e オプションで変更することができ、デフォルトではdevelopment (開発) 環境で実行されます。

$ bin/rails server -e production -p 4000

-bオプションを使うと、Railsを特定のIPにバインドできます。デフォルトはlocalhostです。-dオプションを使うと、デーモンとしてサーバーを起動することができます。

1.3 rails generate

rails generateコマンドでは、テンプレートを用いてさまざまなものを作成します。rails generateを実行すると、利用可能なジェネレータの一覧が表示されます。

ジェネレータコマンドを実行する際にはrails gのように「g」というエイリアスが使えます。

$ bin/rails generate
Usage: rails generate GENERATOR [args] [options]

...
...

Please choose a generator below.

Rails:
  assets
  channel
  controller
  generator
  ...
  ...

ジェネレータgemをインストールしたり、プラグインに付属しているジェネレータをインストールすることで、ジェネレータを追加できます。自分でジェネレータを開発することもできます。

ジェネレータを使うと、アプリケーションを動かすのに必要な Boilerplate Code (訳注: 多くの箇所で繰り返し使われる定形コード: 俗に「テンプレ」とも呼ばれます) を書かなくて済むため、時間を節約できます。

それではコントローラジェネレータを使って、コントローラを作ってみましょう。どのようなコマンドを使えばよいのでしょうか?ジェネレータに聞いてみましょう。

Railsのすべてのコマンドにはヘルプがついています。多くの *nix (訳注: LinuxやUnix、UnixライクなOSなど) のユーティリティと同じようにコマンドの最後に--helpもしくは-hオプションを与えてください (例: rails server --help)。

$ bin/rails generate controller
Usage: rails generate controller NAME [action action] [options]

    ...
    ...

    Description:
    ...

    To create a controller within a module, specify the controller name as a path like 'parent_module/controller_name'.

    ...

Example:
    `rails generate controller CreditCards open debit credit close`

    Credit card controller with URLs like /credit_cards/debit.
        Controller: app/controllers/credit_cards_controller.rb
        Test:       test/controllers/credit_cards_controller_test.rb
        Views:      app/views/credit_cards/debit.html.erb [...]
        Helper:     app/helpers/credit_cards_helper.rb

コントローラジェネレータにはgenerate controller ControllerName action1 action2という形式でパラメータを渡します。helloアクションを実行すると、ちょっとしたメッセージを表示するGreetingsコントローラを作ってみましょう。

$ bin/rails generate controller Greetings hello
     create  app/controllers/greetings_controller.rb
      route  get "greetings/hello"
     invoke    erb 
     create    app/views/greetings
     create    app/views/greetings/hello.html.erb
     invoke  test_unit
     create    test/controllers/greetings_controller_test.rb
     invoke  helper
     create    app/helpers/greetings_helper.rb
     invoke  assets
     invoke    coffee
     create      app/assets/javascripts/greetings.coffee
     invoke    scss
     create      app/assets/stylesheets/greetings.scss

どんなファイルが生成されたのでしょうか?いくつかのディレクトリがアプリケーションに存在することを確認し、コントローラファイル、ビューファイル、機能テストのファイル、ビューのヘルパー、JavaScriptファイルそしてスタイルシートファイルを作成しました。

コントローラ(app/controllers/greetings_controller.rb)を確認し、少し編集してみましょう。

class GreetingsController < ApplicationController
  def hello
    @message = "Hello, how are you today?"
  end 
end 

メッセージを表示するためにビュー(app/views/greetings/hello.html.erb)を編集します。

<h1>A Greeting for You!</h1>
<p><%= @message %></p>

rails serverでサーバーを起動します。

$ bin/rails server
=> Booting Puma...

URLはhttp://localhost:3000/greetings/helloです。

通常のRailsアプリケーションでは、URLはhttp://ホスト名/コントローラ名/アクション名というパターンになります。アクション名を指定しないhttp://ホスト名/コントローラ名というパターンのURLは、コントローラのindexアクションへのURLとなります。

Railsにはデータモデルのためのジェネレータもついています。

$ bin/rails generate model
Usage:
  rails generate model NAME [field[:type][:index] field[:type][:index]] [options]

...

Active Record options:
      [--migration]            # Indicates when to generate migration
                               # Default: true

...

Description:
    Create rails files for model generator.

typeパラメータで利用可能なフィールドの種類についてはAPI documentationに記載されている、SchemaStatementsモジュールのadd_columnメソッドの説明を参照してください。indexパラメータを指定すると、カラムに対応するインデックスが生成されます。

ここでは直接モデルを作成する代わりに(モデルの作成は後ほど行います)、scaffoldをセットアップしましょう。Railsにおけるscaffoldとは、モデル、モデルのためのマイグレーション、モデルを操作するためのコントローラ、モデルを操作・表示するためのビュー、それらのためのテスト一式をさします。

"HighScore"という名のリソースを準備してみましょう。このリソースの役割はビデオゲームでの最高得点を記録することです。

$ bin/rails generate scaffold HighScore game:string score:integer
    invoke  active_record
    create    db/migrate/20130717151933_create_high_scores.rb
    create    app/models/high_score.rb
    invoke  test_unit
    create      test/models/high_score_test.rb
    create      test/fixtures/high_scores.yml
    invoke  resource_route
     route    resources :high_scores
    invoke  scaffold_controller
    create    app/controllers/high_scores_controller.rb
    invoke    erb 
    create      app/views/high_scores
    create      app/views/high_scores/index.html.erb
    create      app/views/high_scores/edit.html.erb
    create      app/views/high_scores/show.html.erb
    create      app/views/high_scores/new.html.erb
    create      app/views/high_scores/_form.html.erb
    invoke  test_unit
    create      test/controllers/high_scores_controller_test.rb
    invoke  helper
    create      app/helpers/high_scores_helper.rb
    invoke    jbuilder
    create      app/views/high_scores/index.json.jbuilder
    create      app/views/high_scores/show.json.jbuilder
    invoke    test_unit
    create      test/system/high_scores_test.rb
    invoke  assets
    invoke    coffee
    create      app/assets/javascripts/high_scores.coffee
    invoke    scss
    create      app/assets/stylesheets/high_scores.scss
    invoke    scss
   identical    app/assets/stylesheets/scaffolds.scss

ジェネレータはモデル、コントローラ、ヘルパー、レイアウト、機能テスト、ユニットテスト、スタイルシート用のディレクトリが存在することをチェックし、ビュー、コントローラ、モデル、マイグレーション(high_scoresテーブルとフィールドを作成する)を生成し、このresource用のルーティングを用意します。またこれらのためのテストも作成します。

migrateを実行してマイグレーションを走らせる必要があります。つまりデータベースのスキーマを変更するためにRubyのコード(コードとは20130717151933_create_high_scores.rbに書かれたコードのことです)を実行する必要があります。データベースとはどのデータベースでしょうか?bin/rails db:migrateコマンドを実行すると、RailsはSQLite3に新しいデータベースを作ります。bin/railsについては後ほど詳しく説明します。

$ bin/rails db:migrate
==  CreateHighScores: migrating ===============================================
-- create_table(:high_scores)
   -> 0.0017s
==  CreateHighScores: migrated (0.0019s) ======================================

単体テスト(unit test)について説明します。単体テストとは、コードをテストしてアサーション(コードが期待どおりに動作するかどうかを確認すること)を行うコードです。単体テストでは、モデルのメソッドといったコードの一部分を取り出して、入力と出力をテストします。単体テストはあなたにとって友人と同じぐらい大事なものです。単体テストを書けば人生が幸福で満たされるという事実に早いうちから気づいた人は、間違いなく他人より先に幸せになれるでしょう。単体テストについて詳しくは、the testing guideを参照してください。

Railsが作ったインターフェースをみてみましょう。

$ bin/rails server

ブラウザでhttp://localhost:3000/high_scoresを開いてみましょう。それではハイスコアを更新するとしましょう(スペースインベーダーで55,160点とかね!) (訳注: 2003年にDonald Hayesがたたき出したスコアです)。

1.4 rails console

consoleコマンドを使うと、コマンドラインでRailsアプリケーションとやり取りすることができます。rails consoleは内部的にIRBを使っているので、IRBを使ったことがあれば簡単に扱えます。IRBは、思いついたアイデアを試してみたり、ウェブサイトにアクセスすることなくサーバのデータを変更したりするのに役立ちます。

コンソールコマンドを実行する際にはrails cのように"c"というエイリアスが使えます。

consoleコマンドを実行する環境を指定することができます。

$ bin/rails console -e staging

データを変更することなくコードをテストしたいときは、rails console --sandboxを実行します。

$ bin/rails console --sandbox
Loading development environment in sandbox (Rails 5.1.0)
Any modifications you make will be rolled back on exit
irb(main):001:0>
1.4.1 appオブジェクトとhelperオブジェクト

rails consoleの実行中、appオブジェクトとhelperオブジェクトにアクセスできます。

appメソッドを使うと、URLヘルパーとpathヘルパーにアクセスできます。またリクエストを投げることもできます。

>> app.root_path
=> "/"

>> app.get _
Started GET "/" for 127.0.0.1 at 2014-06-19 10:41:57 -0300
...

helperメソッドを使うと、Railsのアプリケーションヘルパーと自分が実装したヘルパーにアクセスすることができます。

>> helper.time_ago_in_words 30.days.ago
=> "about 1 month"

>> helper.my_custom_helper
=> "my custom helper"

1.5 rails dbconsole

rails dbconsoleコマンドは使っているデータベースを探し出し、適切なデータベースコマンドラインツールを起動します(また、コマンドラインツールに必要な引数を探し出します)。MySQL (MariaDB含む)、PostgreSQL、SQLite、そしてSQLite3をサポートしています。

DBコンソールコマンドを実行する際にはrails dbのように「db」というエイリアスが使えます。

1.6 rails runner

runnerコマンドを使うと、非対話的にRailsの文脈でRubyのコードを実行することができます。たとえば次のようになります。

$ bin/rails runner "Model.long_running_method"

ランナーコマンドを実行する際にはrails rのように"r"というエイリアスが使えます。

-eを使うことでrunnerコマンドを実行する環境を指定することができます。

$ bin/rails runner -e staging "Model.long_running_method"

ファイル内のRubyコードをrunnerで実行することもできます。

$ bin/rails runner lib/code_to_be_run.rb

1.7 rails destroy

destroygenerateのちょうど反対と言えます。ジェネレータコマンドで生成された内容を調べて、それを取り消します。

rails dのように、「d」というエイリアスを使ってdestroyコマンドを実行することもできます。

$ bin/rails generate model Oops
      invoke  active_record
      create    db/migrate/20120528062523_create_oops.rb
      create    app/models/oops.rb
      invoke  test_unit
      create      test/models/oops_test.rb
      create      test/fixtures/oops.yml

$ bin/rails destroy model Oops
      invoke  active_record
      remove    db/migrate/20120528062523_create_oops.rb
      remove    app/models/oops.rb
      invoke  test_unit
      remove      test/models/oops_test.rb
      remove      test/fixtures/oops.yml

2 bin/rails

従来のrakeコマンドは、Rails 5.0以降Railsの実行ファイルに組み込まれました。コマンドを実行する新しいデフォルトはrakeではなく、bin/railsです。

bin/rails --tasksとタイプすると、実行可能なrailsコマンドの一覧が表示されます。各タスクには説明がついているので、必要なタスクを見つけるのに役立つはずです。

$ bin/rails --help
Usage: rails COMMAND [ARGS]

The most common rails commands are:
generate    Generate new code (short-cut alias: "g")
console     Start the Rails console (short-cut alias: "c")
server      Start the Rails server (short-cut alias: "s")
...

All commands can be run with -h (or --help) for more information.

In addition to those commands, there are:
about                               List versions of all Rails ...
assets:clean[keep]                  Remove old compiled assets
assets:clobber                      Remove compiled assets
assets:environment                  Load asset compile environment
assets:precompile                   Compile all the assets ...
...
db:fixtures:load                    Loads fixtures into the ...
db:migrate                          Migrate the database ...
db:migrate:status                   Display status of migrations
db:rollback                         Rolls the schema back to ...
db:schema:cache:clear               Clears a db/schema_cache.yml file
db:schema:cache:dump                Creates a db/schema_cache.yml file
db:schema:dump                      Creates a db/schema.rb file ...
db:schema:load                      Loads a schema.rb file ...
db:seed                             Loads the seed data ...
db:structure:dump                   Dumps the database structure ...
db:structure:load                   Recreates the databases ...
db:version                          Retrieves the current schema ...
...
restart                             Restart app by touching ...
tmp:create                          Creates tmp directories ...

bin/rails -Tでもタスクの一覧を表示できます。

2.1 about

bin/rails aboutを実行すると、Ruby、RubyGems、Rails、Railsのサブコンポーネント (訳注: Active RecordやAction Packなど) のバージョン、Railsアプリケーションのフォルダー名、現在のRailsの環境名とデータベースアダプター、そして、スキーマのバージョンが表示されます。誰かに質問したいときや、セキュリティパッチが自分のアプリケーションに影響するか確認したいときなど、現在使っているRailsに関する情報が必要なときに便利です。

$ bin/rails about
About your application's environment
Rails version             5.1.0
Ruby version              2.2.2 (x86_64-linux)
RubyGems version          2.4.6
Rack version              2.0.1
JavaScript Runtime        Node.js (V8)
Middleware:               Rack::Sendfile, ActionDispatch::Static, ActionDispatch::Executor, ActiveSupport::Cache::Strategy::LocalCache::Middleware, Rack::Runtime, Rack::MethodOverride, ActionDispatch::RequestId, ActionDispatch::RemoteIp, Sprockets::Rails::QuietAssets, Rails::Rack::Logger, ActionDispatch::ShowExceptions, WebConsole::Middleware, ActionDispatch::DebugExceptions, ActionDispatch::Reloader, ActionDispatch::Callbacks, ActiveRecord::Migration::CheckPending, ActionDispatch::Cookies, ActionDispatch::Session::CookieStore, ActionDispatch::Flash, Rack::Head, Rack::ConditionalGet, Rack::ETag
Application root          /home/foobar/commandsapp
Environment               development
Database adapter          sqlite3
Database schema version   20110805173523

2.2 assets

bin/rails assets:precompileを実行すると、app/assets配下のファイルをプリコンパイルできます。またbin/rails assets:cleanを実行すると、古くなったコンパイル済みのファイルを削除できます。assets:cleanは、新しいassetsがビルドされるときにも古いassetsにリンクする「ローリングデプロイ (rolling deploy)」を実現しています。

public/assets配下を完全に消去するにはbin/rails assets:clobberを実行します。

2.3 db

bin/railsのdb:という名前空間に属するタスクのうち、最もよく使われるのはmigratecreateです。マイグレーションに関するタスク(up, down, redo, reset)はいずれも一度試してみることをおすすめします。bin/rails db:versionを使えばデータベースの状況が分かるので、トラブルシューティングの際に役立ちます。

マイグレーションについては、Active Recordマイグレーションでより詳しく扱っています。

2.4 notes

bin/rails notesは、コードのコメントからFIXME、OPTIMIZE、TODOで始まる行を探し出して表示します (訳注: [FIXME]のように[から始まるものはヒットしません)。検索対象となるファイルの拡張子は.builder.rb.rake.yml.yaml.ruby.css.js.erbで、デフォルトのアノテーション以外に独自のアノテーションも利用できます。

$ bin/rails notes
(in /home/foobar/commandsapp)
app/controllers/admin/users_controller.rb:
  * [ 20] [TODO] any other way to do this?
  * [132] [FIXME] high priority for next deploy

app/models/school.rb:
  * [ 13] [OPTIMIZE] refactor this code to make it faster
  * [ 17] [FIXME]

検索するファイルの拡張子を追加するには、config.annotations.register_extensionsオプションを使います。このオプションは拡張子の一覧と、マッチするべき行を表す正規表現を引数にとります。

config.annotations.register_extensions("scss", "sass", "less") { |annotation| /\/\/\s*(#{annotation}):?\s*(.*)$/ }

特定のアノテーションのみを表示したいとき(例えばFIXMEのみを表示したいとき)はbin/rails notes:fixmeのように実行します。このとき、アノテーションは小文字で書くことに注意してください。

$ bin/rails notes:fixme
(in /home/foobar/commandsapp)
app/controllers/admin/users_controller.rb:
  * [132] high priority for next deploy

app/models/school.rb:
  * [ 17]

独自のアノテーションを使う際には、bin/rails notes:customと書いて、ANNOTATION環境変数を使ってアノテーション名を指定します。

$ bin/rails notes:custom ANNOTATION=BUG
(in /home/foobar/commandsapp)
app/models/article.rb:
  * [ 23] Have to fix this one before pushing!

特定のアノテーションのみを表示するときや、独自のアノテーションを表示する際には、FIXMEやBUGといったアノテーション名は表示されません。

rails notesタスクはデフォルトではappconfiglibbintestディレクトリを対象とします。他のディレクトリも対象にしたい場合は、SOURCE_ANNOTATION_DIRECTORIES環境変数にディレクトリ名をカンマ区切りで指定します。

config.annotations.register_directories("spec", "vendor")

SOURCE_ANNOTATION_DIRECTORIES環境変数でカンマ区切りのディレクトリ名を指定することもできます。

$ export SOURCE_ANNOTATION_DIRECTORIES='spec,vendor'
$ bin/rails notes
(in /home/foobar/commandsapp)
app/models/user.rb:
  * [ 35] [FIXME] User should have a subscription at this point
spec/models/user_spec.rb:
  * [122] [TODO] Verify the user that has a subscription works

2.5 routes

rails routesを使うと、定義されている全ルーティングをみることができます。これはルーティングの問題を解くときや、アプリケーションのルーティング全体を理解するのに役立ちます。

2.6 test

Railsでの単体テストについてはRailsアプリケーションをテストするを参照してください。

RailsにはMinitestと呼ばれるテストスイートが付属しています。Railsではテストを書くことで、安定したアプリケーションを開発します。test:という名前空間の中で定義されたタスクは、あなたがこれから(期待を持って)書くさまざまなテストを実行するときに役立ちます。

2.7 tmp

Rails.root/tmpディレクトリは、(*nix系でいう/tmpディレクトリのような) 一時ファイルを保存するためのディレクトリです。一時ファイルには、プロセスIDのファイル、アクションキャッシュのためのファイルなどがあります。

tmp:という名前空間には、Rails.root/tmpディレクトリを作成、削除するためのタスクが入っています。

  • rails tmp:cache:clearで、tmp/cacheを空にします。
  • rails tmp:sockets:clearで、tmp/socketsを空にします。
  • rails tmp:screenshots:clearで、tmp/screenshotsを空にします。
  • rails tmp:clearで、cache、sockets、screenshotディレクトリを空にします。
  • rails tmp:createで、cache、sockets、pidsのtmpディレクトリを作成します。

2.8 その他のタスク

  • rails stats: コードに対するテストの比率やKLOCs(コードの行数)といった、コードに関する統計値を表示します。
  • rails secret: セッションシークレット用に擬似乱数を生成します。
  • rails time:zones:all: Railsが扱える全タイムゾーンを表示します。

2.9 カスタムRakeタスク

独自のRakeタスクの拡張子は.rakeRails.root/lib/tasks配下に保存します。また、独自のタスクを作成することができる bin/rails generate taskというコマンドもあります。

desc "I am short, but comprehensive description for my cool task"
task task_name: [:prerequisite_task, :another_task_we_depend_on] do
  # All your magic here
  # Any valid Ruby code is allowed
end 

タスクには以下のように引数を渡します。

task :task_name, [:arg_1] => [:prerequisite_1, :prerequisite_2] do |task, args|
  argument_1 = args.arg_1
end

タスクを名前空間内で定義することで、タスクをグルーピングできます。

namespace :db do 
  desc "何もしないたすく"
  task :nothing do
    # マジ何もしない
  end 
end 

タスクの呼び出しは以下のように行います。

$ bin/rails task_name
$ bin/rails "task_name[value 1]" # entire argument string should be quoted
$ bin/rails db:nothing

アプリケーション内のモデルを使ったり、データベースに対してクエリを投げたりしたいときは、タスクからenvironmentタスクへの依存関係を定義する必要があります。environmentタスクはアプリケーションのコードを読み込むタスクです。

3 Railsの高度なコマンドライン

コマンドラインのより高度な使い方として、便利な(時に驚くような)オプションを見つけて、オプションを使いこなすことがあります。ここでは、Railsのもつ妙技を少しだけ紹介します。

3.1 データベースとソースコード管理システムとRails

新しいRailsアプリケーションを作成するときに、データベースの種類とソースコード管理システムの種類を指定することができます。このオプションを使うことで、ちょっとした時間と多くのタイピングを節約できます。

それでは--database=postgresqlオプションと--gitオプションの動きを見てみましょう。

$ mkdir gitapp
$ cd gitapp
$ git init 
Initialized empty Git repository in .git/
$ rails new . --git --database=postgresql
      exists
      create  app/controllers
      create  app/helpers
      ...
      ...
      create  tmp/cache
      create  tmp/pids
      create Rakefile
      add 'Rakefile'
      create README.md
      add 'README.md'
      create app/controllers/application_controller.rb
      add 'app/controllers/application_controller.rb'
      create app/helpers/application_helper.rb
      ...
      create  log/test.log
      add 'log/test.log'

Railsがgitのリポジトリ内にファイルを作成する前に、gitappディレクトリを作成し、空のgitリポジトリを初期化する必要があります。Railsがどのようなデータベースの設定ファイルを作ったか見てみましょう。

$ cat config/database.yml
# PostgreSQL. Versions 9.1 and up are supported.
#
# Install the pg driver:
#   gem install pg
# On OS X with Homebrew:
#   gem install pg -- --with-pg-config=/usr/local/bin/pg_config
# On OS X with MacPorts:
#   gem install pg -- --with-pg-config=/opt/local/lib/postgresql84/bin/pg_config
# On Windows:
#   gem install pg
#       Choose the win32 build.
#       Install PostgreSQL and put its /bin directory on your path.
#
# Configure Using Gemfile
# gem 'pg'
#
default: &default
  adapter: postgresql
  encoding: unicode
  # For details on connection pooling, see Rails configuration guide
  # http://guides.rubyonrails.org/configuring.html#database-pooling
  pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>

development:
  <<: *default
  database: gitapp_development
...
...

選択したデータベース(PostgreSQL)に対応するように、Railsはdatabase.ymlを作成します。

ソースコード管理システムに関するオプションを使う際には、まずアプリケーション用のディレクトリを作り、ソースコード管理システムの初期化を行ってから、rails newコマンドを実行するようご注意ください。