From f57e2d7296fbdf09041bdb237c7423a12ef06621 Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Thu, 16 Apr 2020 20:40:19 +0900 Subject: Preserve encoding in error message for invalid env exec option --- process.c | 2 +- test/ruby/test_process.rb | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/process.c b/process.c index f13ec82ba0..129a2e6706 100644 --- a/process.c +++ b/process.c @@ -2325,7 +2325,7 @@ check_exec_env_i(st_data_t st_key, st_data_t st_val, st_data_t arg) k = StringValueCStr(key); if (strchr(k, '=')) - rb_raise(rb_eArgError, "environment name contains a equal : %s", k); + rb_raise(rb_eArgError, "environment name contains a equal : %"PRIsVALUE, key); if (!NIL_P(val)) StringValueCStr(val); diff --git a/test/ruby/test_process.rb b/test/ruby/test_process.rb index e9c7ee62b2..7170e826d5 100644 --- a/test/ruby/test_process.rb +++ b/test/ruby/test_process.rb @@ -342,6 +342,9 @@ class TestProcess < Test::Unit::TestCase assert_raise_with_message(ArgumentError, /fo=fo/) { system({"fo=fo"=>"ha"}, *ENVCOMMAND) } + assert_raise_with_message(ArgumentError, /\u{30c0}=\u{30e1}/) { + system({"\u{30c0}=\u{30e1}"=>"ha"}, *ENVCOMMAND) + } end def test_execopt_env_path -- cgit v1.2.3