Catching Mechanize 404 => Net:: HTTPNotFound
Я написал простую функцию, которая обрабатывает выборку URL:
def tender_page_get url, agent
sleep(rand(6)+2)
begin
return agent.get(url).parser
rescue Errno::ETIMEDOUT, Timeout::Error, Net::HTTPNotFound
EYE.debug "--winter sleep #{url}"
puts "-x-#{url}"
sleep(300)
tender_page_get url, agent
rescue => e
puts "-x-#{url}"
EYE.debug "--unknown exception"
EYE.debug "#{url} #{e.inspect}"
end
end
Проблема заключается в том, что, хотя я ловил Net::HTTPNotFound
в первом блоке аварийного восстановления, я все еще вижу в своих журнальных записях, например:
--unknown exception
{url} 404 => Net::HTTPNotFound
что означает, что это исключение было обнаружено вторым блоком спасения. Что может быть причиной этого?
Ответы
Ответ 1
Механизм повышает Механизм:: ResponseCodeError для 404, а не Net:: HTTPNotFound. To_s on Mechanize:: ResponseCodeError выглядит следующим образом:
def to_s
"#{response_code} => #{Net::HTTPResponse::CODE_TO_OBJ[response_code]}"
end
Это возвращает '404 = > Net:: HTTPNotFound', что делает его похожим на то, что это исключение.