mirror of
https://github.com/reactos/reactos.git
synced 2025-04-29 18:48:53 +00:00
[SHELL32_APITEST] Improve FindExecutable testcase (#6583)
Make shell32:FindExecutable testcase stable and trustworthy. JIRA issue: ROSTESTS-389 - Reduce dependency with sub-program (instead use copy of notepad.exe). - Simplify.
This commit is contained in:
parent
e1d334794a
commit
0709dff84c
1 changed files with 7 additions and 39 deletions
|
@ -8,30 +8,6 @@
|
||||||
#include "shelltest.h"
|
#include "shelltest.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <shlwapi.h>
|
#include <shlwapi.h>
|
||||||
#include "shell32_apitest_sub.h"
|
|
||||||
|
|
||||||
static char s_sub_program[MAX_PATH];
|
|
||||||
|
|
||||||
static BOOL
|
|
||||||
GetSubProgramPath(void)
|
|
||||||
{
|
|
||||||
GetModuleFileNameA(NULL, s_sub_program, _countof(s_sub_program));
|
|
||||||
PathRemoveFileSpecA(s_sub_program);
|
|
||||||
PathAppendA(s_sub_program, "shell32_apitest_sub.exe");
|
|
||||||
|
|
||||||
if (!PathFileExistsA(s_sub_program))
|
|
||||||
{
|
|
||||||
PathRemoveFileSpecA(s_sub_program);
|
|
||||||
PathAppendA(s_sub_program, "testdata\\shell32_apitest_sub.exe");
|
|
||||||
|
|
||||||
if (!PathFileExistsA(s_sub_program))
|
|
||||||
{
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef struct TEST_ENTRY
|
typedef struct TEST_ENTRY
|
||||||
{
|
{
|
||||||
|
@ -170,11 +146,6 @@ static const TEST_ENTRY s_entries[] =
|
||||||
{ __LINE__, TRUE, "\"test program.bat\"", DIR_2, s_sys_bat_file },
|
{ __LINE__, TRUE, "\"test program.bat\"", DIR_2, s_sys_bat_file },
|
||||||
{ __LINE__, TRUE, "\"test program.bat\"", DIR_3, s_win_bat_file },
|
{ __LINE__, TRUE, "\"test program.bat\"", DIR_3, s_win_bat_file },
|
||||||
{ __LINE__, TRUE, "\"test program.bat\"", DIR_4, s_sys_bat_file },
|
{ __LINE__, TRUE, "\"test program.bat\"", DIR_4, s_sys_bat_file },
|
||||||
{ __LINE__, TRUE, "shell32_apitest_sub.exe", DIR_0, s_sub_program },
|
|
||||||
{ __LINE__, TRUE, "shell32_apitest_sub.exe", DIR_1, "shell32_apitest_sub.exe" },
|
|
||||||
{ __LINE__, FALSE, "shell32_apitest_sub.exe", DIR_2, "" },
|
|
||||||
{ __LINE__, FALSE, "shell32_apitest_sub.exe", DIR_3, "" },
|
|
||||||
{ __LINE__, FALSE, "shell32_apitest_sub.exe", DIR_4, "" },
|
|
||||||
{ __LINE__, TRUE, "test file.txt", DIR_0, s_sys_notepad },
|
{ __LINE__, TRUE, "test file.txt", DIR_0, s_sys_notepad },
|
||||||
{ __LINE__, TRUE, "test file.txt", DIR_1, s_sys_notepad },
|
{ __LINE__, TRUE, "test file.txt", DIR_1, s_sys_notepad },
|
||||||
{ __LINE__, TRUE, "test file.txt", DIR_2, s_sys_notepad },
|
{ __LINE__, TRUE, "test file.txt", DIR_2, s_sys_notepad },
|
||||||
|
@ -203,12 +174,6 @@ static void DoTestEntry(const TEST_ENTRY *pEntry)
|
||||||
|
|
||||||
START_TEST(FindExecutable)
|
START_TEST(FindExecutable)
|
||||||
{
|
{
|
||||||
if (!GetSubProgramPath())
|
|
||||||
{
|
|
||||||
skip("shell32_apitest_sub.exe not found\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
char cur_dir[MAX_PATH];
|
char cur_dir[MAX_PATH];
|
||||||
GetCurrentDirectoryA(_countof(cur_dir), cur_dir);
|
GetCurrentDirectoryA(_countof(cur_dir), cur_dir);
|
||||||
if (PathIsRootA(cur_dir))
|
if (PathIsRootA(cur_dir))
|
||||||
|
@ -227,7 +192,7 @@ START_TEST(FindExecutable)
|
||||||
|
|
||||||
GetWindowsDirectoryA(s_win_test_exe, _countof(s_win_test_exe));
|
GetWindowsDirectoryA(s_win_test_exe, _countof(s_win_test_exe));
|
||||||
PathAppendA(s_win_test_exe, "test program.exe");
|
PathAppendA(s_win_test_exe, "test program.exe");
|
||||||
BOOL ret = CopyFileA(s_sub_program, s_win_test_exe, FALSE);
|
BOOL ret = CopyFileA(s_win_notepad, s_win_test_exe, FALSE);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
{
|
{
|
||||||
skip("Please retry with admin rights\n");
|
skip("Please retry with admin rights\n");
|
||||||
|
@ -236,7 +201,12 @@ START_TEST(FindExecutable)
|
||||||
|
|
||||||
GetSystemDirectoryA(s_sys_test_exe, _countof(s_sys_test_exe));
|
GetSystemDirectoryA(s_sys_test_exe, _countof(s_sys_test_exe));
|
||||||
PathAppendA(s_sys_test_exe, "test program.exe");
|
PathAppendA(s_sys_test_exe, "test program.exe");
|
||||||
ok_int(CopyFileA(s_sub_program, s_sys_test_exe, FALSE), TRUE);
|
ret = CopyFileA(s_win_notepad, s_sys_test_exe, FALSE);
|
||||||
|
if (!ret)
|
||||||
|
{
|
||||||
|
skip("Please retry with admin rights\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
GetWindowsDirectoryA(s_win_bat_file, _countof(s_win_bat_file));
|
GetWindowsDirectoryA(s_win_bat_file, _countof(s_win_bat_file));
|
||||||
PathAppendA(s_win_bat_file, "test program.bat");
|
PathAppendA(s_win_bat_file, "test program.bat");
|
||||||
|
@ -269,6 +239,4 @@ START_TEST(FindExecutable)
|
||||||
DeleteFileA(s_sys_bat_file);
|
DeleteFileA(s_sys_bat_file);
|
||||||
DeleteFileA(s_win_txt_file);
|
DeleteFileA(s_win_txt_file);
|
||||||
DeleteFileA(s_sys_txt_file);
|
DeleteFileA(s_sys_txt_file);
|
||||||
|
|
||||||
DoWaitForWindow(CLASSNAME, CLASSNAME, TRUE, TRUE);
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue