webservices: Implement WsInitializeMessage.
Signed-off-by: Hans Leidekker <hans@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
dc8033d371
commit
d91a7d2e4b
|
@ -44,6 +44,7 @@ static const struct prop_desc msg_props[] =
|
||||||
|
|
||||||
struct msg
|
struct msg
|
||||||
{
|
{
|
||||||
|
WS_MESSAGE_INITIALIZATION init;
|
||||||
WS_MESSAGE_STATE state;
|
WS_MESSAGE_STATE state;
|
||||||
WS_ENVELOPE_VERSION version_env;
|
WS_ENVELOPE_VERSION version_env;
|
||||||
WS_ADDRESSING_VERSION version_addr;
|
WS_ADDRESSING_VERSION version_addr;
|
||||||
|
@ -143,6 +144,30 @@ HRESULT WINAPI WsCreateMessageForChannel( WS_CHANNEL *channel_handle, const WS_M
|
||||||
return create_msg( version_env, version_addr, properties, count, handle );
|
return create_msg( version_env, version_addr, properties, count, handle );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
* WsInitializeMessage [webservices.@]
|
||||||
|
*/
|
||||||
|
HRESULT WINAPI WsInitializeMessage( WS_MESSAGE *handle, WS_MESSAGE_INITIALIZATION init,
|
||||||
|
WS_MESSAGE *src_handle, WS_ERROR *error )
|
||||||
|
{
|
||||||
|
struct msg *msg = (struct msg *)handle;
|
||||||
|
|
||||||
|
TRACE( "%p %u %p %p\n", handle, init, src_handle, error );
|
||||||
|
if (error) FIXME( "ignoring error parameter\n" );
|
||||||
|
if (src_handle)
|
||||||
|
{
|
||||||
|
FIXME( "src message not supported\n" );
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!handle || init > WS_FAULT_MESSAGE) return E_INVALIDARG;
|
||||||
|
if (msg->state >= WS_MESSAGE_STATE_INITIALIZED) return WS_E_INVALID_OPERATION;
|
||||||
|
|
||||||
|
msg->init = init;
|
||||||
|
msg->state = WS_MESSAGE_STATE_INITIALIZED;
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* WsFreeMessage [webservices.@]
|
* WsFreeMessage [webservices.@]
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -156,8 +156,62 @@ static void test_WsCreateMessageForChannel(void)
|
||||||
WsFreeMessage( msg );
|
WsFreeMessage( msg );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_WsInitializeMessage(void)
|
||||||
|
{
|
||||||
|
HRESULT hr;
|
||||||
|
WS_MESSAGE *msg;
|
||||||
|
WS_MESSAGE_STATE state;
|
||||||
|
WS_ENVELOPE_VERSION env_version;
|
||||||
|
WS_ADDRESSING_VERSION addr_version;
|
||||||
|
BOOL addressed;
|
||||||
|
|
||||||
|
return;
|
||||||
|
hr = WsInitializeMessage( NULL, WS_REQUEST_MESSAGE, NULL, NULL );
|
||||||
|
ok( hr == E_INVALIDARG, "got %08x\n", hr );
|
||||||
|
|
||||||
|
hr = WsCreateMessage( WS_ADDRESSING_VERSION_0_9, WS_ENVELOPE_VERSION_SOAP_1_1, NULL,
|
||||||
|
0, &msg, NULL );
|
||||||
|
ok( hr == S_OK, "got %08x\n", hr );
|
||||||
|
|
||||||
|
hr = WsInitializeMessage( msg, 0xdeadbeef, NULL, NULL );
|
||||||
|
ok( hr == E_INVALIDARG, "got %08x\n", hr );
|
||||||
|
|
||||||
|
hr = WsInitializeMessage( msg, WS_REQUEST_MESSAGE, NULL, NULL );
|
||||||
|
ok( hr == S_OK, "got %08x\n", hr );
|
||||||
|
|
||||||
|
hr = WsInitializeMessage( msg, WS_REQUEST_MESSAGE, NULL, NULL );
|
||||||
|
ok( hr == WS_E_INVALID_OPERATION, "got %08x\n", hr );
|
||||||
|
|
||||||
|
state = 0xdeadbeef;
|
||||||
|
hr = WsGetMessageProperty( msg, WS_MESSAGE_PROPERTY_STATE, &state, sizeof(state), NULL );
|
||||||
|
ok( hr == S_OK, "got %08x\n", hr );
|
||||||
|
ok( state == WS_MESSAGE_STATE_INITIALIZED, "got %u\n", state );
|
||||||
|
|
||||||
|
addressed = -1;
|
||||||
|
hr = WsGetMessageProperty( msg, WS_MESSAGE_PROPERTY_IS_ADDRESSED, &addressed, sizeof(addressed),
|
||||||
|
NULL );
|
||||||
|
ok( hr == S_OK, "got %08x\n", hr );
|
||||||
|
ok( !addressed, "unexpected value %d\n", addressed );
|
||||||
|
|
||||||
|
state = WS_MESSAGE_STATE_EMPTY;
|
||||||
|
hr = WsSetMessageProperty( msg, WS_MESSAGE_PROPERTY_STATE, &state, sizeof(state), NULL );
|
||||||
|
ok( hr == E_INVALIDARG, "got %08x\n", hr );
|
||||||
|
|
||||||
|
env_version = WS_ENVELOPE_VERSION_SOAP_1_1;
|
||||||
|
hr = WsSetMessageProperty( msg, WS_MESSAGE_PROPERTY_ENVELOPE_VERSION, &env_version,
|
||||||
|
sizeof(env_version), NULL );
|
||||||
|
ok( hr == E_INVALIDARG, "got %08x\n", hr );
|
||||||
|
|
||||||
|
addr_version = WS_ADDRESSING_VERSION_0_9;
|
||||||
|
hr = WsSetMessageProperty( msg, WS_MESSAGE_PROPERTY_ADDRESSING_VERSION, &addr_version,
|
||||||
|
sizeof(addr_version), NULL );
|
||||||
|
ok( hr == E_INVALIDARG, "got %08x\n", hr );
|
||||||
|
WsFreeMessage( msg );
|
||||||
|
}
|
||||||
|
|
||||||
START_TEST(msg)
|
START_TEST(msg)
|
||||||
{
|
{
|
||||||
test_WsCreateMessage();
|
test_WsCreateMessage();
|
||||||
test_WsCreateMessageForChannel();
|
test_WsCreateMessageForChannel();
|
||||||
|
test_WsInitializeMessage();
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,7 +90,7 @@
|
||||||
@ stdcall WsGetWriterPosition(ptr ptr ptr)
|
@ stdcall WsGetWriterPosition(ptr ptr ptr)
|
||||||
@ stdcall WsGetWriterProperty(ptr long ptr long ptr)
|
@ stdcall WsGetWriterProperty(ptr long ptr long ptr)
|
||||||
@ stdcall WsGetXmlAttribute(ptr ptr ptr ptr ptr ptr)
|
@ stdcall WsGetXmlAttribute(ptr ptr ptr ptr ptr ptr)
|
||||||
@ stub WsInitializeMessage
|
@ stdcall WsInitializeMessage(ptr long ptr ptr)
|
||||||
@ stub WsMarkHeaderAsUnderstood
|
@ stub WsMarkHeaderAsUnderstood
|
||||||
@ stub WsMatchPolicyAlternative
|
@ stub WsMatchPolicyAlternative
|
||||||
@ stdcall WsMoveReader(ptr long ptr ptr)
|
@ stdcall WsMoveReader(ptr long ptr ptr)
|
||||||
|
|
Loading…
Reference in New Issue