前提・実現したいこと
Rspecを用いてスクレイピングプログラムのテストを考えています。
以下のソースのように、Crawlerクラスの各メソッドのテストをしたいと思っており、
まずCrawlerクラスのインスタンスを生成しようと思うのですが、
initializeでクロールの対象ページにfetch_htmlメソッドでアクセスするため、
fetch_htmlメソッドをスタブ化したいと考えております。
しかし、レシーバが存在しない関数的メソッドのため、
どのようにスタブしたらいいかわからず、
どなたか、ご教授いただけますと幸いでございます。
該当のソースコード
ruby
1#crawler.rb 2require_relative "common.rbのパス" 3 4class Crawler 5 def initialize(top_page: "https://hoge.html") 6 @doc = Nokogiri::HTML.parse(fetch_html(top_page)) 7 end 8 9 def list_crawl 10 urls = @doc.css(".hogehoge").~~~~ 11 end 12end 13 14#common.rb 15def fetch_html(url) 16 sleep 1 17 URI.open(url).read 18end 19 20#crawl_spec.rb 21require 'rails_helper' 22require_relative 'crawler.rbのパス' 23 24describe 'crawler' do 25 context 'list_crawl' do 26 it 'is succeed with correct html' do 27 html_path = File.expand_path("foo.htmlのパス", __FILE__) 28 html = File.open(html_path).read 29 # 以降Crawler.newした際に、fetch_htmlメソッドがスタブされるようにしたいです。(@docにfoo.htmlがパースされたインスタンスを生成したい) 30 end 31 end 32end 33
補足情報(FW/ツールのバージョンなど)
ruby 2.7.2p137
rails 6.1.3
rspec-rails 5.0.1
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/05/25 15:01