2

(Rails 4、Ruby 2.0.0 を使用して) レコードを保存しようとすると、詳細ではないエラーが発生します。

これが起こることです。

2.0.0p0 :001 > Startup
 => Startup(id: integer, name: string, url: string, founded: date, mal: boolean,
            created_at: datetime, updated_at: datetime, creator: string, 
            description: text, category: text) 

2.0.0p0 :002 > @s = Startup.new(:name => "New Startup", 
                                :url =>  "http://newstartup.com", 
                                :founded => Date.today,
                                :mal => false, 
                                :creator => "127.0.0.1", 
                                :description => "This is a description", 
                                :category => ["","Sports"])
 => #<Startup id: nil, name: "New Startup", url: "http://newstartup.com", founded: "2013-04-25", mal: false, created_at: nil, updated_at: nil, creator: "127.0.0.1", description: "This is a description", category: ["", "Sports"]> 

2.0.0p0 :003 > @s.save
   (0.2ms)  BEGIN
   (0.3ms)  ROLLBACK
 => false 

これは私のモデルです:

class Startup < ActiveRecord::Base
  before_validation(:on => :create) do
    self.mal = false
  end

  attr_accessible :name, :url, :description, :category, :creator, :mal, :founded
end

スキーマ:

create_table "startups", force: true do |t|
  t.string   "name"
  t.string   "url"
  t.date     "founded"
  t.boolean  "mal"
  t.datetime "created_at"
  t.datetime "updated_at"
  t.string   "creator"
  t.text     "description"
  t.text     "category"
end

およびコントローラー:

class StartupsController < ApplicationController
  before_action :set_startup, only: [:show, :edit, :update, :destroy]
  before_create :set_creator

  # GET /startups
  # GET /startups.json
  def index
    @startups = Startup.all
  end

  def land
    @startup = Startup.new
    @resource = User.new
    @devise_mapping = Devise.mappings[:user]
  end

  # GET /startups/1
  # GET /startups/1.json
  def show
  end

  # GET /startups/new
  def new
    @startup = Startup.new
  end

  # GET /startups/1/edit
  def edit
  end

  # POST /startups
  # POST /startups.json
  def create
    @startup = Startup.new(startup_params)

    respond_to do |format|
      if @startup.save
        format.html { redirect_to @startup, notice: 'Startup was successfully created.' }
        format.json { render action: 'show', status: :created, location: @startup }
      else
        format.html { render action: 'new' }
        format.json { render json: @startup.errors, status: :unprocessable_entity }
      end
    end
  end

  # PATCH/PUT /startups/1
  # PATCH/PUT /startups/1.json
  def update
    respond_to do |format|
      if @startup.update(startup_params)
        format.html { redirect_to @startup, notice: 'Startup was successfully updated.' }
        format.json { head :no_content }
      else
        format.html { render action: 'edit' }
        format.json { render json: @startup.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /startups/1
  # DELETE /startups/1.json
  def destroy
    @startup.destroy
    respond_to do |format|
      format.html { redirect_to startups_url }
      format.json { head :no_content }
    end
  end

  private
    # Use callbacks to share common setup or constraints between actions.
    def set_startup
      @startup = Startup.find(params[:id])
    end

    def set_creator
      @startup.creator = request.remote_ip
    end

    # Never trust parameters from the scary internet, only allow the white list through.
    def startup_params
      params.require(:startup).permit(:name, :url, :added, :founded, :mal, :creator, :description, {:category => []})
    end
end

Startup.category文字列から文字列のリストに切り替えたいときに、この問題が発生し始めました。

どこが間違っているのか、またはどこでエラー情報を確認できますか?

4

1 に答える 1

12

whateverModel.save例外は発生しませんが、true(モデルが保存されている) または を返しますfalsesavecreateまたはupdate_attributes(強打なしで)またはvalid?モデルがerrorsコンソールからプロパティを公開する場合:

puts @s.errors.messages.inspect

アップデート :

あなたの最後の(そして唯一の)式before_validationが返されます。falseこれは、トランザクションが中止されることを意味します。試してください:

self.mal=false
true
于 2013-04-26T00:46:44.743 に答える