mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
96e7dd21de
--HG-- rename : build/mobile/robocop/Actions.java.in => build/mobile/robocop/Actions.java rename : build/mobile/robocop/Assert.java.in => build/mobile/robocop/Assert.java rename : build/mobile/robocop/Driver.java.in => build/mobile/robocop/Driver.java rename : build/mobile/robocop/Element.java.in => build/mobile/robocop/Element.java rename : build/mobile/robocop/FennecInstrumentationTestRunner.java.in => build/mobile/robocop/FennecInstrumentationTestRunner.java rename : build/mobile/robocop/FennecMochitestAssert.java.in => build/mobile/robocop/FennecMochitestAssert.java rename : build/mobile/robocop/FennecNativeActions.java.in => build/mobile/robocop/FennecNativeActions.java rename : build/mobile/robocop/FennecNativeDriver.java.in => build/mobile/robocop/FennecNativeDriver.java rename : build/mobile/robocop/FennecNativeElement.java.in => build/mobile/robocop/FennecNativeElement.java rename : build/mobile/robocop/FennecTalosAssert.java.in => build/mobile/robocop/FennecTalosAssert.java rename : build/mobile/robocop/PaintedSurface.java.in => build/mobile/robocop/PaintedSurface.java rename : build/mobile/robocop/RoboCopException.java.in => build/mobile/robocop/RoboCopException.java rename : build/mobile/robocop/RobocopUtils.java.in => build/mobile/robocop/RobocopUtils.java rename : mobile/android/base/tests/AboutHomeTest.java.in => mobile/android/base/tests/AboutHomeTest.java rename : mobile/android/base/tests/BaseTest.java.in => mobile/android/base/tests/BaseTest.java rename : mobile/android/base/tests/ContentContextMenuTest.java.in => mobile/android/base/tests/ContentContextMenuTest.java rename : mobile/android/base/tests/ContentProviderTest.java.in => mobile/android/base/tests/ContentProviderTest.java rename : mobile/android/base/tests/DatabaseHelper.java.in => mobile/android/base/tests/DatabaseHelper.java rename : mobile/android/base/tests/JavascriptTest.java.in => mobile/android/base/tests/JavascriptTest.java rename : mobile/android/base/tests/MotionEventHelper.java.in => mobile/android/base/tests/MotionEventHelper.java rename : mobile/android/base/tests/MotionEventReplayer.java.in => mobile/android/base/tests/MotionEventReplayer.java rename : mobile/android/base/tests/PixelTest.java.in => mobile/android/base/tests/PixelTest.java rename : mobile/android/base/tests/StringHelper.java.in => mobile/android/base/tests/StringHelper.java rename : mobile/android/base/tests/testAboutPage.java.in => mobile/android/base/tests/testAboutPage.java rename : mobile/android/base/tests/testAddSearchEngine.java.in => mobile/android/base/tests/testAddSearchEngine.java rename : mobile/android/base/tests/testAddonManager.java.in => mobile/android/base/tests/testAddonManager.java rename : mobile/android/base/tests/testAwesomebar.java.in => mobile/android/base/tests/testAwesomebar.java rename : mobile/android/base/tests/testAwesomebarSwipes.java.in => mobile/android/base/tests/testAwesomebarSwipes.java rename : mobile/android/base/tests/testAxisLocking.java.in => mobile/android/base/tests/testAxisLocking.java rename : mobile/android/base/tests/testBookmark.java.in => mobile/android/base/tests/testBookmark.java rename : mobile/android/base/tests/testBookmarkFolders.java.in => mobile/android/base/tests/testBookmarkFolders.java rename : mobile/android/base/tests/testBookmarkKeyword.java.in => mobile/android/base/tests/testBookmarkKeyword.java rename : mobile/android/base/tests/testBookmarklets.java.in => mobile/android/base/tests/testBookmarklets.java rename : mobile/android/base/tests/testBookmarksPage.java.in => mobile/android/base/tests/testBookmarksPage.java rename : mobile/android/base/tests/testBrowserProvider.java.in => mobile/android/base/tests/testBrowserProvider.java rename : mobile/android/base/tests/testBrowserProviderPerf.java.in => mobile/android/base/tests/testBrowserProviderPerf.java rename : mobile/android/base/tests/testBrowserSearchVisibility.java.in => mobile/android/base/tests/testBrowserSearchVisibility.java rename : mobile/android/base/tests/testCheck.java.in => mobile/android/base/tests/testCheck.java rename : mobile/android/base/tests/testCheck2.java.in => mobile/android/base/tests/testCheck2.java rename : mobile/android/base/tests/testClearPrivateData.java.in => mobile/android/base/tests/testClearPrivateData.java rename : mobile/android/base/tests/testDeviceSearchEngine.java.in => mobile/android/base/tests/testDeviceSearchEngine.java rename : mobile/android/base/tests/testDistribution.java.in => mobile/android/base/tests/testDistribution.java rename : mobile/android/base/tests/testDoorHanger.java.in => mobile/android/base/tests/testDoorHanger.java rename : mobile/android/base/tests/testFindInPage.java.in => mobile/android/base/tests/testFindInPage.java rename : mobile/android/base/tests/testFlingCorrectness.java.in => mobile/android/base/tests/testFlingCorrectness.java rename : mobile/android/base/tests/testFormHistory.java.in => mobile/android/base/tests/testFormHistory.java rename : mobile/android/base/tests/testGetUserMedia.java.in => mobile/android/base/tests/testGetUserMedia.java rename : mobile/android/base/tests/testHistory.java.in => mobile/android/base/tests/testHistory.java rename : mobile/android/base/tests/testHomeBanner.java.in => mobile/android/base/tests/testHomeBanner.java rename : mobile/android/base/tests/testImportFromAndroid.java.in => mobile/android/base/tests/testImportFromAndroid.java rename : mobile/android/base/tests/testInputUrlBar.java.in => mobile/android/base/tests/testInputUrlBar.java rename : mobile/android/base/tests/testJNI.java.in => mobile/android/base/tests/testJNI.java rename : mobile/android/base/tests/testJarReader.java.in => mobile/android/base/tests/testJarReader.java rename : mobile/android/base/tests/testLinkContextMenu.java.in => mobile/android/base/tests/testLinkContextMenu.java rename : mobile/android/base/tests/testLoad.java.in => mobile/android/base/tests/testLoad.java rename : mobile/android/base/tests/testMailToContextMenu.java.in => mobile/android/base/tests/testMailToContextMenu.java rename : mobile/android/base/tests/testMasterPassword.java.in => mobile/android/base/tests/testMasterPassword.java rename : mobile/android/base/tests/testNewTab.java.in => mobile/android/base/tests/testNewTab.java rename : mobile/android/base/tests/testOrderedBroadcast.java.in => mobile/android/base/tests/testOrderedBroadcast.java rename : mobile/android/base/tests/testOverscroll.java.in => mobile/android/base/tests/testOverscroll.java rename : mobile/android/base/tests/testPan.java.in => mobile/android/base/tests/testPan.java rename : mobile/android/base/tests/testPanCorrectness.java.in => mobile/android/base/tests/testPanCorrectness.java rename : mobile/android/base/tests/testPasswordEncrypt.java.in => mobile/android/base/tests/testPasswordEncrypt.java rename : mobile/android/base/tests/testPasswordProvider.java.in => mobile/android/base/tests/testPasswordProvider.java rename : mobile/android/base/tests/testPermissions.java.in => mobile/android/base/tests/testPermissions.java rename : mobile/android/base/tests/testPictureLinkContextMenu.java.in => mobile/android/base/tests/testPictureLinkContextMenu.java rename : mobile/android/base/tests/testPrefsObserver.java.in => mobile/android/base/tests/testPrefsObserver.java rename : mobile/android/base/tests/testPrivateBrowsing.java.in => mobile/android/base/tests/testPrivateBrowsing.java rename : mobile/android/base/tests/testPromptGridInput.java.in => mobile/android/base/tests/testPromptGridInput.java rename : mobile/android/base/tests/testReaderMode.java.in => mobile/android/base/tests/testReaderMode.java rename : mobile/android/base/tests/testSearchSuggestions.java.in => mobile/android/base/tests/testSearchSuggestions.java rename : mobile/android/base/tests/testSettingsMenuItems.java.in => mobile/android/base/tests/testSettingsMenuItems.java rename : mobile/android/base/tests/testShareLink.java.in => mobile/android/base/tests/testShareLink.java rename : mobile/android/base/tests/testSharedPreferences.java.in => mobile/android/base/tests/testSharedPreferences.java rename : mobile/android/base/tests/testSystemPages.java.in => mobile/android/base/tests/testSystemPages.java rename : mobile/android/base/tests/testTabHistory.java.in => mobile/android/base/tests/testTabHistory.java rename : mobile/android/base/tests/testThumbnails.java.in => mobile/android/base/tests/testThumbnails.java rename : mobile/android/base/tests/testVkbOverlap.java.in => mobile/android/base/tests/testVkbOverlap.java rename : mobile/android/base/tests/test_bug720538.java.in => mobile/android/base/tests/test_bug720538.java extra : rebase_source : c8d715aa110b07c6010054a674879e143a5f04e7 extra : amend_source : fb5714b78e055e336b5e0c6a0da8eb8c931ff09e extra : histedit_source : ec57d8ba94000092438a2ba0bf4fb66091e98513%2C114ade72bb9b72b96557da74f1179734fa347e5c
148 lines
5.1 KiB
Java
148 lines
5.1 KiB
Java
package org.mozilla.gecko.tests;
|
|
|
|
import org.mozilla.gecko.*;
|
|
|
|
import android.util.Log;
|
|
|
|
import java.util.regex.Matcher;
|
|
import java.util.regex.Pattern;
|
|
|
|
import junit.framework.AssertionFailedError;
|
|
|
|
import org.json.JSONArray;
|
|
import org.json.JSONException;
|
|
import org.json.JSONObject;
|
|
|
|
|
|
public class JavascriptTest extends BaseTest {
|
|
public static final String LOGTAG = "JavascriptTest";
|
|
|
|
public final String javascriptUrl;
|
|
|
|
public JavascriptTest(String javascriptUrl) {
|
|
super();
|
|
this.javascriptUrl = javascriptUrl;
|
|
}
|
|
|
|
@Override
|
|
protected int getTestType() {
|
|
return TEST_MOCHITEST;
|
|
}
|
|
|
|
/**
|
|
* Route messages from Javascript's head.js test framework into Java's
|
|
* Mochitest framework.
|
|
*/
|
|
protected static class JavascriptTestMessageParser {
|
|
// Messages matching this pattern are handled specially. Messages not
|
|
// matching this pattern are still printed.
|
|
private static final Pattern testMessagePattern =
|
|
Pattern.compile("\n+TEST-(.*) \\| (.*) \\| (.*)\n*");
|
|
|
|
private final Assert mAsserter;
|
|
|
|
// Used to help print stack traces neatly.
|
|
private String lastTestName = "";
|
|
|
|
// Have we seen a message saying the test is finished?
|
|
private boolean testFinishedMessageSeen = false;
|
|
|
|
public JavascriptTestMessageParser(final Assert asserter) {
|
|
this.mAsserter = asserter;
|
|
}
|
|
|
|
private boolean testIsFinished() {
|
|
return testFinishedMessageSeen;
|
|
}
|
|
|
|
private void logMessage(String str) {
|
|
Matcher m = testMessagePattern.matcher(str);
|
|
|
|
if (m.matches()) {
|
|
String type = m.group(1);
|
|
String name = m.group(2);
|
|
String message = m.group(3);
|
|
|
|
if ("INFO".equals(type)) {
|
|
mAsserter.info(name, message);
|
|
testFinishedMessageSeen = testFinishedMessageSeen ||
|
|
"exiting test".equals(message);
|
|
} else if ("PASS".equals(type)) {
|
|
mAsserter.ok(true, name, message);
|
|
} else if ("UNEXPECTED-FAIL".equals(type)) {
|
|
try {
|
|
mAsserter.ok(false, name, message);
|
|
} catch (junit.framework.AssertionFailedError e) {
|
|
// Swallow this exception. We want to see all the
|
|
// Javascript failures, not die on the very first one!
|
|
}
|
|
} else if ("KNOWN-FAIL".equals(type)) {
|
|
mAsserter.todo(false, name, message);
|
|
} else if ("UNEXPECTED-PASS".equals(type)) {
|
|
mAsserter.todo(true, name, message);
|
|
}
|
|
|
|
lastTestName = name;
|
|
} else {
|
|
// Generally, these extra lines are stack traces from failures,
|
|
// so we print them with the name of the last test seen.
|
|
mAsserter.info(lastTestName, str.trim());
|
|
}
|
|
}
|
|
}
|
|
|
|
public void testJavascript() throws Exception {
|
|
blockForGeckoReady();
|
|
|
|
// We want to be waiting for Robocop messages before the page is loaded
|
|
// because the test harness runs each test in the suite (and possibly
|
|
// completes testing) before the page load event is fired.
|
|
final Actions.EventExpecter expecter = mActions.expectGeckoEvent("Robocop:Status");
|
|
mAsserter.dumpLog("Registered listener for Robocop:Status");
|
|
|
|
final String url = getAbsoluteUrl("/robocop/robocop_javascript.html?path=" + javascriptUrl);
|
|
mAsserter.dumpLog("Loading JavaScript test from " + url);
|
|
|
|
loadUrl(url);
|
|
|
|
final JavascriptTestMessageParser testMessageParser =
|
|
new JavascriptTestMessageParser(mAsserter);
|
|
|
|
try {
|
|
while (true) {
|
|
if (Log.isLoggable(LOGTAG, Log.VERBOSE)) {
|
|
Log.v(LOGTAG, "Waiting for Robocop:Status");
|
|
}
|
|
String data = expecter.blockForEventData();
|
|
if (Log.isLoggable(LOGTAG, Log.VERBOSE)) {
|
|
Log.v(LOGTAG, "Got Robocop:Status with data '" + data + "'");
|
|
}
|
|
|
|
JSONObject o = new JSONObject(data);
|
|
String innerType = o.getString("innerType");
|
|
|
|
if (!"progress".equals(innerType)) {
|
|
throw new Exception("Unexpected Robocop:Status innerType " + innerType);
|
|
}
|
|
|
|
String message = o.getString("message");
|
|
if (message == null) {
|
|
throw new Exception("Robocop:Status progress message must not be null");
|
|
}
|
|
|
|
testMessageParser.logMessage(message);
|
|
|
|
if (testMessageParser.testIsFinished()) {
|
|
if (Log.isLoggable(LOGTAG, Log.DEBUG)) {
|
|
Log.d(LOGTAG, "Got test finished message");
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
} finally {
|
|
expecter.unregisterListener();
|
|
mAsserter.dumpLog("Unregistered listener for Robocop:Status");
|
|
}
|
|
}
|
|
}
|