msi: Add tests for the InstallServices action.
This commit is contained in:
parent
39c4bbe56a
commit
d6632dd0fb
|
@ -72,7 +72,8 @@ static const CHAR component_dat[] = "Component\tComponentId\tDirectory_\tAttribu
|
|||
"Three\t{010B6ADD-B27D-4EDD-9B3D-34C4F7D61684}\tCHANGEDDIR\t2\t\tthree.txt\n"
|
||||
"Two\t{BF03D1A6-20DA-4A65-82F3-6CAC995915CE}\tFIRSTDIR\t2\t\ttwo.txt\n"
|
||||
"dangler\t{6091DF25-EF96-45F1-B8E9-A9B1420C7A3C}\tTARGETDIR\t4\t\tregdata\n"
|
||||
"component\t\tTARGETDIR\t0\t1\tfile";
|
||||
"component\t\tMSITESTDIR\t0\t1\tfile\n"
|
||||
"service_comp\t\tMSITESTDIR\t0\t1\tservice_file";
|
||||
|
||||
static const CHAR directory_dat[] = "Directory\tDirectory_Parent\tDefaultDir\n"
|
||||
"s72\tS72\tl255\n"
|
||||
|
@ -93,7 +94,8 @@ static const CHAR feature_dat[] = "Feature\tFeature_Parent\tTitle\tDescription\t
|
|||
"One\t\tOne\tThe One Feature\t1\t3\tMSITESTDIR\t0\n"
|
||||
"Three\t\tThree\tThe Three Feature\t3\t3\tCHANGEDDIR\t0\n"
|
||||
"Two\t\tTwo\tThe Two Feature\t2\t3\tFIRSTDIR\t0\n"
|
||||
"feature\t\t\t\t2\t1\tTARGETDIR\t0";
|
||||
"feature\t\t\t\t2\t1\tTARGETDIR\t0\n"
|
||||
"service_feature\t\t\t\t2\t1\tTARGETDIR\t0";
|
||||
|
||||
static const CHAR feature_comp_dat[] = "Feature_\tComponent_\n"
|
||||
"s38\ts72\n"
|
||||
|
@ -103,7 +105,8 @@ static const CHAR feature_comp_dat[] = "Feature_\tComponent_\n"
|
|||
"One\tOne\n"
|
||||
"Three\tThree\n"
|
||||
"Two\tTwo\n"
|
||||
"feature\tcomponent";
|
||||
"feature\tcomponent\n"
|
||||
"service_feature\tservice_comp\n";
|
||||
|
||||
static const CHAR file_dat[] = "File\tComponent_\tFileName\tFileSize\tVersion\tLanguage\tAttributes\tSequence\n"
|
||||
"s72\ts72\tl255\ti4\tS72\tS20\tI2\ti2\n"
|
||||
|
@ -113,7 +116,8 @@ static const CHAR file_dat[] = "File\tComponent_\tFileName\tFileSize\tVersion\tL
|
|||
"one.txt\tOne\tone.txt\t1000\t\t\t0\t1\n"
|
||||
"three.txt\tThree\tthree.txt\t1000\t\t\t0\t3\n"
|
||||
"two.txt\tTwo\ttwo.txt\t1000\t\t\t0\t2\n"
|
||||
"file\tcomponent\tfilename\t100\t\t\t8192\t1";
|
||||
"file\tcomponent\tfilename\t100\t\t\t8192\t1\n"
|
||||
"service_file\tservice_comp\tservice.exe\t100\t\t\t8192\t1";
|
||||
|
||||
static const CHAR install_exec_seq_dat[] = "Action\tCondition\tSequence\n"
|
||||
"s72\tS255\tI2\n"
|
||||
|
@ -123,6 +127,7 @@ static const CHAR install_exec_seq_dat[] = "Action\tCondition\tSequence\n"
|
|||
"CostInitialize\t\t800\n"
|
||||
"FileCost\t\t900\n"
|
||||
"InstallFiles\t\t4000\n"
|
||||
"InstallServices\t\t5000\n"
|
||||
"InstallFinalize\t\t6600\n"
|
||||
"InstallInitialize\t\t1500\n"
|
||||
"InstallValidate\t\t1400\n"
|
||||
|
@ -160,6 +165,17 @@ static const CHAR registry_dat[] = "Registry\tRoot\tKey\tName\tValue\tComponent_
|
|||
"regdata\t2\tSOFTWARE\\Wine\\msitest\tblah\tbad\tdangler\n"
|
||||
"OrderTest\t2\tSOFTWARE\\Wine\\msitest\tOrderTestName\tOrderTestValue\tcomponent";
|
||||
|
||||
static const CHAR service_install_dat[] = "ServiceInstall\tName\tDisplayName\tServiceType\tStartType\tErrorControl\t"
|
||||
"LoadOrderGroup\tDependencies\tStartName\tPassword\tArguments\tComponent_\tDescription\n"
|
||||
"s72\ts255\tL255\ti4\ti4\ti4\tS255\tS255\tS255\tS255\tS255\ts72\tL255\n"
|
||||
"ServiceInstall\tServiceInstall\n"
|
||||
"TestService\tTestService\tTestService\t2\t3\t0\t\t\tTestService\t\t\tservice_comp\t\t";
|
||||
|
||||
static const CHAR service_control_dat[] = "ServiceControl\tName\tEvent\tArguments\tWait\tComponent_\n"
|
||||
"s72\tl255\ti2\tL255\tI2\ts72\n"
|
||||
"ServiceControl\tServiceControl\n"
|
||||
"ServiceControl\tTestService\t8\t\t0\tservice_comp";
|
||||
|
||||
typedef struct _msi_table
|
||||
{
|
||||
const CHAR *filename;
|
||||
|
@ -181,7 +197,9 @@ static const msi_table tables[] =
|
|||
ADD_TABLE(install_exec_seq),
|
||||
ADD_TABLE(media),
|
||||
ADD_TABLE(property),
|
||||
ADD_TABLE(registry)
|
||||
ADD_TABLE(registry),
|
||||
ADD_TABLE(service_install),
|
||||
ADD_TABLE(service_control)
|
||||
};
|
||||
|
||||
/* cabinet definitions */
|
||||
|
@ -491,7 +509,8 @@ static void create_test_files(void)
|
|||
create_file("five.txt");
|
||||
create_cab_file("msitest.cab");
|
||||
|
||||
create_file("filename");
|
||||
create_file("msitest\\filename");
|
||||
create_file("msitest\\service.exe");
|
||||
|
||||
DeleteFileA("four.txt");
|
||||
DeleteFileA("five.txt");
|
||||
|
@ -513,12 +532,13 @@ static BOOL delete_pf(const CHAR *rel_path, BOOL is_file)
|
|||
|
||||
static void delete_test_files(void)
|
||||
{
|
||||
DeleteFileA("filename");
|
||||
DeleteFileA("msitest.msi");
|
||||
DeleteFileA("msitest.cab");
|
||||
DeleteFileA("msitest\\second\\three.txt");
|
||||
DeleteFileA("msitest\\first\\two.txt");
|
||||
DeleteFileA("msitest\\one.txt");
|
||||
DeleteFileA("msitest\\service.exe");
|
||||
DeleteFileA("msitest\\filename");
|
||||
RemoveDirectoryA("msitest\\second");
|
||||
RemoveDirectoryA("msitest\\first");
|
||||
RemoveDirectoryA("msitest");
|
||||
|
@ -593,6 +613,27 @@ static void create_database(const CHAR *name, const msi_table *tables, int num_t
|
|||
MsiCloseHandle(db);
|
||||
}
|
||||
|
||||
static void check_service_is_installed(void)
|
||||
{
|
||||
SC_HANDLE scm, service;
|
||||
BOOL res;
|
||||
|
||||
scm = OpenSCManager(NULL, NULL, SC_MANAGER_ALL_ACCESS);
|
||||
ok(scm != NULL, "Failed to open the SC Manager\n");
|
||||
|
||||
service = OpenService(scm, "TestService", SC_MANAGER_ALL_ACCESS);
|
||||
todo_wine
|
||||
{
|
||||
ok(service != NULL, "Failed to open TestService\n");
|
||||
}
|
||||
|
||||
res = DeleteService(service);
|
||||
todo_wine
|
||||
{
|
||||
ok(res, "Failed to delete TestService\n");
|
||||
}
|
||||
}
|
||||
|
||||
static void test_MsiInstallProduct(void)
|
||||
{
|
||||
UINT r;
|
||||
|
@ -618,6 +659,8 @@ static void test_MsiInstallProduct(void)
|
|||
ok(delete_pf("msitest\\first\\two.txt", TRUE), "File not installed\n");
|
||||
ok(delete_pf("msitest\\first", FALSE), "File not installed\n");
|
||||
ok(delete_pf("msitest\\one.txt", TRUE), "File not installed\n");
|
||||
ok(delete_pf("msitest\\filename", TRUE), "File not installed\n");
|
||||
ok(delete_pf("msitest\\service.exe", TRUE), "File not installed\n");
|
||||
ok(delete_pf("msitest", FALSE), "File not installed\n");
|
||||
}
|
||||
|
||||
|
@ -650,6 +693,7 @@ static void test_MsiInstallProduct(void)
|
|||
ok(res == ERROR_SUCCESS, "Expected ERROR_SUCCESS, got %d\n", res);
|
||||
ok(!lstrcmpA(path, "OrderTestValue"), "Expected imaname, got %s\n", path);
|
||||
|
||||
check_service_is_installed();
|
||||
|
||||
RegDeleteKeyA(HKEY_LOCAL_MACHINE, "SOFTWARE\\Wine\\msitest");
|
||||
|
||||
|
|
Loading…
Reference in New Issue