2 * Copyright 2002 Andriy Palamarchuk
4 * Conformance test of the network buffer function.
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
23 #include "wine/test.h"
32 static NET_API_STATUS (WINAPI *pNetApiBufferAllocate)(DWORD,LPVOID*)=NULL;
33 static NET_API_STATUS (WINAPI *pNetApiBufferFree)(LPVOID)=NULL;
34 static NET_API_STATUS (WINAPI *pNetApiBufferReallocate)(LPVOID,DWORD,LPVOID*)=NULL;
35 static NET_API_STATUS (WINAPI *pNetApiBufferSize)(LPVOID,LPDWORD)=NULL;
38 static void run_apibuf_tests(void)
44 /* test normal logic */
45 ok(pNetApiBufferAllocate(1024, &p) == NERR_Success,
47 ok(pNetApiBufferSize(p, &dwSize) == NERR_Success, "Got size\n");
48 ok(dwSize >= 1024, "The size is correct\n");
50 ok(pNetApiBufferReallocate(p, 1500, &p) == NERR_Success,
52 ok(pNetApiBufferSize(p, &dwSize) == NERR_Success, "Got size\n");
53 ok(dwSize >= 1500, "The size is correct\n");
55 ok(pNetApiBufferFree(p) == NERR_Success, "Freed\n");
57 ok(pNetApiBufferSize(p, &dwSize) == NERR_Success, "Got size\n");
58 ok(pNetApiBufferSize(NULL, &dwSize) == ERROR_INVALID_PARAMETER, "Error for NULL pointer\n");
60 /* border reallocate cases */
61 ok(pNetApiBufferReallocate(0, 1500, &p) == NERR_Success, "Reallocate with OldBuffer = NULL failed\n");
62 ok(p != NULL, "No memory got allocated\n");
63 ok(pNetApiBufferAllocate(1024, &p) == NERR_Success, "Memory not reserved\n");
64 ok(pNetApiBufferReallocate(p, 0, &p) == NERR_Success, "Not freed\n");
65 ok(p == NULL, "Pointer not cleared\n");
68 ok(pNetApiBufferAllocate(0, &p) == NERR_Success,
70 ok(pNetApiBufferSize(p, &dwSize) == NERR_Success, "Got size\n");
71 ok(dwSize < 0xFFFFFFFF, "The size of the 0-length buffer\n");
72 ok(pNetApiBufferFree(p) == NERR_Success, "Freed\n");
75 /* NT: ERROR_INVALID_PARAMETER, lasterror is untouched) */
76 SetLastError(0xdeadbeef);
77 res = pNetApiBufferAllocate(0, NULL);
78 ok( (res == ERROR_INVALID_PARAMETER) && (GetLastError() == 0xdeadbeef),
79 "returned %d with 0x%x (expected ERROR_INVALID_PARAMETER with "
80 "0xdeadbeef)\n", res, GetLastError());
82 SetLastError(0xdeadbeef);
83 res = pNetApiBufferAllocate(1024, NULL);
84 ok( (res == ERROR_INVALID_PARAMETER) && (GetLastError() == 0xdeadbeef),
85 "returned %d with 0x%x (expected ERROR_INVALID_PARAMETER with "
86 "0xdeadbeef)\n", res, GetLastError());
91 HMODULE hnetapi32=LoadLibraryA("netapi32.dll");
93 pNetApiBufferAllocate=(void*)GetProcAddress(hnetapi32,"NetApiBufferAllocate");
94 pNetApiBufferFree=(void*)GetProcAddress(hnetapi32,"NetApiBufferFree");
95 pNetApiBufferReallocate=(void*)GetProcAddress(hnetapi32,"NetApiBufferReallocate");
96 pNetApiBufferSize=(void*)GetProcAddress(hnetapi32,"NetApiBufferSize");
98 if (pNetApiBufferAllocate && pNetApiBufferFree && pNetApiBufferReallocate && pNetApiBufferSize)
101 win_skip("Needed functions are not available\n");
103 FreeLibrary(hnetapi32);