kernel32/tests: Test for quirks in a few different time zones.
Signed-off-by: Giovanni Mascellani <gmascellani@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
4581f50819
commit
d1b80f4d63
|
@ -894,6 +894,9 @@ static WORD day_of_month(const SYSTEMTIME* systemtime, WORD year)
|
||||||
if (systemtime->wYear != 0)
|
if (systemtime->wYear != 0)
|
||||||
return systemtime->wDay;
|
return systemtime->wDay;
|
||||||
|
|
||||||
|
if (systemtime->wMonth == 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
first_of_month.wYear = year;
|
first_of_month.wYear = year;
|
||||||
first_of_month.wMonth = systemtime->wMonth;
|
first_of_month.wMonth = systemtime->wMonth;
|
||||||
first_of_month.wDay = 1;
|
first_of_month.wDay = 1;
|
||||||
|
@ -926,13 +929,37 @@ static WORD day_of_month(const SYSTEMTIME* systemtime, WORD year)
|
||||||
|
|
||||||
static void test_GetTimeZoneInformationForYear(void)
|
static void test_GetTimeZoneInformationForYear(void)
|
||||||
{
|
{
|
||||||
BOOL ret;
|
BOOL ret, broken_test = FALSE;
|
||||||
SYSTEMTIME systemtime;
|
SYSTEMTIME systemtime;
|
||||||
TIME_ZONE_INFORMATION local_tzinfo, tzinfo, tzinfo2;
|
TIME_ZONE_INFORMATION local_tzinfo, tzinfo, tzinfo2;
|
||||||
DYNAMIC_TIME_ZONE_INFORMATION dyn_tzinfo;
|
DYNAMIC_TIME_ZONE_INFORMATION dyn_tzinfo;
|
||||||
static const WCHAR std_tzname[] = {'G','r','e','e','n','l','a','n','d',' ','S','t','a','n','d','a','r','d',' ','T','i','m','e',0};
|
|
||||||
static const WCHAR dlt_tzname[] = {'G','r','e','e','n','l','a','n','d',' ','D','a','y','l','i','g','h','t',' ','T','i','m','e',0};
|
|
||||||
WORD std_day, dlt_day;
|
WORD std_day, dlt_day;
|
||||||
|
unsigned i;
|
||||||
|
static const struct
|
||||||
|
{
|
||||||
|
const WCHAR *tzname;
|
||||||
|
USHORT year;
|
||||||
|
LONG bias, std_bias, dlt_bias;
|
||||||
|
WORD std_month, std_day, dlt_month, dlt_day;
|
||||||
|
int tzinfo_todo : 1, bias_todo : 1, std_bias_todo : 1, dlt_bias_todo : 1;
|
||||||
|
int std_month_todo : 1, std_day_todo : 1, dlt_month_todo : 1, dlt_day_todo : 1;
|
||||||
|
}
|
||||||
|
test_data[] =
|
||||||
|
{
|
||||||
|
{ L"Greenland Standard Time", 2015, 180, 0, -60, 10, 24, 3, 28 },
|
||||||
|
{ L"Greenland Standard Time", 2016, 180, 0, -60, 10, 29, 3, 26 },
|
||||||
|
{ L"Greenland Standard Time", 2017, 180, 0, -60, 10, 28, 3, 25 },
|
||||||
|
{ L"Easter Island Standard Time", 2014, 360, 0, -60, 4, 26, 9, 6, 0, 1, 0, 1, 1, 1, 1, 1 },
|
||||||
|
{ L"Easter Island Standard Time", 2015, 300, 0, -60, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1 },
|
||||||
|
{ L"Easter Island Standard Time", 2016, 360, 0, -60, 5, 14, 8, 13, 0, 1, 0, 1, 1, 1, 1, 1 },
|
||||||
|
{ L"Egypt Standard Time", 2013, -120, 0, -60, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1 },
|
||||||
|
{ L"Egypt Standard Time", 2014, -120, 0, -60, 9, 25, 5, 15, 0, 0, 0, 0, 1, 1, 1, 1 },
|
||||||
|
{ L"Egypt Standard Time", 2015, -120, 0, -60, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1 },
|
||||||
|
{ L"Egypt Standard Time", 2016, -120, 0, -60, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1 },
|
||||||
|
{ L"Altai Standard Time", 2016, -420, 0, 60, 3, 27, 1, 1, 1 },
|
||||||
|
{ L"Altai Standard Time", 2017, -420, 0, -60, 0, 0, 0, 0, 1 },
|
||||||
|
{ L"Altai Standard Time", 2018, -420, 0, -60, 0, 0, 0, 0, 1 },
|
||||||
|
};
|
||||||
|
|
||||||
if (!pGetTimeZoneInformationForYear || !pGetDynamicTimeZoneInformation)
|
if (!pGetTimeZoneInformationForYear || !pGetDynamicTimeZoneInformation)
|
||||||
{
|
{
|
||||||
|
@ -971,38 +998,78 @@ static void test_GetTimeZoneInformationForYear(void)
|
||||||
ok(tzinfo.DaylightBias == local_tzinfo.DaylightBias, "Expected DaylightBias %d, got %d\n", local_tzinfo.DaylightBias, tzinfo.DaylightBias);
|
ok(tzinfo.DaylightBias == local_tzinfo.DaylightBias, "Expected DaylightBias %d, got %d\n", local_tzinfo.DaylightBias, tzinfo.DaylightBias);
|
||||||
|
|
||||||
memset(&dyn_tzinfo, 0xaa, sizeof(dyn_tzinfo));
|
memset(&dyn_tzinfo, 0xaa, sizeof(dyn_tzinfo));
|
||||||
lstrcpyW(dyn_tzinfo.TimeZoneKeyName, std_tzname);
|
lstrcpyW(dyn_tzinfo.TimeZoneKeyName, L"Greenland Daylight Time");
|
||||||
|
SetLastError(0xdeadbeef);
|
||||||
|
ret = pGetTimeZoneInformationForYear(2015, &dyn_tzinfo, &tzinfo);
|
||||||
|
if (ret)
|
||||||
|
broken_test = TRUE;
|
||||||
|
ok((ret == FALSE && GetLastError() == ERROR_FILE_NOT_FOUND) ||
|
||||||
|
broken(broken_test) /* vista,7 */,
|
||||||
|
"GetTimeZoneInformationForYear err %u\n", GetLastError());
|
||||||
|
|
||||||
|
memset(&dyn_tzinfo, 0xaa, sizeof(dyn_tzinfo));
|
||||||
|
lstrcpyW(dyn_tzinfo.TimeZoneKeyName, L"Altai Standard Time");
|
||||||
|
SetLastError(0xdeadbeef);
|
||||||
|
ret = pGetTimeZoneInformationForYear(2015, &dyn_tzinfo, &tzinfo);
|
||||||
|
if (!ret && GetLastError() == ERROR_FILE_NOT_FOUND)
|
||||||
|
broken_test = TRUE;
|
||||||
|
todo_wine ok(ret == TRUE || broken(broken_test) /* before 10 1809 */,
|
||||||
|
"GetTimeZoneInformationForYear err %u\n", GetLastError());
|
||||||
|
|
||||||
|
if (broken(broken_test))
|
||||||
|
{
|
||||||
|
win_skip("Old Windows version\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(test_data); i++)
|
||||||
|
{
|
||||||
|
memset(&dyn_tzinfo, 0xaa, sizeof(dyn_tzinfo));
|
||||||
|
memset(&tzinfo, 0xbb, sizeof(tzinfo));
|
||||||
|
lstrcpyW(dyn_tzinfo.TimeZoneKeyName, test_data[i].tzname);
|
||||||
dyn_tzinfo.DynamicDaylightTimeDisabled = FALSE;
|
dyn_tzinfo.DynamicDaylightTimeDisabled = FALSE;
|
||||||
|
|
||||||
ret = pGetTimeZoneInformationForYear(2015, &dyn_tzinfo, &tzinfo);
|
ret = pGetTimeZoneInformationForYear(test_data[i].year, &dyn_tzinfo, &tzinfo);
|
||||||
ok(ret == TRUE, "GetTimeZoneInformationForYear failed, err %u\n", GetLastError());
|
todo_wine_if(test_data[i].tzinfo_todo)
|
||||||
ok(tzinfo.Bias == 180, "Expected Bias 180, got %d\n", tzinfo.Bias);
|
ok(ret == TRUE, "GetTimeZoneInformationForYear failed, err %u, for %s\n", GetLastError(), wine_dbgstr_w(test_data[i].tzname));
|
||||||
ok(tzinfo.StandardDate.wMonth == 10, "Expected standard month 10, got %d\n", tzinfo.StandardDate.wMonth);
|
if (!ret)
|
||||||
std_day = day_of_month(&tzinfo.StandardDate, 2015);
|
continue;
|
||||||
ok(std_day == 24, "Expected standard day 24, got %d\n", std_day);
|
todo_wine_if(test_data[i].bias_todo)
|
||||||
ok(tzinfo.StandardBias == 0, "Expected StandardBias 0, got %d\n", tzinfo.StandardBias);
|
ok(tzinfo.Bias == test_data[i].bias, "Expected bias %d, got %d, for %s\n",
|
||||||
ok(tzinfo.DaylightDate.wMonth == 3, "Expected daylight month 3, got %d\n", tzinfo.DaylightDate.wMonth);
|
test_data[i].bias, tzinfo.Bias, wine_dbgstr_w(test_data[i].tzname));
|
||||||
dlt_day = day_of_month(&tzinfo.DaylightDate, 2015);
|
todo_wine_if(test_data[i].std_month_todo)
|
||||||
ok(dlt_day == 28, "Expected daylight day 28, got %d\n", dlt_day);
|
ok(tzinfo.StandardDate.wMonth == test_data[i].std_month, "Expected standard month %d, got %d, for %s\n",
|
||||||
ok(tzinfo.DaylightBias == -60, "Expected DaylightBias -60, got %d\n", tzinfo.DaylightBias);
|
test_data[i].std_month, tzinfo.StandardDate.wMonth, wine_dbgstr_w(test_data[i].tzname));
|
||||||
|
std_day = day_of_month(&tzinfo.StandardDate, test_data[i].year);
|
||||||
|
todo_wine_if(test_data[i].std_day_todo)
|
||||||
|
ok(std_day == test_data[i].std_day, "Expected standard day %d, got %d, for %s\n",
|
||||||
|
test_data[i].std_day, std_day, wine_dbgstr_w(test_data[i].tzname));
|
||||||
|
todo_wine_if(test_data[i].std_bias_todo)
|
||||||
|
ok(tzinfo.StandardBias == test_data[i].std_bias, "Expected standard bias %d, got %d, for %s\n",
|
||||||
|
test_data[i].std_bias, tzinfo.StandardBias, wine_dbgstr_w(test_data[i].tzname));
|
||||||
|
todo_wine_if(test_data[i].dlt_month_todo)
|
||||||
|
ok(tzinfo.DaylightDate.wMonth == test_data[i].dlt_month, "Expected daylight month %d, got %d, for %s\n",
|
||||||
|
test_data[i].dlt_month, tzinfo.DaylightDate.wMonth, wine_dbgstr_w(test_data[i].tzname));
|
||||||
|
dlt_day = day_of_month(&tzinfo.DaylightDate, test_data[i].year);
|
||||||
|
todo_wine_if(test_data[i].dlt_day_todo)
|
||||||
|
ok(dlt_day == test_data[i].dlt_day, "Expected daylight day %d, got %d, for %s\n",
|
||||||
|
test_data[i].dlt_day, dlt_day, wine_dbgstr_w(test_data[i].tzname));
|
||||||
|
todo_wine_if(test_data[i].dlt_bias_todo)
|
||||||
|
ok(tzinfo.DaylightBias == test_data[i].dlt_bias, "Expected daylight bias %d, got %d, for %s\n",
|
||||||
|
test_data[i].dlt_bias, tzinfo.DaylightBias, wine_dbgstr_w(test_data[i].tzname));
|
||||||
|
|
||||||
ret = pGetTimeZoneInformationForYear(2016, &dyn_tzinfo, &tzinfo2);
|
if (i > 0 && test_data[i-1].tzname == test_data[i].tzname)
|
||||||
ok(ret == TRUE, "GetTimeZoneInformationForYear failed, err %u\n", GetLastError());
|
{
|
||||||
ok(!lstrcmpW(tzinfo.StandardName, tzinfo2.StandardName),
|
ok(!lstrcmpW(tzinfo.StandardName, tzinfo2.StandardName),
|
||||||
"Got differing StandardName values %s and %s\n",
|
"Got differing StandardName values %s and %s\n",
|
||||||
wine_dbgstr_w(tzinfo.StandardName), wine_dbgstr_w(tzinfo2.StandardName));
|
wine_dbgstr_w(tzinfo.StandardName), wine_dbgstr_w(tzinfo2.StandardName));
|
||||||
ok(!lstrcmpW(tzinfo.DaylightName, tzinfo2.DaylightName),
|
ok(!lstrcmpW(tzinfo.DaylightName, tzinfo2.DaylightName),
|
||||||
"Got differing DaylightName values %s and %s\n",
|
"Got differing DaylightName values %s and %s\n",
|
||||||
wine_dbgstr_w(tzinfo.DaylightName), wine_dbgstr_w(tzinfo2.DaylightName));
|
wine_dbgstr_w(tzinfo.DaylightName), wine_dbgstr_w(tzinfo2.DaylightName));
|
||||||
|
}
|
||||||
|
|
||||||
memset(&dyn_tzinfo, 0xaa, sizeof(dyn_tzinfo));
|
memcpy(&tzinfo2, &tzinfo, sizeof(tzinfo2));
|
||||||
lstrcpyW(dyn_tzinfo.TimeZoneKeyName, dlt_tzname);
|
}
|
||||||
|
|
||||||
SetLastError(0xdeadbeef);
|
|
||||||
ret = pGetTimeZoneInformationForYear(2015, &dyn_tzinfo, &tzinfo);
|
|
||||||
ok((ret == FALSE && GetLastError() == ERROR_FILE_NOT_FOUND) ||
|
|
||||||
broken(ret == TRUE) /* vista,7 */,
|
|
||||||
"GetTimeZoneInformationForYear err %u\n", GetLastError());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_GetTickCount(void)
|
static void test_GetTickCount(void)
|
||||||
|
|
Loading…
Reference in New Issue