Vấn đề / Problem
Như các bạn đã biết, việc gỡ lỗi (debug) là một phần quan trọng và thường xuyên trong công việc của lập trình viên. Nó giúp chúng ta xác định và khắc phục lỗi trong quá trình phát triển phần mềm. Tôi đã gặp một tình huống khi thực hiện việc gỡ lỗi trên một ứng dụng web được xây dựng trên framework Ruby on Rails phiên bản 5.2. Vấn đề xuất phát từ việc không thể dừng tại các điểm breakpoint khi sử dụng môi trường phát triển (IDE) với phiên bản Rails 5 (thay vì phiên bản Rails 4).
Môi trường của mình như sau:
- Ruby Framework: Rails 5.2
- IDE: Visual Studio Code ( Trên Các IDE khác cũng vậy )
- ruby-debug-ide version: 0.6.1
- OS: Ubuntu 16.04
Nguyên nhân / Cause
Nguyên nhân của vấn đề là từ Rails 5.2.0 đến 5.2.1, Rails sử dụng bootsnap để tăng tốc cho framework của mình bằng cách sử dụng caching. Nhưng vô tính nó làm vô hiệu quá các điểm breakpoint trên IDE.
Giải pháp / Khắc phục
Nếu bạn vẫn đang sử dụng Rails version 5.2.0 và 5.2.1 thì bạn hãy comment dòng sau ở file [app root]/config/boot.rb
require 'bootsnap/setup' # Speed up boot time by caching expensive operations.
Chú ý: thật may mắn là Rails đã xử lý vấn đề này ở phiên bản mới nhất 5.2.2.( ruby/ruby@b85b10c).
Vì vậy chúng ta có 1 giải pháp khắc phục nữa là, chỉ thay đoạn code trên bằng:
unless ( (('2.5.0'..'2.5.1').include? RUBY_VERSION) && defined?(Debugger) ) require 'bootsnap/setup' # Speed up boot time by caching expensive operations. end
Nó sẽ chỉ require bootsnap khi ở các version bị lỗi.