[BCRYPT_WINETEST]
authorAmine Khaldi <amine.khaldi@reactos.org>
Tue, 22 Apr 2014 11:36:32 +0000 (11:36 +0000)
committerAmine Khaldi <amine.khaldi@reactos.org>
Tue, 22 Apr 2014 11:36:32 +0000 (11:36 +0000)
* Import from Wine 1.7.17.
CORE-8080

svn path=/trunk/; revision=62873

rostests/winetests/CMakeLists.txt
rostests/winetests/bcrypt/CMakeLists.txt [new file with mode: 0644]
rostests/winetests/bcrypt/bcrypt.c [new file with mode: 0644]
rostests/winetests/bcrypt/testlist.c [new file with mode: 0644]

index 0f9d2ec..f6ad832 100644 (file)
@@ -8,6 +8,7 @@ add_subdirectory(atl)
 add_subdirectory(atl100)
 add_subdirectory(atl80)
 add_subdirectory(avifil32)
+add_subdirectory(bcrypt)
 add_subdirectory(browseui)
 add_subdirectory(cabinet)
 add_subdirectory(cmd)
diff --git a/rostests/winetests/bcrypt/CMakeLists.txt b/rostests/winetests/bcrypt/CMakeLists.txt
new file mode 100644 (file)
index 0000000..8c7262f
--- /dev/null
@@ -0,0 +1,5 @@
+
+add_executable(bcrypt_winetest bcrypt.c testlist.c)
+set_module_type(bcrypt_winetest win32cui)
+add_importlibs(bcrypt_winetest user32 msvcrt kernel32)
+add_cd_file(TARGET bcrypt_winetest DESTINATION reactos/bin FOR all)
diff --git a/rostests/winetests/bcrypt/bcrypt.c b/rostests/winetests/bcrypt/bcrypt.c
new file mode 100644 (file)
index 0000000..288e745
--- /dev/null
@@ -0,0 +1,87 @@
+/*
+ * Unit test for bcrypt functions
+ *
+ * Copyright 2014 Bruno Jesus
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include <ntstatus.h>
+#define WIN32_NO_STATUS
+#include <windows.h>
+#include <bcrypt.h>
+
+#include "wine/test.h"
+
+static NTSTATUS (WINAPI *pBCryptGenRandom)(BCRYPT_ALG_HANDLE hAlgorithm, PUCHAR pbBuffer,
+                                           ULONG cbBuffer, ULONG dwFlags);
+
+static BOOL Init(void)
+{
+    HMODULE hbcrypt = LoadLibraryA("bcrypt.dll");
+    if (!hbcrypt)
+    {
+        win_skip("bcrypt library not available\n");
+        return FALSE;
+    }
+
+    pBCryptGenRandom = (void *)GetProcAddress(hbcrypt, "BCryptGenRandom");
+
+    return TRUE;
+}
+
+static void test_BCryptGenRandom(void)
+{
+    NTSTATUS ret;
+    UCHAR buffer[256];
+
+    if (!pBCryptGenRandom)
+    {
+        win_skip("BCryptGenRandom is not available\n");
+        return;
+    }
+
+    ret = pBCryptGenRandom(NULL, NULL, 0, 0);
+    ok(ret == STATUS_INVALID_HANDLE, "Expected STATUS_INVALID_HANDLE, got 0x%x\n", ret);
+    ret = pBCryptGenRandom(NULL, buffer, 0, 0);
+    ok(ret == STATUS_INVALID_HANDLE, "Expected STATUS_INVALID_HANDLE, got 0x%x\n", ret);
+    ret = pBCryptGenRandom(NULL, buffer, sizeof(buffer), 0);
+    ok(ret == STATUS_INVALID_HANDLE, "Expected STATUS_INVALID_HANDLE, got 0x%x\n", ret);
+    ret = pBCryptGenRandom(NULL, buffer, sizeof(buffer), BCRYPT_USE_SYSTEM_PREFERRED_RNG);
+    ok(ret == STATUS_SUCCESS, "Expected success, got 0x%x\n", ret);
+    ret = pBCryptGenRandom(NULL, buffer, sizeof(buffer),
+          BCRYPT_USE_SYSTEM_PREFERRED_RNG|BCRYPT_RNG_USE_ENTROPY_IN_BUFFER);
+    ok(ret == STATUS_SUCCESS, "Expected success, got 0x%x\n", ret);
+    ret = pBCryptGenRandom(NULL, NULL, sizeof(buffer), BCRYPT_USE_SYSTEM_PREFERRED_RNG);
+    ok(ret == STATUS_INVALID_PARAMETER, "Expected STATUS_INVALID_PARAMETER, got 0x%x\n", ret);
+
+    /* Zero sized buffer should work too */
+    ret = pBCryptGenRandom(NULL, buffer, 0, BCRYPT_USE_SYSTEM_PREFERRED_RNG);
+    ok(ret == STATUS_SUCCESS, "Expected success, got 0x%x\n", ret);
+
+    /* Test random number generation - It's impossible for a sane RNG to return 8 zeros */
+    memset(buffer, 0, 16);
+    ret = pBCryptGenRandom(NULL, buffer, 8, BCRYPT_USE_SYSTEM_PREFERRED_RNG);
+    ok(ret == STATUS_SUCCESS, "Expected success, got 0x%x\n", ret);
+    ok(memcmp(buffer, buffer + 8, 8), "Expected a random number, got 0\n");
+}
+
+START_TEST(bcrypt)
+{
+    if (!Init())
+        return;
+
+    test_BCryptGenRandom();
+}
diff --git a/rostests/winetests/bcrypt/testlist.c b/rostests/winetests/bcrypt/testlist.c
new file mode 100644 (file)
index 0000000..7f0af3b
--- /dev/null
@@ -0,0 +1,12 @@
+/* Automatically generated; DO NOT EDIT!! */
+
+#define STANDALONE
+#include <wine/test.h>
+
+extern void func_bcrypt(void);
+
+const struct test winetest_testlist[] =
+{
+    { "bcrypt", func_bcrypt },
+    { 0, 0 }
+};