diff options
author | Kazuhiro NISHIYAMA <zn@mbf.nifty.com> | 2020-05-08 00:12:48 +0900 |
---|---|---|
committer | Kazuhiro NISHIYAMA <zn@mbf.nifty.com> | 2020-05-08 00:12:48 +0900 |
commit | 22b1e824d736d394c9efaabf882e9a6110135a57 (patch) | |
tree | 81501857b7ddf86948245eee4c874fb83d30ff5f /tool/lib | |
parent | f38c641994265a87a0380752dbc670937094be42 (diff) |
Check encodings of STDIN,STDOUT,STDERR too
Diffstat (limited to 'tool/lib')
-rw-r--r-- | tool/lib/leakchecker.rb | 31 |
1 files changed, 19 insertions, 12 deletions
diff --git a/tool/lib/leakchecker.rb b/tool/lib/leakchecker.rb index 222b9ec3c8..7ed48ec1ab 100644 --- a/tool/lib/leakchecker.rb +++ b/tool/lib/leakchecker.rb @@ -237,23 +237,30 @@ class LeakChecker end def find_encodings - [Encoding.default_internal, Encoding.default_external] + { + 'Encoding.default_internal' => Encoding.default_internal, + 'Encoding.default_external' => Encoding.default_external, + 'STDIN.internal_encoding' => STDIN.internal_encoding, + 'STDIN.external_encoding' => STDIN.external_encoding, + 'STDOUT.internal_encoding' => STDOUT.internal_encoding, + 'STDOUT.external_encoding' => STDOUT.external_encoding, + 'STDERR.internal_encoding' => STDERR.internal_encoding, + 'STDERR.external_encoding' => STDERR.external_encoding, + } end def check_encodings(test_name) - old_internal, old_external = @encoding_info - new_internal, new_external = find_encodings + old_encoding_info = @encoding_info + @encoding_info = find_encodings leaked = false - if new_internal != old_internal - leaked = true - puts "Encoding.default_internal changed: #{test_name} : #{old_internal.inspect} to #{new_internal.inspect}" - end - if new_external != old_external - leaked = true - puts "Encoding.default_external changed: #{test_name} : #{old_external.inspect} to #{new_external.inspect}" + @encoding_info.each do |key, new_encoding| + old_encoding = old_encoding_info[key] + if new_encoding != old_encoding + leaked = true + puts "#{key} changed: #{test_name} : #{old_encoding.inspect} to #{new_encoding.inspect}" + end end - @encoding_info = [new_internal, new_external] - return leaked + leaked end WARNING_CATEGORIES = %i[deprecated experimental].freeze |