My goal was to write automatic performance test for Android CPU intensive code using an instrumental test (AndroidJUnitRunner).
I was very surprised to find that the test results are not reliable, to simulate CPU intensive code, I want to test, I wrote the following loop
for(int i=0;i<1000000;i++){
Math.pow(2,i);
}
The code was tested as an instrumental test and within an Android app
The result I got was as follows:
Instrumental test showed ~230ms to complete the loop whereas the same code on the same device (G5) took ~600ms
I will appreciate any clue why the execution of same code on AndroidJUnitRunner takes three times less time than on the real device while both of them finally are executed on the same device