From 58dd45ae26c8f2f19bcb3bf8809cc4eaef1abb92 Mon Sep 17 00:00:00 2001 From: sfc-gh-ext-simba-hx Date: Tue, 9 Jul 2024 10:09:07 -0700 Subject: [PATCH] fix issue of sf_getenv_s on Windows with environment variable not being set --- lib/platform.c | 6 ++++-- tests/test_unit_proxy.cpp | 8 -------- 2 files changed, 4 insertions(+), 10 deletions(-) diff --git a/lib/platform.c b/lib/platform.c index 26939c4799..baf5a0ead3 100755 --- a/lib/platform.c +++ b/lib/platform.c @@ -270,8 +270,10 @@ int STDCALL sf_setenv(const char *name, const char *value) { char * STDCALL sf_getenv_s(const char *name, char *outbuf, size_t bufsize) { #ifdef _WIN32 - size_t len; - return getenv_s(&len, outbuf, bufsize, name) ? NULL : outbuf; + size_t len = 0; + // SNOW-1526802 on Windows environment variable can't be set to empty + // and getenv_s returns 0 with length of 0 for environment variables not being set + return getenv_s(&len, outbuf, bufsize, name) || (len == 0) ? NULL : outbuf; #else char* envval = getenv(name); if (!envval) diff --git a/tests/test_unit_proxy.cpp b/tests/test_unit_proxy.cpp index 6dce6f6b88..518336e2fc 100755 --- a/tests/test_unit_proxy.cpp +++ b/tests/test_unit_proxy.cpp @@ -66,8 +66,6 @@ void test_proxy_empty(void **unused) void test_allproxy_noproxy_fromenv(void **unused) { - SKIP_IF_PROXY_ENV_IS_SET; - sf_setenv("all_proxy", "https://someuser:somepwd@somewhere.com:5050"); sf_setenv("no_proxy", "proxyserver.com"); test_proxy_parts_equality("", "someuser", "somepwd", "somewhere.com", 5050, Proxy::Protocol::HTTPS, "proxyserver.com", true); @@ -77,8 +75,6 @@ void test_allproxy_noproxy_fromenv(void **unused) void test_httpsproxy_fromenv(void **unused) { - SKIP_IF_PROXY_ENV_IS_SET; - sf_setenv("https_proxy", "https://someuser:somepwd@somewhere.com:5050"); test_proxy_parts_equality("", "someuser", "somepwd", "somewhere.com", 5050, Proxy::Protocol::HTTPS, "", true); sf_unsetenv("https_proxy"); @@ -86,8 +82,6 @@ void test_httpsproxy_fromenv(void **unused) void test_httpproxy_fromenv(void **unused) { - SKIP_IF_PROXY_ENV_IS_SET; - sf_setenv("http_proxy", "http://username:password@proxyserver.company.com:80"); test_proxy_parts_equality("", "username", "password", "proxyserver.company.com", 80, Proxy::Protocol::HTTP, "", true); sf_unsetenv("http_proxy"); @@ -95,8 +89,6 @@ void test_httpproxy_fromenv(void **unused) void test_noproxy_fromenv(void **unused) { - SKIP_IF_PROXY_ENV_IS_SET; - sf_setenv("NO_PROXY", "proxyserver.company.com"); test_proxy_parts_equality("", "", "", "", 0, Proxy::Protocol::NONE, "proxyserver.company.com", true); sf_unsetenv("NO_PROXY");