Given that the APIs used to write the custom rules are about as well documented and supported as the ones needed for unit testing -- and have remained the same between 1.36 (for CLR2) and 10.0 (for CLR4) -- it s probably worth noting the outline of the process to get a Microsoft.FxCop.Sdk.Method
object, which can be performed using only types and methods declared public
in the FxCop assemblies (no reflection trickery required).
Start with the Type
of the object for which you want a Microsoft.FxCop.Sdk.Method
, call this t
. Get the AssemblyNode
for the assembly containing t
via the static entrypoint
assembly = AssemblyNode.GetAssembly(t.Module.Assembly.Location)
Get the FxCop TypeNode
corresponding to t
via
assembly.GetType(Identifier.For(t.Namespace), Identifier.For(t.Name))
Then search through the TypeNode
s Members
field to find the one where member.Name.Name
is the name of the method you were looking for. Given that this is a unit test, you should be able to arrange that the dummy method being examined is not overloaded.
Then call MyRule.Check(member)
to perform the test; this returns the collection of Problem
objects, which can be inspected to assert that it contains the expected results and only the expected results.