Bug #19188
closedRuby 2.7.7 CGI Cookie Processing
Description
This is my first bug report here, apologies if I mess things up.
Ruby 2.7.7 introduced a code change in lib/ruby/2.7.0/cgi/cookie.rb. There is now a custom setter for the domain attribute. You can see me debugging this below
126: def domain=(str)
127: byebug
=> 128: if str and ((str = str.b).bytesize > 255 or !DOMAIN_VALUE_RE.match?(str))
129: raise ArgumentError, "invalid domain: #{str.dump}"
130: end
When you are running a test on rails using capybara and rspec the value of domain will be ".example.com". This value is the same on ruby 2.7.6. The new code in 2.7.7 rejects this code as an invalid domain because DOMAIN_VALUE_RE.match?(str)
is false.
I think DOMAIN_VALUE_RE
needs to be changed so it matches ".example.com" otherwise lots of tests on Rails applications are going to fail
Updated by alanwu (Alan Wu) about 2 years ago
- Status changed from Open to Closed
This is already fixed on the master branch: https://github.com/ruby/ruby/commit/745dcf5326ea2c8e2047a3bddeb0fbb7e7d07649
Updated by mame (Yusuke Endoh) about 2 years ago
You may want to use cgi gem 0.3.6