Day 046 - Method overloading and testing issues
As you'll recall from yesterday, I had a class like this:
MyClass is class END PROCEDURE Constructor() PROCEDURE Destructor() PROCEDURE MethodA(intValue is int) RESULT intValue PROCEDURE MethodA(strValue is string) RESULT strValue PROCEDURE MethodB(value) RESULT value
and I was doing some unit testing. Specifically, I wanted to explore procedure overloading. And to that end I decided to try passing a string to MethodA to verify that overloading works as I expect.
But I had a problem. The unit test interface only showed me options for the int syntax. I tried entering a string, with or without quotes, and although the entry value was accepted, after I ran the test the parameter and the expected result had both been set to 0.
But there is a solution for testing overloaded methods. Over on the right side there's a button to edit the parameters.
On the edit parameters window I set the input and control parameters to <automatic>.
I was then able to pass in either a string or a numeric value. I verified that the appropriate method was called with some debug statements. (I could just as easily have set a return value based on which method was called, but I've often used OutputDebugString when debugging complex processing, and it's a nice feature to have.)
To recap, parameters can be of automatic type (determined at runtime) or they can have a defined type. And you can overload methods. But what if you have a method that takes an automatic type? Can you overload it with a syntax for a specific type?
Here are my two methods:
PROCEDURE MethodB(value) Debug("automatic syntax used for value " + value) RESULT value PROCEDURE MethodB(value is int) Debug("int syntax used for value " + value) RESULT value
I ran the test twice, once with a string and once with an int. Here's the trace output:
[3444] automatic syntax used for value abc [3444] int syntax used for value 35
I really didn't expect that to work, but it did!
Besides parameters, return value types can, apparently, also be determined at runtime. I wrote the following code:
PROCEDURE MethodC(nParam is int) nValue is int sValue is string nValue = 12 sValue = "abc" IF nParam = 1 THEN RESULT nValue END RESULT sValue
and set up a test case. But I was unable to run the test, and I also found that I could no longer run the MethodA test. I fiddled around with this for a while, but no joy.
I'll take another kick at the unrunnable tests tomorrow.