如何使用RSpec测试CSV导入?

时间:2016-02-11 13:30:36

标签: ruby-on-rails rspec

我在使用存根时遇到问题,不知道应该如何测试这个类方法:

class Artist < ActiveRecord::Base
  def self.import(file)
    CSV.foreach(file.path, headers: true) do |row|
      Artist.find_or_create_by(row.to_hash)
    end
  end
end

RSpec.describe Artist, type: :model do
  describe ".import" do
    before :each do
      create(:artist, name: 'artist1', facebook_url: nil)
      create(:artist, name: 'artist2', facebook_url: "facebook_url")
    end

    context "when facebook_url is empty" do
      it "updates facebook_url" do
        #Here I should somehow stub CSV with name, facebook_url
        #headers and row: artist1,artist1_facebook_url - HOW ?

        Artist.import(file)
        expect(Artist.find_by(name: 'artist1').facebook_url).to eq "artist1_facebook_url"
      end
    end
  end
end

如何将其存根以使此测试有效?

1 个答案:

答案 0 :(得分:7)

你可以这样写:

file = CSV.generate do |csv|
  csv << ["name", "facebook_url"] #hash keys
  csv << ["artict1", "nil"]
  csv << ["artict2", "facebook_url"]
end 
# String instead of file

然后是这样的:

expect(File).to receive(:open).with("filename", "r").and_return(file)  
Artist.import("filename")
expect(Artist.find_by(name: 'artist1').facebook_url).to eq "artist1_facebook_url"