summaryrefslogtreecommitdiffstats
path: root/winpr/libwinpr/dsparse/test
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 01:24:41 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-04 01:24:41 +0000
commita9bcc81f821d7c66f623779fa5147e728eb3c388 (patch)
tree98676963bcdd537ae5908a067a8eb110b93486a6 /winpr/libwinpr/dsparse/test
parentInitial commit. (diff)
downloadfreerdp3-a9bcc81f821d7c66f623779fa5147e728eb3c388.tar.xz
freerdp3-a9bcc81f821d7c66f623779fa5147e728eb3c388.zip
Adding upstream version 3.3.0+dfsg1.upstream/3.3.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'winpr/libwinpr/dsparse/test')
-rw-r--r--winpr/libwinpr/dsparse/test/CMakeLists.txt25
-rw-r--r--winpr/libwinpr/dsparse/test/TestDsMakeSpn.c151
2 files changed, 176 insertions, 0 deletions
diff --git a/winpr/libwinpr/dsparse/test/CMakeLists.txt b/winpr/libwinpr/dsparse/test/CMakeLists.txt
new file mode 100644
index 0000000..d2b5ea4
--- /dev/null
+++ b/winpr/libwinpr/dsparse/test/CMakeLists.txt
@@ -0,0 +1,25 @@
+
+set(MODULE_NAME "TestDsParse")
+set(MODULE_PREFIX "TEST_DSPARSE")
+
+set(${MODULE_PREFIX}_DRIVER ${MODULE_NAME}.c)
+
+set(${MODULE_PREFIX}_TESTS
+ TestDsMakeSpn.c)
+
+create_test_sourcelist(${MODULE_PREFIX}_SRCS
+ ${${MODULE_PREFIX}_DRIVER}
+ ${${MODULE_PREFIX}_TESTS})
+
+add_executable(${MODULE_NAME} ${${MODULE_PREFIX}_SRCS})
+
+target_link_libraries(${MODULE_NAME} winpr)
+
+set_target_properties(${MODULE_NAME} PROPERTIES RUNTIME_OUTPUT_DIRECTORY "${TESTING_OUTPUT_DIRECTORY}")
+
+foreach(test ${${MODULE_PREFIX}_TESTS})
+ get_filename_component(TestName ${test} NAME_WE)
+ add_test(${TestName} ${TESTING_OUTPUT_DIRECTORY}/${MODULE_NAME} ${TestName})
+endforeach()
+
+set_property(TARGET ${MODULE_NAME} PROPERTY FOLDER "WinPR/Test")
diff --git a/winpr/libwinpr/dsparse/test/TestDsMakeSpn.c b/winpr/libwinpr/dsparse/test/TestDsMakeSpn.c
new file mode 100644
index 0000000..dcaf635
--- /dev/null
+++ b/winpr/libwinpr/dsparse/test/TestDsMakeSpn.c
@@ -0,0 +1,151 @@
+
+#include <stdio.h>
+#include <winpr/crt.h>
+#include <winpr/winpr.h>
+#include <winpr/tchar.h>
+#include <winpr/dsparse.h>
+
+static BOOL test_DsMakeSpnA(void)
+{
+ LPCSTR testServiceClass = "HTTP";
+ LPCSTR testServiceName = "LAB1-W2K8R2-GW.lab1.awake.local";
+ LPCSTR testSpn = "HTTP/LAB1-W2K8R2-GW.lab1.awake.local";
+ BOOL rc = FALSE;
+ CHAR Spn[100] = { 0 };
+ DWORD status = 0;
+ DWORD SpnLength = -1;
+
+ status = DsMakeSpnA(testServiceClass, testServiceName, NULL, 0, NULL, &SpnLength, NULL);
+
+ if (status != ERROR_INVALID_PARAMETER)
+ {
+ printf("DsMakeSpnA: expected ERROR_INVALID_PARAMETER\n");
+ goto fail;
+ }
+
+ SpnLength = 0;
+ status = DsMakeSpnA(testServiceClass, testServiceName, NULL, 0, NULL, &SpnLength, NULL);
+
+ if (status != ERROR_BUFFER_OVERFLOW)
+ {
+ printf("DsMakeSpnA: expected ERROR_BUFFER_OVERFLOW\n");
+ goto fail;
+ }
+
+ if (SpnLength != 37)
+ {
+ printf("DsMakeSpnA: SpnLength mismatch: Actual: %" PRIu32 ", Expected: 37\n", SpnLength);
+ goto fail;
+ }
+
+ status = DsMakeSpnA(testServiceClass, testServiceName, NULL, 0, NULL, &SpnLength, Spn);
+
+ if (status != ERROR_SUCCESS)
+ {
+ printf("DsMakeSpnA: expected ERROR_SUCCESS\n");
+ goto fail;
+ }
+
+ if (strcmp(Spn, testSpn) != 0)
+ {
+ printf("DsMakeSpnA: SPN mismatch: Actual: %s, Expected: %s\n", Spn, testSpn);
+ goto fail;
+ }
+
+ printf("DsMakeSpnA: %s\n", Spn);
+ rc = TRUE;
+fail:
+ return rc;
+}
+
+static BOOL test_DsMakeSpnW(void)
+{
+ const CHAR ctestServiceClass[] = { 'H', 'T', 'T', 'P', '\0' };
+ const CHAR ctestServiceName[] = { 'L', 'A', 'B', '1', '-', 'W', '2', 'K', '8', 'R', '2',
+ '-', 'G', 'W', '.', 'l', 'a', 'b', '1', '.', 'a', 'w',
+ 'a', 'k', 'e', '.', 'l', 'o', 'c', 'a', 'l', '\0' };
+ const CHAR ctestSpn[] = { 'H', 'T', 'T', 'P', '/', 'L', 'A', 'B', '1', '-', 'W', '2', 'K',
+ '8', 'R', '2', '-', 'G', 'W', '.', 'l', 'a', 'b', '1', '.', 'a',
+ 'w', 'a', 'k', 'e', '.', 'l', 'o', 'c', 'a', 'l', '\0' };
+ WCHAR testServiceClass[ARRAYSIZE(ctestServiceClass)] = { 0 };
+ WCHAR testServiceName[ARRAYSIZE(ctestServiceName)] = { 0 };
+ WCHAR testSpn[ARRAYSIZE(ctestSpn)] = { 0 };
+
+ BOOL rc = FALSE;
+ WCHAR Spn[100] = { 0 };
+ DWORD status = 0;
+ DWORD SpnLength = -1;
+
+ ConvertUtf8NToWChar(ctestServiceClass, ARRAYSIZE(ctestServiceClass), testServiceClass,
+ ARRAYSIZE(testServiceClass));
+ ConvertUtf8NToWChar(ctestServiceName, ARRAYSIZE(ctestServiceName), testServiceName,
+ ARRAYSIZE(testServiceName));
+ ConvertUtf8NToWChar(ctestSpn, ARRAYSIZE(ctestSpn), testSpn, ARRAYSIZE(testSpn));
+
+ status = DsMakeSpnW(testServiceClass, testServiceName, NULL, 0, NULL, &SpnLength, NULL);
+
+ if (status != ERROR_INVALID_PARAMETER)
+ {
+ printf("DsMakeSpnW: expected ERROR_INVALID_PARAMETER\n");
+ goto fail;
+ }
+
+ SpnLength = 0;
+ status = DsMakeSpnW(testServiceClass, testServiceName, NULL, 0, NULL, &SpnLength, NULL);
+
+ if (status != ERROR_BUFFER_OVERFLOW)
+ {
+ printf("DsMakeSpnW: expected ERROR_BUFFER_OVERFLOW\n");
+ goto fail;
+ }
+
+ if (SpnLength != 37)
+ {
+ printf("DsMakeSpnW: SpnLength mismatch: Actual: %" PRIu32 ", Expected: 37\n", SpnLength);
+ goto fail;
+ }
+
+ status = DsMakeSpnW(testServiceClass, testServiceName, NULL, 0, NULL, &SpnLength, Spn);
+
+ if (status != ERROR_SUCCESS)
+ {
+ printf("DsMakeSpnW: expected ERROR_SUCCESS\n");
+ goto fail;
+ }
+
+ if (_wcscmp(Spn, testSpn) != 0)
+ {
+ char buffer1[8192] = { 0 };
+ char buffer2[8192] = { 0 };
+ char* SpnA = buffer1;
+ char* testSpnA = buffer2;
+
+ ConvertWCharToUtf8(Spn, SpnA, ARRAYSIZE(buffer1));
+ ConvertWCharToUtf8(testSpn, testSpnA, ARRAYSIZE(buffer2));
+ printf("DsMakeSpnW: SPN mismatch: Actual: %s, Expected: %s\n", SpnA, testSpnA);
+ goto fail;
+ }
+
+ {
+ char buffer[8192] = { 0 };
+ char* SpnA = buffer;
+
+ ConvertWCharToUtf8(Spn, SpnA, ARRAYSIZE(buffer));
+ printf("DsMakeSpnW: %s\n", SpnA);
+ }
+
+ rc = TRUE;
+fail:
+ return rc;
+}
+int TestDsMakeSpn(int argc, char* argv[])
+{
+ WINPR_UNUSED(argc);
+ WINPR_UNUSED(argv);
+
+ if (!test_DsMakeSpnA())
+ return -1;
+ if (!test_DsMakeSpnW())
+ return -2;
+ return 0;
+}