質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.92%

Rspecでno method errorを出る。

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 191

atsushi0804

score 1

RspecとFactoryBotを使用したテストで予期せぬエラーがでた。

railsで商品売買アプリを自主制作しており、現在Orderモデルに対するバリデーションの単体テストを書いています。そこでorderモデルのカラムの一つaddressカラムのエラーがどうも解除できません。

bundle exec rspec ./spec/models/order_spec.rb後のターミナルのエラー文

Order
  #create
    id,zipcode,prefecture,city,address,building,seller_id,buyer_id,item_id,reciever_last_name,receiver_first_nameがあれば登録できること (FAILED - 1)

Failures:

  1) Order#create id,zipcode,prefecture,city,address,building,seller_id,buyer_id,item_id,reciever_last_name,receiver_first_nameがあれば登録できること
     Failure/Error: order = build(:order)

     NoMethodError:
       undefined method `address=' for #<Order:0x00007fa1c5ef0330>
     # ./spec/models/order_spec.rb:11:in `block (3 levels) in <top (required)>'

Finished in 0.76696 seconds (files took 4.64 seconds to load)
1 example, 1 failure

Failed examples:

rspec ./spec/models/order_spec.rb:10 # Order#create id,zipcode,prefecture,city,address,building,seller_id,buyer_id,item_id,reciever_last_name,receiver_first_nameがあれば登録できること

FactoryBotのorders.rbの記述

FactoryBot.define do
  factory :order do
    zipcode              {'998-9909'}
    prefecture           {'Fukuoka'}
    city                 {'Fukuoka'}
    building             {'Fukuoka000'}
    address              {'fukuoka'}
    receiver_last_name   {'test'}
    receiver_first_name  {'test'}
    buyer_id             {'1'}
    seller_id            {'2'}
    item
  end
end

order_spec.rb内の記述

require 'rails_helper'

describe Order do
  describe '#create' do

    before do
      @item = create(:item)
    end

    it 'id,zipcode,prefecture,city,address,building,seller_id,buyer_id,item_id,reciever_last_name,receiver_first_nameがあれば登録できること' do
      order = build(:order)
      expect(order).to be_valid
    end

  end
end

一応モデル内のバリデーションは以下になります。

class Order < ApplicationRecord
  belongs_to :item
  belongs_to :seller, class_name: 'User', optional: true, foreign_key: true
  belongs_to :buyer, class_name: 'User', optional: true, foreign_key: true

  validates :receiver_last_name, presence: true
  validates :receiver_first_name, presence: true
  validates :zipcode, presence: true
  validates :prefecture, presence: true
  validates :city, presence: true
  validates :address, presence: true
end

疑問に思うこと

  • ターミナルで表示されるのはNoMethodError:undefined method `address=' for #<Order:0x00007fa1c5ef0330>でaddress=が定義されていませんとなっています。しかしFactoryBotに記述しているのはaddressであってaddress=ではありません。これはどういうことなのでしょうか?

試したこと

  • 一度FactoryBotの中のaddressの記述を消してテストをしてみると上記のエラー文の
NoMethodError:undefined method `address=' for #<Order:0x00007fa1c5ef0330>

ここが

NoMethodError:undefined method `address' for #<Order:0x00007fa1c5ef0330>

と=がなくなった状態になります。FactoryBotを何も書いていないのに上記のエラー文が出てしまうのはどういうことかわからずに困っています。 どうかアドバイスを頂けますと助かります。お願いします。

追記

schema.rbで確認しましたが、ordersテーブルにストリング型でしっかりとaddressが存在する状態です。

  create_table "orders", options: "ENGINE=InnoDB DEFAULT CHARSET=utf8", force: :cascade do |t|
    t.bigint "seller_id", null: false
    t.bigint "buyer_id", null: false
    t.bigint "item_id", null: false
    t.string "receiver_last_name"
    t.string "receiver_first_name"
    t.string "zipcode", null: false
    t.string "prefecture", null: false
    t.string "city", null: false
    t.string "address", null: false
    t.string "building"
    t.datetime "created_at", null: false
    t.datetime "updated_at", null: false
    t.index ["buyer_id"], name: "index_orders_on_buyer_id"
    t.index ["item_id"], name: "index_orders_on_item_id"
    t.index ["seller_id"], name: "index_orders_on_seller_id"
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+1

症状からの第一感では DBのtable orders に addressというcolumnがない、という感じです。
migration1やdb/schema.rbで確認してください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/09 16:17

    追記でschema.rbの中身をあげさせていただきましたが、テーブルにはしっかりとaddressカラムが存在する形になります。mysqlで確認しても存在しております。
    この状況だと何か他に問題点はありますでしょうか?

    キャンセル

  • 2020/07/09 16:42

    address=  が無いというのが出たのは address {'fukuoka'} によって、
    order.address = 'fukuok' が実行されるからです。
    address= は ActiveRecordがDBと接続した時にtable ordersのschemaを読んで動的に定義します。
    さて、、、、
    mysqlで確認したdatabaseは、developmentのものではないですか? testのものでも有りますか?

    キャンセル

  • 2020/07/09 20:35

    コメントありがとうございます!
    確認しましたところ、developmentもtestの方でもどちらでもaddressというカラムが存在する状況でした。スペル間違いもない状況です。

    キャンセル

  • 2020/07/09 20:38

    今rails db:migrate:resetをして見たら理由がわからないのですが無事にテストが通りました。。。

    キャンセル

0

一応解決しました!

rails db:migrate:resetを実行した後にテストを実行したら無事に通りました。。。
どうしてリセットをしたら通ったのかはわかりませんのでもしどちら様か可能性のある理由があれば教えていただけると助かりますが、一応自己解決とさせていただきます!
winterboumさんは回答どうもありがとうございます!

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る