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

, что означает, что это исключение было перехвачено вторым блоком восстановления. В чем может быть причина?

12
задан blahdiblah 15 December 2011 в 20:45
поделиться