Bonjour,
J'ai besoin d'un petit coup de pouce : j'ai importé une référence web de notre ERP (Sage X3) dans mon logiciel sous VS2005. Jusque là pas de problèmes : les tests ont été concluants mais en production j'ai un phénomène que je n'arrive pas à élucider (1 à 2% des cas)
J'ai une fonction save (générée en auto) qui crée un enregistrement dans une base :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
template <typename TClient>
inline HRESULT CCAdxWebServiceXmlCCServiceT<TClient>::save(
		CAdxCallContext callContext, 
		BSTR publicName, 
		BSTR objectXml, 
		CAdxResultXml* saveReturn
	)
{
    if ( saveReturn == NULL )
		return E_POINTER;
 
	HRESULT __atlsoap_hr = InitializeSOAP(NULL);
	if (FAILED(__atlsoap_hr))
	{
		SetClientError(SOAPCLIENT_INITIALIZE_ERROR);
		return __atlsoap_hr;
	}
 
	CleanupClient();
 
	CComPtr<IStream> __atlsoap_spReadStream;
	__CCAdxWebServiceXmlCCService_save_struct __params;
	memset(&__params, 0x00, sizeof(__params));
	__params.callContext = callContext;
	__params.publicName = publicName;
	__params.objectXml = objectXml;
 
	__atlsoap_hr = SetClientStruct(&__params, 10);
	if (FAILED(__atlsoap_hr))
	{
		SetClientError(SOAPCLIENT_OUTOFMEMORY);
		goto __skip_cleanup;
	}
 
	__atlsoap_hr = GenerateResponse(GetWriteStream());
	if (FAILED(__atlsoap_hr))
	{
		SetClientError(SOAPCLIENT_GENERATE_ERROR);
		goto __skip_cleanup;
	}
 
	__atlsoap_hr = SendRequest(_T("SOAPAction: \"\"\r\n"));
	if (FAILED(__atlsoap_hr))
	{
		goto __skip_cleanup;
	}
	__atlsoap_hr = GetReadStream(&__atlsoap_spReadStream);
	if (FAILED(__atlsoap_hr))
	{
		SetClientError(SOAPCLIENT_READ_ERROR);
		goto __skip_cleanup;
	}
 
	// cleanup any in/out-params and out-headers from previous calls
	Cleanup();
	__atlsoap_hr = BeginParse(__atlsoap_spReadStream);
	if (FAILED(__atlsoap_hr))
	{
		SetClientError(SOAPCLIENT_PARSE_ERROR);
		goto __cleanup;
	}
 
	*saveReturn = __params.saveReturn;
	goto __skip_cleanup;
 
__cleanup:
	Cleanup();
__skip_cleanup:
	ResetClientState(true);
	memset(&__params, 0x00, sizeof(__params));
	return __atlsoap_hr;
}
qui me renvoie une erreur alors que la création s'est bien passée!
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
 
hr = service.save(Context, CComBSTR(L"ZPALETTE").Detach(), requete, &result2);
        if (FAILED(hr))
		{
_com_error err(hr);
LPCTSTR errMsg = err.ErrorMessage();
errMsg : Erreur non spécifiée (0x80004005)
un message d'erreur comme on les aime... J'ai horodaté 2 messages : 1 avant l'appel et l'autre immédiatement après pour mettre en évidence un timeout mais la fonction s'exécute dans la seconde!
Avez-vous une piste pour que je puisse avancer?