![Page 1: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/1.jpg)
Тестирование. Скорость.
Александр Балашов / Evrone
![Page 2: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/2.jpg)
Загрузка приложения
1
![Page 3: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/3.jpg)
![Page 4: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/4.jpg)
![Page 5: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/5.jpg)
![Page 6: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/6.jpg)
(при реальном количестве гемов)
![Page 7: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/7.jpg)
Группы в Gemfile
=> 3с
group :testgroup :developmentgroup :production
![Page 8: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/8.jpg)
:development
•hirb
•wirble
• bullet
•migration_opener
• letter_opener
• capistrano
• quiet_assets
• capistrano-nc
• localeapp
• dev_log_in
![Page 9: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/9.jpg)
:test
• fakeweb
• timecop
• database_cleaner
• launchy
• zonebie
![Page 10: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/10.jpg)
:production
•newrelic_rpm
![Page 11: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/11.jpg)
Lazy require
=> 3с
gem 'savon', require: falserequire 'savon'
gem ‘paper_trail’, require: false
gem 'whenever', require: false
![Page 12: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/12.jpg)
Почистить Gemfile
![Page 13: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/13.jpg)
Редко используемые
# gem ‘debugger’# gem ‘ruby-prof’
![Page 14: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/14.jpg)
Время выполнения
2
![Page 15: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/15.jpg)
Finished in 15 minutes 12.9 seconds1589 examples, 0 failures, 0 pending
![Page 16: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/16.jpg)
![Page 17: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/17.jpg)
Статистика FactoryGirl
USER — 1m 36create: 3425
![Page 18: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/18.jpg)
• до 2 мин на создание одной фабрики
• несколько тысяч вызовов каждой• 7 фабрик с временем минута и более
![Page 19: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/19.jpg)
Время FactoryGirl
50%
![Page 20: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/20.jpg)
FactoryGirl.create(:user)
Когда реально нужно учитывать состояние БД
![Page 21: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/21.jpg)
FactoryGirl.build(:user)
Реально создаёт объекты в БД
![Page 22: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/22.jpg)
User.new
•Простые валидации•Методы не связанные с БД
![Page 23: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/23.jpg)
stub_model(User)
•Быстро работает•Независимость тестов•Подходит для spec/services/*
•Подходит для spec/mailers/*
![Page 24: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/24.jpg)
FactoryGirl Seeds
![Page 25: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/25.jpg)
Вложенные фабрики
=> 2мин
rating < comment < post < user < city
![Page 26: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/26.jpg)
factory :keyword do project { seed(:project) } user { project.user }
![Page 27: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/27.jpg)
Стандартные фабрики
comment = create(:comment)
![Page 28: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/28.jpg)
Finished in 10 minutes 42.38 seconds1556 examples, 0 failures, 0 pending
![Page 29: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/29.jpg)
(10 * 60 + 42) / (15 * 60 + 13) =
2x
![Page 30: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/30.jpg)
Запуск тестов
3
![Page 31: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/31.jpg)
Spork
![Page 32: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/32.jpg)
Spin
spin servespin push spec/models/user_spec.rb:12
![Page 33: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/33.jpg)
Zeus
zeus startzeus test spec/models/user_spec.rb:12
![Page 34: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/34.jpg)
Spring
spring rspec spec/models/user_spec.rb:12
![Page 35: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/35.jpg)
alias rg='spring rails g'alias rs='spring rails s'alias rc='spring rails c'
![Page 36: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/36.jpg)
rails/commands
rails console test
> test "models/user"
![Page 37: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/37.jpg)
rspec-console
rspec spec/models/user_spec.rb:13
![Page 38: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/38.jpg)
Приёмы в спеках
4
![Page 39: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/39.jpg)
valid? вместо save
![Page 40: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/40.jpg)
много it при объёмном before
![Page 41: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/41.jpg)
slow: true
(требует CI-сервера)
# .rspec--tag ~slow --tag ~stable
![Page 42: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/42.jpg)
stable: true
(требует CI-сервера)
![Page 43: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/43.jpg)
Rails.logger.level = Logger::WARN
![Page 44: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/44.jpg)
Devise.stretches = 1
![Page 45: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/45.jpg)
Top 10 slowest examples
# .rspec-p
![Page 46: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/46.jpg)
Повсеместный User
user = create(:user)
![Page 47: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/47.jpg)
Finished in 2 minutes 38.91 seconds893 examples, 0 failures, 0 pending
![Page 48: Скоростное тестирование Rails / Александр Балашов (Evrone)](https://reader034.vdocuments.pub/reader034/viewer/2022042606/546e699ab4af9fd7268b461c/html5/thumbnails/48.jpg)
(15 * 60 + 13) / (2 * 60 + 38) =
6x