taskschd: IRegistrationInfo::put_Author() should accept NULL input.
Signed-off-by: Dmitry Timoshkov <dmitry@baikal.ru> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
19f4037dd5
commit
6c091f8790
|
@ -608,15 +608,14 @@ static HRESULT WINAPI RegistrationInfo_get_Author(IRegistrationInfo *iface, BSTR
|
|||
static HRESULT WINAPI RegistrationInfo_put_Author(IRegistrationInfo *iface, BSTR author)
|
||||
{
|
||||
registration_info *reginfo = impl_from_IRegistrationInfo(iface);
|
||||
WCHAR *str = NULL;
|
||||
|
||||
TRACE("%p,%s\n", iface, debugstr_w(author));
|
||||
|
||||
if (!author) return E_INVALIDARG;
|
||||
|
||||
if (author && !(str = heap_strdupW(author))) return E_OUTOFMEMORY;
|
||||
heap_free(reginfo->author);
|
||||
reginfo->author = heap_strdupW(author);
|
||||
/* FIXME: update XML on the server side */
|
||||
return reginfo->author ? S_OK : E_OUTOFMEMORY;
|
||||
reginfo->author = str;
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
static HRESULT WINAPI RegistrationInfo_get_Version(IRegistrationInfo *iface, BSTR *version)
|
||||
|
|
|
@ -1424,6 +1424,7 @@ static void test_TaskDefinition(void)
|
|||
"<Task xmlns=\"http://schemas.microsoft.com/windows/2004/02/mit/task\">\n"
|
||||
" <RegistrationInfo>\n"
|
||||
" <Description>\"Task1\"</Description>\n"
|
||||
" <Author>author</Author>\n"
|
||||
" </RegistrationInfo>\n"
|
||||
" <Settings>\n"
|
||||
" <Enabled>false</Enabled>\n"
|
||||
|
@ -1503,6 +1504,7 @@ static void test_TaskDefinition(void)
|
|||
" </Exec>\n"
|
||||
" </Actions>\n"
|
||||
"</Task>\n";
|
||||
static const WCHAR authorW[] = { 'a','u','t','h','o','r',0 };
|
||||
static WCHAR Task1[] = { '"','T','a','s','k','1','"',0 };
|
||||
static struct settings def_settings = { { 0 }, { 'P','T','7','2','H',0 }, { 0 },
|
||||
0, 7, TASK_INSTANCES_IGNORE_NEW, TASK_COMPATIBILITY_V2, VARIANT_TRUE, VARIANT_TRUE,
|
||||
|
@ -1609,9 +1611,17 @@ todo_wine
|
|||
ok(hr == S_OK, "get_Description error %#x\n", hr);
|
||||
ok(!bstr, "expected NULL, got %s\n", wine_dbgstr_w(bstr));
|
||||
|
||||
hr = IRegistrationInfo_get_Author(reginfo, &bstr);
|
||||
ok(hr == S_OK, "get_Author error %#x\n", hr);
|
||||
ok(!lstrcmpW(bstr, authorW), "expected %s, got %s\n", wine_dbgstr_w(authorW), wine_dbgstr_w(bstr));
|
||||
SysFreeString(bstr);
|
||||
hr = IRegistrationInfo_put_Author(reginfo, NULL);
|
||||
ok(hr == S_OK, "put_Author error %#x\n", hr);
|
||||
bstr = (BSTR)0xdeadbeef;
|
||||
hr = IRegistrationInfo_get_Author(reginfo, &bstr);
|
||||
ok(hr == S_OK, "get_Author error %#x\n", hr);
|
||||
ok(!bstr, "expected NULL, got %s\n", wine_dbgstr_w(bstr));
|
||||
|
||||
hr = IRegistrationInfo_get_Version(reginfo, &bstr);
|
||||
ok(hr == S_OK, "get_Version error %#x\n", hr);
|
||||
ok(!bstr, "expected NULL, got %s\n", wine_dbgstr_w(bstr));
|
||||
|
|
Loading…
Reference in New Issue