Механизм Catching 404 => Net :: HTTPNotFound - PullRequest
12 голосов
/ 08 мая 2011

Я написал простую функцию, которая обрабатывает выборку 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 Ответ

19 голосов
/ 22 мая 2011

Mechanize вызывает Mechanize :: ResponseCodeError для 404, а не для Net :: HTTPNotFound.To_s на Mechanize :: ResponseCodeError выглядит следующим образом:

def to_s
  "#{response_code} => #{Net::HTTPResponse::CODE_TO_OBJ[response_code]}"
end

Это возвращает '404 => Net :: HTTPNotFound', что делает его похожим на возникающее исключение.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...