diff options
author | Devtools Arcadia <arcadia-devtools@yandex-team.ru> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /util/system/ut | |
download | ydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'util/system/ut')
-rw-r--r-- | util/system/ut/stdin_osfhandle/main.cpp | 15 | ||||
-rw-r--r-- | util/system/ut/stdin_osfhandle/ya.make | 14 | ||||
-rw-r--r-- | util/system/ut/ya.make | 88 |
3 files changed, 117 insertions, 0 deletions
diff --git a/util/system/ut/stdin_osfhandle/main.cpp b/util/system/ut/stdin_osfhandle/main.cpp new file mode 100644 index 0000000000..fe2ea836a9 --- /dev/null +++ b/util/system/ut/stdin_osfhandle/main.cpp @@ -0,0 +1,15 @@ +#include <io.h> +#include <stdio.h> +#include <windows.h> + +int main() { + auto handle = (unsigned long long)_get_osfhandle(0); + fprintf(stderr, "_get_osfhandle(0)=%llu\n", handle); + // It look's like classic windows undocumented behaviour + // https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/get-osfhandle + // _get_osfhandle returns INVALID_HANDLE_VALUE - 1 without any sign of error if specified fd was closed. + // Working with such handle will lead to future various errors. + if (handle + 1 == (unsigned long long)INVALID_HANDLE_VALUE) + return 1; + return 0; +} diff --git a/util/system/ut/stdin_osfhandle/ya.make b/util/system/ut/stdin_osfhandle/ya.make new file mode 100644 index 0000000000..d71ab22e69 --- /dev/null +++ b/util/system/ut/stdin_osfhandle/ya.make @@ -0,0 +1,14 @@ +PROGRAM() + +OWNER(g:util) +SUBSCRIBER(g:util-subscribers) + +SRCS( + main.cpp +) + +NO_UTIL() + +BUILD_ONLY_IF(OS_WINDOWS) + +END() diff --git a/util/system/ut/ya.make b/util/system/ut/ya.make new file mode 100644 index 0000000000..127e7c261e --- /dev/null +++ b/util/system/ut/ya.make @@ -0,0 +1,88 @@ +UNITTEST_FOR(util) + +OWNER(g:util) +SUBSCRIBER(g:util-subscribers) + +FORK_TESTS() + +FORK_SUBTESTS() + +SPLIT_FACTOR(40) + +TIMEOUT(300) + +SIZE(MEDIUM) + +IF (OS_DARWIN) + SIZE(LARGE) + TAG(ya:fat ya:force_sandbox ya:exotic_platform) + TIMEOUT(3600) +ENDIF() + +PEERDIR( + library/cpp/testing/benchmark +) + +SRCS( + system/align_ut.cpp + system/atexit_ut.cpp + system/atomic_ut.cpp + system/backtrace_ut.cpp + system/byteorder_ut.cpp + system/compat_ut.cpp + system/compiler_ut.cpp + system/context_ut.cpp + system/condvar_ut.cpp + system/cpu_id_ut.cpp + system/datetime_ut.cpp + system/daemon_ut.cpp + system/direct_io_ut.cpp + system/env_ut.cpp + system/error_ut.cpp + system/event_ut.cpp + system/execpath_ut.cpp + system/file_ut.cpp + system/filemap_ut.cpp + system/flock_ut.cpp + system/fs_ut.cpp + system/fstat_ut.cpp + system/getpid_ut.cpp + system/guard_ut.cpp + system/hi_lo_ut.cpp + system/hostname_ut.cpp + system/info_ut.cpp + system/interrupt_signals_ut.cpp + system/mem_info_ut.cpp + system/mincore_ut.cpp + system/mutex_ut.cpp + system/nice_ut.cpp + system/pipe_ut.cpp + system/platform_ut.cpp + system/progname_ut.cpp + system/rusage_ut.cpp + system/rwlock_ut.cpp + system/sanitizers_ut.cpp + system/shellcommand_ut.cpp + system/spinlock_ut.cpp + system/src_root_ut.cpp + system/src_location_ut.cpp + system/shmat_ut.cpp + system/tempfile_ut.cpp + system/thread_ut.cpp + system/tls_ut.cpp + system/types_ut.cpp + system/type_name_ut.cpp + system/user_ut.cpp + system/unaligned_mem_ut.cpp + system/yassert_ut.cpp +) + +IF (OS_WINDOWS) + DEPENDS( + util/system/ut/stdin_osfhandle + ) +ENDIF() + +REQUIREMENTS(ram:12) + +END() |