From 6ac748ec12265666987755f5f921df60b26857ef Mon Sep 17 00:00:00 2001 From: theanarkh Date: Wed, 31 Aug 2022 02:33:40 +0800 Subject: [PATCH] src: fix uv_err_name memory leak MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit PR-URL: https://github.com/nodejs/node/pull/44421 Refs: https://github.com/nodejs/node/pull/44401 Reviewed-By: Chengzhong Wu Reviewed-By: Ben Noordhuis Reviewed-By: James M Snell Reviewed-By: Colin Ihrig Reviewed-By: Juan José Arboleda --- src/uv.cc | 3 ++- test/parallel/test-uv-errno.js | 2 ++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/src/uv.cc b/src/uv.cc index 81e80711df8fc5..a98b054a4d3360 100644 --- a/src/uv.cc +++ b/src/uv.cc @@ -73,7 +73,8 @@ void ErrName(const FunctionCallbackInfo& args) { int err; if (!args[0]->Int32Value(env->context()).To(&err)) return; CHECK_LT(err, 0); - const char* name = uv_err_name(err); + char name[50]; + uv_err_name_r(err, name, sizeof(name)); args.GetReturnValue().Set(OneByteString(env->isolate(), name)); } diff --git a/test/parallel/test-uv-errno.js b/test/parallel/test-uv-errno.js index e46b365e4b69e4..f30518fb474657 100644 --- a/test/parallel/test-uv-errno.js +++ b/test/parallel/test-uv-errno.js @@ -12,6 +12,8 @@ const { internalBinding } = require('internal/test/binding'); const uv = internalBinding('uv'); const keys = Object.keys(uv); +assert.strictEqual(uv.errname(-111111), 'Unknown system error -111111'); + keys.forEach((key) => { if (!key.startsWith('UV_')) return;