2011-12-16 19:27:52 +00:00
|
|
|
#filter substitution
|
|
|
|
package @ANDROID_PACKAGE_NAME@.tests;
|
|
|
|
|
|
|
|
|
|
|
|
import com.jayway.android.robotium.solo.Solo;
|
|
|
|
import @ANDROID_PACKAGE_NAME@.*;
|
|
|
|
|
|
|
|
import android.app.Activity;
|
|
|
|
import android.test.ActivityInstrumentationTestCase2;
|
|
|
|
import android.test.PerformanceTestCase;
|
|
|
|
import android.util.Log;
|
|
|
|
import android.widget.Button;
|
|
|
|
import android.content.Intent;
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
@SuppressWarnings("unused")
|
|
|
|
public class testPan extends ActivityInstrumentationTestCase2 {
|
|
|
|
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
public testPan(Class activityClass) {
|
|
|
|
super(activityClass);
|
|
|
|
// TODO Auto-generated constructor stub
|
|
|
|
}
|
|
|
|
private static final String TARGET_PACKAGE_ID = "org.mozilla.gecko";
|
|
|
|
private static final String LAUNCH_ACTIVITY_FULL_CLASSNAME="@ANDROID_PACKAGE_NAME@.App";
|
|
|
|
private Solo solo;
|
|
|
|
private Activity activity;
|
|
|
|
private Driver driver;
|
|
|
|
private Actions actions;
|
2011-12-30 20:57:34 +00:00
|
|
|
private Assert asserter;
|
2011-12-16 19:27:52 +00:00
|
|
|
private static Class<?> launcherActivityClass;
|
|
|
|
|
|
|
|
static{
|
|
|
|
try{
|
|
|
|
launcherActivityClass = Class.forName(LAUNCH_ACTIVITY_FULL_CLASSNAME);
|
|
|
|
} catch (ClassNotFoundException e){
|
|
|
|
throw new RuntimeException(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
public testPan() throws ClassNotFoundException {
|
|
|
|
super(TARGET_PACKAGE_ID, launcherActivityClass);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void setUp() throws Exception
|
|
|
|
{
|
|
|
|
// Load config file from sdcard (setup by python script)
|
|
|
|
String configFile = FennecNativeDriver.getFile("/mnt/sdcard/robotium.config");
|
|
|
|
HashMap config = FennecNativeDriver.convertTextToTable(configFile);
|
|
|
|
|
|
|
|
// Create the intent to be used with all the important arguments.
|
|
|
|
Intent i = new Intent(Intent.ACTION_MAIN);
|
|
|
|
String argsList = "-no-remote -profile " + (String)config.get("profile");
|
|
|
|
i.putExtra("args", argsList);
|
|
|
|
|
|
|
|
//Start the activity
|
|
|
|
setActivityIntent(i);
|
|
|
|
activity = getActivity();
|
|
|
|
|
|
|
|
//Set up Robotium.solo and Driver objects
|
|
|
|
solo = new Solo(getInstrumentation(), getActivity());
|
|
|
|
driver = new FennecNativeDriver(activity, solo);
|
|
|
|
actions = new FennecNativeActions(activity, solo, getInstrumentation());
|
|
|
|
driver.setLogFile((String)config.get("logfile"));
|
2011-12-30 20:57:34 +00:00
|
|
|
|
|
|
|
asserter = new FennecNativeAssert();
|
|
|
|
asserter.setLogFile((String)config.get("logfile"));
|
2011-12-16 19:27:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public void testPan() {
|
|
|
|
// TODO: find a better way to not hardcode this url
|
2011-12-30 20:57:34 +00:00
|
|
|
String url = "http://mochi.test:8888/startup_test/fenncmark/wikipedia.html";
|
2011-12-22 14:09:50 +00:00
|
|
|
actions.waitForGeckoEvent("Gecko:Ready");
|
2011-12-16 19:27:52 +00:00
|
|
|
Element awesomebar = driver.findElement("awesome_bar");
|
|
|
|
awesomebar.click();
|
|
|
|
|
|
|
|
Element urlbar = driver.findElement("awesomebar_text");
|
2011-12-22 14:09:50 +00:00
|
|
|
getInstrumentation().waitForIdleSync();
|
2011-12-16 19:27:52 +00:00
|
|
|
actions.sendKeys(url);
|
2011-12-30 20:57:34 +00:00
|
|
|
asserter.is(url, urlbar.getText(),"Asserting Awesomebar typing works");
|
2011-12-16 19:27:52 +00:00
|
|
|
|
|
|
|
actions.sendSpecialKey(Actions.SpecialKey.ENTER);
|
|
|
|
actions.waitForGeckoEvent("DOMContentLoaded");
|
|
|
|
driver.setupScrollHandling();
|
|
|
|
|
|
|
|
// Setup scrolling coordinates.
|
|
|
|
int midX = driver.getGeckoLeft() + driver.getGeckoWidth()/2;
|
|
|
|
int midY = driver.getGeckoTop() + driver.getGeckoHeight()/2;
|
|
|
|
int endY = driver.getGeckoTop() + driver.getGeckoHeight()/10;
|
|
|
|
|
|
|
|
driver.startFrameRecording();
|
|
|
|
|
|
|
|
int i = 0;
|
|
|
|
// Scroll a thousand times or until the end of the page.
|
|
|
|
do {
|
|
|
|
actions.drag(midX, midX, midY, endY);
|
|
|
|
try {
|
|
|
|
Thread.sleep(200);
|
|
|
|
}
|
|
|
|
catch (InterruptedException e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
i++;
|
|
|
|
} while( i < 1000 && driver.getScrollHeight() + 2*driver.getHeight() < driver.getPageHeight() );
|
2011-12-30 20:57:34 +00:00
|
|
|
// asserter.ok(i < 1000, "Less than 1000", "Should take less than 1000 drags to get to bottom of the page.");
|
2011-12-16 19:27:52 +00:00
|
|
|
|
|
|
|
int frames = driver.stopFrameRecording();
|
|
|
|
driver.dumpLog("__start_report" + Integer.toString(frames) + "__end_report");
|
|
|
|
Long msecs = System.currentTimeMillis();
|
|
|
|
driver.dumpLog("__startTimestamp" + msecs.toString() + "__endTimestamp");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void tearDown() throws Exception {
|
|
|
|
try {
|
|
|
|
solo.finalize();
|
|
|
|
}catch (Throwable e){
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
getActivity().finish();
|
|
|
|
super.tearDown();
|
|
|
|
}
|
|
|
|
}
|