Blame winpr/libwinpr/path/test/TestPathCchAppend.c

Packit Service fa4841
Packit Service fa4841
#include <stdio.h>
Packit Service fa4841
#include <winpr/crt.h>
Packit Service fa4841
#include <winpr/path.h>
Packit Service fa4841
#include <winpr/tchar.h>
Packit Service fa4841
#include <winpr/winpr.h>
Packit Service fa4841
Packit Service fa4841
static const TCHAR testBasePathBackslash[] = _T("C:\\Program Files\\");
Packit Service fa4841
static const TCHAR testBasePathNoBackslash[] = _T("C:\\Program Files");
Packit Service fa4841
static const TCHAR testMorePathBackslash[] = _T("\\Microsoft Visual Studio 11.0");
Packit Service fa4841
static const TCHAR testMorePathNoBackslash[] = _T("Microsoft Visual Studio 11.0");
Packit Service fa4841
static const TCHAR testPathOut[] = _T("C:\\Program Files\\Microsoft Visual Studio 11.0");
Packit Service fa4841
Packit Service fa4841
int TestPathCchAppend(int argc, char* argv[])
Packit Service fa4841
{
Packit Service fa4841
	HRESULT status;
Packit Service fa4841
	TCHAR Path[PATHCCH_MAX_CCH];
Packit Service fa4841
	size_t i;
Packit Service fa4841
Packit Service fa4841
	/* Base Path: Backslash, More Path: No Backslash */
Packit Service fa4841
Packit Service fa4841
	_tcscpy(Path, testBasePathBackslash);
Packit Service fa4841
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathNoBackslash);
Packit Service fa4841
Packit Service fa4841
	if (status != S_OK)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend status: 0x%08") _T(PRIX32) _T("\n"), status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	if (_tcscmp(Path, testPathOut) != 0)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* Base Path: Backslash, More Path: Backslash */
Packit Service fa4841
Packit Service fa4841
	_tcscpy(Path, testBasePathBackslash);
Packit Service fa4841
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathBackslash);
Packit Service fa4841
Packit Service fa4841
	if (status != S_OK)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend status: 0x%08") _T(PRIX32) _T("\n"), status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	if (_tcscmp(Path, testPathOut) != 0)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* Base Path: No Backslash, More Path: Backslash */
Packit Service fa4841
Packit Service fa4841
	_tcscpy(Path, testBasePathNoBackslash);
Packit Service fa4841
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathBackslash);
Packit Service fa4841
Packit Service fa4841
	if (status != S_OK)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend status: 0x%08") _T(PRIX32) _T("\n"), status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	if (_tcscmp(Path, testPathOut) != 0)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* Base Path: No Backslash, More Path: No Backslash */
Packit Service fa4841
Packit Service fa4841
	_tcscpy(Path, testBasePathNoBackslash);
Packit Service fa4841
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathNoBackslash);
Packit Service fa4841
Packit Service fa4841
	if (status != S_OK)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend status: 0x%08") _T(PRIX32) _T("\n"), status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	if (_tcscmp(Path, testPathOut) != 0)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* According to msdn a NULL Path is an invalid argument */
Packit Service fa4841
	status = PathCchAppend(NULL, PATHCCH_MAX_CCH, testMorePathNoBackslash);
Packit Service fa4841
	if (status != E_INVALIDARG)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend with NULL path unexpectedly returned status: 0x%08") _T(
Packit Service fa4841
		             PRIX32) _T("\n"),
Packit Service fa4841
		         status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* According to msdn a NULL pszMore is an invalid argument (although optional !?) */
Packit Service fa4841
	_tcscpy(Path, testBasePathNoBackslash);
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH, NULL);
Packit Service fa4841
	if (status != E_INVALIDARG)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend with NULL pszMore unexpectedly returned status: 0x%08") _T(
Packit Service fa4841
		             PRIX32) _T("\n"),
Packit Service fa4841
		         status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* According to msdn cchPath must be > 0 and <= PATHCCH_MAX_CCH */
Packit Service fa4841
	_tcscpy(Path, testBasePathNoBackslash);
Packit Service fa4841
	status = PathCchAppend(Path, 0, testMorePathNoBackslash);
Packit Service fa4841
	if (status != E_INVALIDARG)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend with cchPath value 0 unexpectedly returned status: 0x%08") _T(
Packit Service fa4841
		             PRIX32) _T("\n"),
Packit Service fa4841
		         status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
	_tcscpy(Path, testBasePathNoBackslash);
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH + 1, testMorePathNoBackslash);
Packit Service fa4841
	if (status != E_INVALIDARG)
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend with cchPath value > PATHCCH_MAX_CCH unexpectedly returned ")
Packit Service fa4841
		         _T("status: 0x%08") _T(PRIX32) _T("\n"),
Packit Service fa4841
		         status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	/* Resulting file must not exceed PATHCCH_MAX_CCH */
Packit Service fa4841
Packit Service fa4841
	for (i = 0; i < PATHCCH_MAX_CCH - 1; i++)
Packit Service fa4841
		Path[i] = _T('X');
Packit Service fa4841
Packit Service fa4841
	Path[PATHCCH_MAX_CCH - 1] = 0;
Packit Service fa4841
Packit Service fa4841
	status = PathCchAppend(Path, PATHCCH_MAX_CCH, _T("\\This cannot be appended to Path"));
Packit Service fa4841
	if (SUCCEEDED(status))
Packit Service fa4841
	{
Packit Service fa4841
		_tprintf(_T("PathCchAppend unexepectedly succeeded with status: 0x%08") _T(PRIX32) _T("\n"),
Packit Service fa4841
		         status);
Packit Service fa4841
		return -1;
Packit Service fa4841
	}
Packit Service fa4841
Packit Service fa4841
	return 0;
Packit Service fa4841
}