Ошибка RSpec и Machinist: слишком много открытых файлов - PullRequest
7 голосов
/ 29 февраля 2012

Этим утром у меня появляется следующая ошибка:

  14) Deal on creation sets frozen to false or nil
     Failure/Error: Unable to find matching line from backtrace
     Errno::EMFILE:
       Too many open files - identify -format %wx%h '/var/folders/BJ/BJcTANEBFxWcan28U2YEKE+++TI/-Tmp-/stream20120229-36866-4l1sa8.gif[0]'
     # ./spec/support/blueprints.rb:29:in `block in <top (required)>'

Спецификации чертовски медленны (даже со спорком), поэтому они бесполезны. Для запуска 20 примеров в модели требуется 9 минут. Строка 29 в blueprint.rb находится между следующими блоками:

Company.blueprint do
  name { "Office Tronic#{rand(10 ** 10)}" }
  website { 'officetronic.com' }
  subdomain {"officetronic#{rand(10 ** 10)}"}
  facebook { 'officetronic' }
  twitter { 'officetronic' }
  description { 'We are a company dealing with electronics and office supply' }
  address_line1 {'34 John Street'}
  address_line2 {''}
  post_code { 'EC2 3RR' }
  phone { '01 343243434' }
  city { 'London' }
  your_name { 'john Doe' }
  font_colour {'000000'}
  logo_file_name { 'mylogo.png' }  
  logo_content_type { "application/png" }
  logo_file_size { 100 }
end

Deal.blueprint do
  company {Company.make!}
  title { '50% off for web sites dev' }
  description { '50% of discount...' }
  quantity { 1 }
  min_quantity { 0 }
  start_time { Chronic.parse('one month') }
  end_time { Chronic.parse('two months') }
  price { 1500 } # in cents
  shipping_cost{ 100 } # in cents
  published { true }
  small_print { 'Some text' }
  show_map { true }
  post_code { 'E1 6BJ' }
  rrp {15}
end

1 Ответ

11 голосов
/ 26 мая 2013

Слишком много открытых файлов - ошибка ОС, означающая, что в ОС закончились файловые дескрипторы.В Linux обычно существует жесткое ограничение на количество файлов, которые могут быть открыты одновременно, и этот предел достигнут.

Чтобы временно увеличить ограничение, сначала запустите ulimit -n 8192, а затем запустите спецификации.

Чтобы окончательно увеличить лимит, следуйте этим инструкциям и замените nginx именем учетной записи пользователя, которую вы используете для запуска спецификаций.

...