Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to test CSV import with RSpec?

I have problems with using stubs, and not sure how should I test this class method:

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

How should I stub it to make this test work ?

like image 434
Marcin Doliwa Avatar asked Feb 11 '16 13:02

Marcin Doliwa


Video Answer


1 Answers

You can write something like:

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

Then test it:

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"
like image 146
Ilya Avatar answered Oct 25 '22 23:10

Ilya