IntelliTrace Arguments By Reference

2019-09-15 23:44发布

Using IntelliTrace, I'm unable to see the output of a string passed by reference into a method and the result of the method in the same event (or at all).

Method example:

public bool ByReferenceTestMethod(System.ArgumentNullException exception, ref string referenceArgument)
{
    referenceArgument = string.Format("referenceArgument{0}", exception.Message);
    return true;
}

collectionplan.xml example working without reference argument reference:

<DiagnosticEventSpecification>
    <CategoryId>stackoverflow.test.application</CategoryId>
    <SettingsName _locID="settingsName.Test.Application.Reference">VerifyIDFromBackEnd called</SettingsName>
    <SettingsDescription _locID="settingsDescription.Test.Application.Reference">VerifyIDFromBackEnd was called</SettingsDescription>
    <Bindings>
        <Binding onReturn="false">
            <ModuleSpecificationId>stackoverflow.test.application</ModuleSpecificationId>
            <MethodName>ByReferenceTestMethod</MethodName>
            <MethodId>Test.Application.TestClass.ByReferenceTestMethod(System.ArgumentException,System.String&amp;):System.Boolean</MethodId>
            <ShortDescription _locID="shortDescription.Test.Application.Reference.called">Method 'ByReferenceTestMethod' called</ShortDescription>
            <LongDescription _locID="longDescription.Test.Application.Reference.called">ByReferenceTestMethod called with ArgumentException parameter name "{0}" and message "{1}"</LongDescription>
            <TypeName>Test.Application.TestClass</TypeName>
            <DataQueries>
                <DataQuery index="1" maxSize="2048" type="String" name="Exception parameter" _locID="dataquery.Test.Application.Reference.exception.Paramname" query="m_paramName" />
                <DataQuery index="1" maxSize="2048" type="String" name="Exception message" _locID="dataquery.Test.Application.Reference.exc5eption.Message" _locAttrData="name" query="_message" />
        </DataQueries>
        </Binding>
        <Binding onReturn="true">
            <ModuleSpecificationId>stackoverflow.test.application</ModuleSpecificationId>
            <MethodName>ByReferenceTestMethod</MethodName>
            <MethodId>Test.Application.TestClass.ByReferenceTestMethod(System.Exception,System.String&amp;):System.Boolean</MethodId>
            <ShortDescription _locID="shortDescription.Test.Application.Reference.result">Method 'ByReferenceTestMethod' completed</ShortDescription>
            <LongDescription _locID="longDescription.Test.Application.Reference.result">ByReferenceTestMethod returned result "{0}" with an unknown referenceArgument</LongDescription>
            <TypeName>Test.Application.TestClass</TypeName>
            <DataQueries>
                <DataQuery index="-1" maxSize="0" type="Boolean" name="Reference Result" _locID="dataquery.Test.Application.Reference.result" _locAttrData="name" query="" />
            </DataQueries>
        </Binding>
    </Bindings>
</DiagnosticEventSpecification>

collectionplan.xml example not working with reference argument reference:

<LongDescription _locID="longDescription.Test.Application.Reference.result">ByReferenceTestMethod returned result "{0}" with referenceArgument "{1}"</LongDescription>
<TypeName>Test.Application.TestClass</TypeName>
<DataQueries>
    <DataQuery index="-1" maxSize="0" type="Boolean" name="Reference Result" _locID="dataquery.Test.Application.Reference.result" _locAttrData="name" query="" />
    <DataQuery index="2" maxSize="4096" type="String" name="referenceArgument" _locID="dataquery.Test.Application.Reference.Reference.Value" _locAttrData="name" query="" />
</DataQueries>

This shows the LongDescription without the resolved markers and if I change the order the message itself doesn't appear at all.

From what I understand, the ref should appear when onResult="true" because that event isn't evaluated until after the method returns. If I use place the same argument in the onResult="false" dataquery then it is evaluated before the value is possibly set by the method.

What am I doing wrong?

1条回答
时光不老,我们不散
2楼-- · 2019-09-15 23:58

As far as I know you can't do what you want. I tried to do the same thing a few times in the past and it didn't work. However, the problem is not with ref parameters. It will also not work with "normal" parameters.

If you use onReturn="true" then you can only refer to a value that was returned from a method i.e. index="-1". You cannot read values of parameters in this case. It is due to how IntelliTrace works under the hood and I don't know the workaround.

Programmable data queries will also not help. PDQ has two methods to implemented:

  • object[] EntryQuery(object thisArg, object[] args)
  • object[] ExitQuery(object returnValue)

The first one is called to analyse input parameters (onReturn="false") and the second one to analyse a return value (onReturn="false"). Again, in ExitQuery you only have access to a return value.

查看更多
登录 后发表回答