src/dblib/unittests/t0005

Main

Hostnamekrb5.freetds.io
uname -aLinux krb5.freetds.io 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux
date2025-10-26

==26537== Memcheck, a memory error detector
==26537== Copyright (C) 2002-2017, and GNU GPL'd, by Julian Seward et al.
==26537== Using Valgrind-3.13.0 and LibVEX; rerun with -h for copyright info
==26537== Command: ./t0005
==26537== 
--26537-- Valgrind options:
--26537--    --tool=memcheck
--26537--    --vgdb=no
--26537--    --num-callers=20
--26537--    --leak-check=yes
--26537--    -v
--26537--    --show-reachable=yes
--26537--    --log-fd=3
--26537--    --suppressions=/home/test/suppressions.supp
--26537--    --track-origins=yes
--26537-- Contents of /proc/version:
--26537--   Linux version 4.15.0-213-generic (buildd@lcy02-amd64-079) (gcc version 7.5.0 (Ubuntu 7.5.0-3ubuntu1~18.04)) #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023
--26537-- 
--26537-- Arch and hwcaps: AMD64, LittleEndian, amd64-cx16-lzcnt-rdtscp-sse3-avx-avx2-bmi
--26537-- Page sizes: currently 4096, max supported 4096
--26537-- Valgrind library directory: /usr/lib/valgrind
--26537-- Reading syms from /home/test/ftdstmp/ftds_comp100/test3/src/dblib/unittests/t0005
--26537-- Reading syms from /lib/x86_64-linux-gnu/ld-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/ld-2.27.so ..
--26537--   .. CRC mismatch (computed 2977d8b2 wanted c64f09ed)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/ld-2.27.so ..
--26537--   .. CRC is valid
--26537-- Reading syms from /usr/lib/valgrind/memcheck-amd64-linux
--26537--   Considering /usr/lib/valgrind/memcheck-amd64-linux ..
--26537--   .. CRC mismatch (computed 41ddb025 wanted 9972f546)
--26537--    object doesn't have a symbol table
--26537--    object doesn't have a dynamic symbol table
--26537-- Scheduler: using generic scheduler lock implementation.
--26537-- Reading suppressions file: /home/test/suppressions.supp
--26537-- Reading suppressions file: /usr/lib/valgrind/default.supp
--26537-- REDIR: 0x4020d20 (ld-linux-x86-64.so.2:strlen) redirected to 0x580608c1 (???)
--26537-- REDIR: 0x4020b00 (ld-linux-x86-64.so.2:index) redirected to 0x580608db (???)
--26537-- Reading syms from /usr/lib/valgrind/vgpreload_core-amd64-linux.so
--26537--   Considering /usr/lib/valgrind/vgpreload_core-amd64-linux.so ..
--26537--   .. CRC mismatch (computed 50df1b30 wanted 4800a4cf)
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so
--26537--   Considering /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so ..
--26537--   .. CRC mismatch (computed f893b962 wanted 95ee359e)
--26537--    object doesn't have a symbol table
==26537== WARNING: new redirection conflicts with existing -- ignoring it
--26537--     old: 0x04020d20 (strlen              ) R-> (0000.0) 0x580608c1 ???
--26537--     new: 0x04020d20 (strlen              ) R-> (2007.0) 0x04c34db0 strlen
--26537-- REDIR: 0x401d540 (ld-linux-x86-64.so.2:strcmp) redirected to 0x4c35ee0 (strcmp)
--26537-- REDIR: 0x4021260 (ld-linux-x86-64.so.2:mempcpy) redirected to 0x4c394f0 (mempcpy)
--26537-- Reading syms from /home/test/ftdstmp/ftds_comp100/src/dblib/.libs/libsybdb.so.5.1.0
--26537-- Reading syms from /lib/x86_64-linux-gnu/libpthread-2.27.so
--26537--   Considering /usr/lib/debug/.build-id/1f/06001733b9be9478b105faf0dac6bdf36c85de.debug ..
--26537--   .. build-id is valid
--26537-- Reading syms from /lib/x86_64-linux-gnu/libc-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libc-2.27.so ..
--26537--   .. CRC mismatch (computed f250d419 wanted 4aacab51)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libc-2.27.so ..
--26537--   .. CRC is valid
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/libgssapi_krb5.so.2.2
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/libssl.so.1.1
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/libcrypto.so.1.1
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/libkrb5.so.3.3
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/libk5crypto.so.3.1
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /lib/x86_64-linux-gnu/libcom_err.so.2.1
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/libkrb5support.so.0.1
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /lib/x86_64-linux-gnu/libdl-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libdl-2.27.so ..
--26537--   .. CRC mismatch (computed 56b0b30d wanted 7867693f)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libdl-2.27.so ..
--26537--   .. CRC is valid
--26537-- Reading syms from /lib/x86_64-linux-gnu/libkeyutils.so.1.5
--26537--    object doesn't have a symbol table
--26537-- Reading syms from /lib/x86_64-linux-gnu/libresolv-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libresolv-2.27.so ..
--26537--   .. CRC mismatch (computed 0da9c5d1 wanted b111a73d)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libresolv-2.27.so ..
--26537--   .. CRC is valid
--26537-- REDIR: 0x53d6a50 (libc.so.6:memmove) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5d60 (libc.so.6:strncpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6d30 (libc.so.6:strcasecmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d57b0 (libc.so.6:strcat) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5d90 (libc.so.6:rindex) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d8480 (libc.so.6:rawmemchr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6bc0 (libc.so.6:mempcpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d69f0 (libc.so.6:bcmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5d20 (libc.so.6:strncmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5820 (libc.so.6:strcmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6b20 (libc.so.6:memset) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53f3db0 (libc.so.6:wcschr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5cc0 (libc.so.6:strnlen) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5890 (libc.so.6:strcspn) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6d80 (libc.so.6:strncasecmp) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5860 (libc.so.6:strcpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6ec0 (libc.so.6:memcpy@@GLIBC_2.14) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5dc0 (libc.so.6:strpbrk) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d57e0 (libc.so.6:index) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d5c90 (libc.so.6:strlen) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53e0380 (libc.so.6:memrchr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6dd0 (libc.so.6:strcasecmp_l) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d69c0 (libc.so.6:memchr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53f4b70 (libc.so.6:wcslen) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6070 (libc.so.6:strspn) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6d00 (libc.so.6:stpncpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6cd0 (libc.so.6:stpcpy) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d84b0 (libc.so.6:strchrnul) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6e20 (libc.so.6:strncasecmp_l) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x5469700 (libc.so.6:__memcpy_chk) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x53d6900 (libc.so.6:strstr) redirected to 0x4a2c6e0 (_vgnU_ifunc_wrapper)
--26537-- REDIR: 0x54c6280 (libc.so.6:__strrchr_avx2) redirected to 0x4c34730 (rindex)
--26537-- REDIR: 0x54c6450 (libc.so.6:__strlen_avx2) redirected to 0x4c34cf0 (strlen)
--26537-- REDIR: 0x53cf910 (libc.so.6:free) redirected to 0x4c32cd0 (free)
--26537-- REDIR: 0x53cf020 (libc.so.6:malloc) redirected to 0x4c31aa0 (malloc)
--26537-- REDIR: 0x54c6990 (libc.so.6:__memcpy_avx_unaligned_erms) redirected to 0x4c386e0 (memmove)
--26537-- REDIR: 0x54bd3d0 (libc.so.6:__strncmp_sse42) redirected to 0x4c35570 (__strncmp_sse42)
--26537-- REDIR: 0x53d65a0 (libc.so.6:__GI_strstr) redirected to 0x4c39760 (__strstr_sse2)
--26537-- REDIR: 0x54c22e0 (libc.so.6:__memchr_avx2) redirected to 0x4c35f80 (memchr)
--26537-- REDIR: 0x54c21c0 (libc.so.6:__strspn_sse42) redirected to 0x4c39990 (strspn)
--26537-- REDIR: 0x54c1f30 (libc.so.6:__strcspn_sse42) redirected to 0x4c398d0 (strcspn)
--26537-- REDIR: 0x54c6090 (libc.so.6:__strchrnul_avx2) redirected to 0x4c39020 (strchrnul)
found SYBASE15.tempdb for sa in "../../../PWD"
--26537-- REDIR: 0x54c6970 (libc.so.6:__mempcpy_avx_unaligned_erms) redirected to 0x4c39130 (mempcpy)
SQL text will be read from ../../../src/dblib/unittests/t0005.sql
Starting ./t0005
--26537-- REDIR: 0x53d2050 (libc.so.6:calloc) redirected to 0x4c33a70 (calloc)
--26537-- REDIR: 0x54c5e60 (libc.so.6:__strchr_avx2) redirected to 0x4c34950 (index)
--26537-- REDIR: 0x54c2e40 (libc.so.6:__strcasecmp_avx) redirected to 0x4c355f0 (strcasecmp)
About to logon
--26537-- REDIR: 0x54c6e10 (libc.so.6:__memset_avx2_unaligned_erms) redirected to 0x4c385d0 (memset)
About to open
--26537-- REDIR: 0x53e1b30 (libc.so.6:__strcmp_sse2_unaligned) redirected to 0x4c35da0 (strcmp)
--26537-- REDIR: 0x53ef810 (libc.so.6:__stpcpy_sse2_unaligned) redirected to 0x4c38200 (__stpcpy_sse2_unaligned)
--26537-- Reading syms from /lib/x86_64-linux-gnu/libnss_compat-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libnss_compat-2.27.so ..
--26537--   .. CRC mismatch (computed dc0305b8 wanted 460e4052)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnss_compat-2.27.so ..
--26537--   .. CRC is valid
--26537-- REDIR: 0x53ee200 (libc.so.6:__strcpy_sse2_unaligned) redirected to 0x4c34dd0 (strcpy)
--26537-- Reading syms from /lib/x86_64-linux-gnu/libnss_nis-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libnss_nis-2.27.so ..
--26537--   .. CRC mismatch (computed 38cb38d0 wanted 96404ac2)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnss_nis-2.27.so ..
--26537--   .. CRC is valid
--26537-- Reading syms from /lib/x86_64-linux-gnu/libnsl-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libnsl-2.27.so ..
--26537--   .. CRC mismatch (computed 12772991 wanted 58367bd1)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnsl-2.27.so ..
--26537--   .. CRC is valid
--26537-- Reading syms from /lib/x86_64-linux-gnu/libnss_files-2.27.so
--26537--   Considering /lib/x86_64-linux-gnu/libnss_files-2.27.so ..
--26537--   .. CRC mismatch (computed 2270a715 wanted a5763524)
--26537--   Considering /usr/lib/debug/lib/x86_64-linux-gnu/libnss_files-2.27.so ..
--26537--   .. CRC is valid
--26537-- REDIR: 0x53f11f0 (libc.so.6:__strcat_sse2_unaligned) redirected to 0x4c34990 (strcat)
--26537-- REDIR: 0x53d0c50 (libc.so.6:realloc) redirected to 0x4c33cb0 (realloc)
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so
--26537--   Considering /usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so ..
--26537--   .. CRC mismatch (computed 83103428 wanted d26a1d18)
--26537--   Considering /usr/lib/debug/usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so ..
--26537--   .. CRC is valid
--26537-- REDIR: 0x54c2a60 (libc.so.6:__memcmp_avx2_movbe) redirected to 0x4c37e00 (bcmp)
--26537-- Reading syms from /usr/lib/x86_64-linux-gnu/gconv/UTF-16.so
--26537--   Considering /usr/lib/x86_64-linux-gnu/gconv/UTF-16.so ..
--26537--   .. CRC mismatch (computed da5394b1 wanted a59039cd)
--26537--   Considering /usr/lib/debug/usr/lib/x86_64-linux-gnu/gconv/UTF-16.so ..
--26537--   .. CRC is valid
creating table
	  1: create table #dblib0005 (i int not null, s char(10) not null)
insert
	  1: insert into #dblib0005 values (1, 'row 0001')
	  1: insert into #dblib0005 values (2, 'row 0002')
	  1: insert into #dblib0005 values (3, 'row 0003')
	  1: insert into #dblib0005 values (4, 'row 0004')
	  1: insert into #dblib0005 values (5, 'row 0005')
	  1: insert into #dblib0005 values (6, 'row 0006')
	  1: insert into #dblib0005 values (7, 'row 0007')
	  1: insert into #dblib0005 values (8, 'row 0008')
	  1: insert into #dblib0005 values (9, 'row 0009')
	  1: insert into #dblib0005 values (10, 'row 0010')
	  1: insert into #dblib0005 values (11, 'row 0011')
	  1: insert into #dblib0005 values (12, 'row 0012')
	  1: insert into #dblib0005 values (13, 'row 0013')
	  1: insert into #dblib0005 values (14, 'row 0014')
	  1: insert into #dblib0005 values (15, 'row 0015')
	  1: insert into #dblib0005 values (16, 'row 0016')
	  1: insert into #dblib0005 values (17, 'row 0017')
	  1: insert into #dblib0005 values (18, 'row 0018')
	  1: insert into #dblib0005 values (19, 'row 0019')
	  1: insert into #dblib0005 values (20, 'row 0020')
	  1: insert into #dblib0005 values (21, 'row 0021')
	  1: insert into #dblib0005 values (22, 'row 0022')
	  1: insert into #dblib0005 values (23, 'row 0023')
	  1: insert into #dblib0005 values (24, 'row 0024')
	  1: insert into #dblib0005 values (25, 'row 0025')
	  1: insert into #dblib0005 values (26, 'row 0026')
	  1: insert into #dblib0005 values (27, 'row 0027')
	  1: insert into #dblib0005 values (28, 'row 0028')
	  1: insert into #dblib0005 values (29, 'row 0029')
	  1: insert into #dblib0005 values (30, 'row 0030')
	  1: insert into #dblib0005 values (31, 'row 0031')
	  1: insert into #dblib0005 values (32, 'row 0032')
	  1: insert into #dblib0005 values (33, 'row 0033')
	  1: insert into #dblib0005 values (34, 'row 0034')
	  1: insert into #dblib0005 values (35, 'row 0035')
	  1: insert into #dblib0005 values (36, 'row 0036')
	  1: insert into #dblib0005 values (37, 'row 0037')
	  1: insert into #dblib0005 values (38, 'row 0038')
	  1: insert into #dblib0005 values (39, 'row 0039')
	  1: insert into #dblib0005 values (40, 'row 0040')
	  1: insert into #dblib0005 values (41, 'row 0041')
	  1: insert into #dblib0005 values (42, 'row 0042')
	  1: insert into #dblib0005 values (43, 'row 0043')
	  1: insert into #dblib0005 values (44, 'row 0044')
	  1: insert into #dblib0005 values (45, 'row 0045')
	  1: insert into #dblib0005 values (46, 'row 0046')
	  1: insert into #dblib0005 values (47, 'row 0047')
	  1: insert into #dblib0005 values (48, 'row 0048')
	  1: insert into #dblib0005 values (49, 'row 0049')
	  1: select * from #dblib0005 where i < 5 order by i
col 1 is i
col 2 is s
Read a row of data -> 1 row 0001  
Read a row of data -> 2 row 0002  
Read a row of data -> 3 row 0003  
Read a row of data -> 4 row 0004  
This query should succeeded as we have fetched the exact
number of rows in the result set
	  1: select * from #dblib0005 where i < 6 order by i
col 1 is i
col 2 is s
Read a row of data -> 1 row 0001  
Read a row of data -> 2 row 0002  
Read a row of data -> 3 row 0003  
Read a row of data -> 4 row 0004  
Testing anticipated failure
	  1: /*
	  2:  * The following query should fail because the test 
	  3:  * has not fetched all the rows in the result set.
	  4:  */
	  5: select * from #dblib0005 where i > 950 order by i
OK: anticipated error 20019 (Attempt to initiate a new TDS server operation with results pending) arrived
calling dbcancel to flush results
Dropping proc
	  1: if object_id('t0005_proc') is not null drop procedure t0005_proc
creating proc
	  1: create proc t0005_proc (@b int out) as
	  2: begin
	  3: select * from #dblib0005 where i < 6 order by i
	  4: select @b = 42
	  5: end
	  6: 
calling proc
	  1: declare @myout int exec t0005_proc @b = @myout output
col 1 is i
col 2 is s
Read a row of data -> 1 row 0001  
Read a row of data -> 2 row 0002  
Read a row of data -> 3 row 0003  
Read a row of data -> 4 row 0004  
Read a row of data -> 5 row 0005  
Calling dbsqlexec before dbnextrow returns NO_MORE_ROWS
The following command should succeed because
we have fetched the exact number of rows in the result set
	  1: select getdate()
	  1: drop procedure t0005_proc
t0005.c OK
--26537-- Discarding syms at 0x7e4a710-0x7e4c25b in /usr/lib/x86_64-linux-gnu/gconv/UTF-16.so due to munmap()
--26537-- Discarding syms at 0x7c47600-0x7c48292 in /usr/lib/x86_64-linux-gnu/gconv/ISO8859-1.so due to munmap()
--26537-- Discarding syms at 0x74062a0-0x740c1ac in /lib/x86_64-linux-gnu/libnss_compat-2.27.so due to munmap()
--26537-- Discarding syms at 0x7611070-0x76180d9 in /lib/x86_64-linux-gnu/libnss_nis-2.27.so due to munmap()
--26537-- Discarding syms at 0x781f090-0x782c8a7 in /lib/x86_64-linux-gnu/libnsl-2.27.so due to munmap()
--26537-- Discarding syms at 0x7a37350-0x7a3dd8f in /lib/x86_64-linux-gnu/libnss_files-2.27.so due to munmap()
==26537== 
==26537== HEAP SUMMARY:
==26537==     in use at exit: 0 bytes in 0 blocks
==26537==   total heap usage: 685 allocs, 685 frees, 1,394,630 bytes allocated
==26537== 
==26537== All heap blocks were freed -- no leaks are possible
==26537== 
==26537== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
==26537== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)

Main