diff options
-rw-r--r-- | tests/src/com/android/browser/PopularUrlsTest.java | 224 |
1 files changed, 200 insertions, 24 deletions
diff --git a/tests/src/com/android/browser/PopularUrlsTest.java b/tests/src/com/android/browser/PopularUrlsTest.java index 4ae69c7..93aadda 100644 --- a/tests/src/com/android/browser/PopularUrlsTest.java +++ b/tests/src/com/android/browser/PopularUrlsTest.java @@ -18,11 +18,15 @@ package com.android.browser; import java.io.BufferedReader; import java.io.File; +import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.OutputStreamWriter; +import java.util.Iterator; +import java.util.LinkedList; +import java.util.List; import java.util.concurrent.CountDownLatch; import android.app.Instrumentation; @@ -48,10 +52,12 @@ public class PopularUrlsTest extends ActivityInstrumentationTestCase2<BrowserAct private final static String newLine = System.getProperty("line.separator"); private final static String sInputFile = "popular_urls.txt"; private final static String sOutputFile = "test_output.txt"; + private final static String sStatusFile = "test_status.txt"; private final static File sExternalStorage = Environment.getExternalStorageDirectory(); private BrowserActivity mActivity = null; private Instrumentation mInst = null; private CountDownLatch mLatch = new CountDownLatch(1); + private RunStatus mStatus; public PopularUrlsTest() { super("com.android.browser", BrowserActivity.class); @@ -64,25 +70,41 @@ public class PopularUrlsTest extends ActivityInstrumentationTestCase2<BrowserAct mActivity = getActivity(); mInst = getInstrumentation(); mInst.waitForIdleSync(); + + mStatus = RunStatus.load(); + } + + @Override + protected void tearDown() throws Exception { + if (mStatus != null) { + mStatus.cleanUp(); + } + + super.tearDown(); } static BufferedReader getInputStream() throws FileNotFoundException { - String path = sExternalStorage + File.separator + sInputFile; + return getInputStream(sInputFile); + } + + static BufferedReader getInputStream(String inputFile) throws FileNotFoundException { + String path = sExternalStorage + File.separator + inputFile; FileReader fileReader = new FileReader(path); BufferedReader bufferedReader = new BufferedReader(fileReader); return bufferedReader; } - static OutputStreamWriter getOutputStream() throws IOException { - String path = sExternalStorage + File.separator + sOutputFile; + OutputStreamWriter getOutputStream() throws IOException { + return getOutputStream(sOutputFile); + } + + OutputStreamWriter getOutputStream(String outputFile) throws IOException { + String path = sExternalStorage + File.separator + outputFile; File file = new File(path); - if (file.exists()) { - file.delete(); - } - return new FileWriter(file); + return new FileWriter(file, mStatus.getIsRecovery()); } /** @@ -189,40 +211,181 @@ public class PopularUrlsTest extends ActivityInstrumentationTestCase2<BrowserAct mLatch.await(); } + private static class RunStatus { + private File mFile; + private int iteration; + private int page; + private String url; + private boolean isRecovery; + + private RunStatus(String file) throws IOException { + mFile = new File(file); + FileReader input = null; + BufferedReader reader = null; + try { + input = new FileReader(mFile); + isRecovery = true; + reader = new BufferedReader(input); + iteration = Integer.parseInt(reader.readLine()); + page = Integer.parseInt(reader.readLine()); + } catch (FileNotFoundException ex) { + isRecovery = false; + iteration = 0; + page = 0; + } finally { + try { + if (reader != null) { + reader.close(); + } + } finally { + if (input != null) { + input.close(); + } + } + } + } + + public static RunStatus load() throws IOException { + return load(sStatusFile); + } + + public static RunStatus load(String file) throws IOException { + return new RunStatus(sExternalStorage + File.separator + file); + } + + public void write() throws IOException { + FileWriter output = null; + OutputStreamWriter writer = null; + if (mFile.exists()) { + mFile.delete(); + } + try { + output = new FileWriter(mFile); + output.write(iteration + newLine); + output.write(page + newLine); + output.write(url + newLine); + } finally { + try { + if (writer != null) { + writer.close(); + } + } finally { + if (output != null) { + output.close(); + } + } + } + } + + public void cleanUp() { + if (mFile.exists()) { + mFile.delete(); + } + } + + public void resetPage() { + page = 0; + } + + public void incrementPage() { + ++page; + } + + public void incrementIteration() { + ++iteration; + } + + public int getPage() { + return page; + } + + public int getIteration() { + return iteration; + } + + public boolean getIsRecovery() { + return isRecovery; + } + + public void setUrl(String url) { + this.url = url; + } + } + /** * Loops over a list of URLs, points the browser to each one, and records the time elapsed. * * @param input the reader from which to get the URLs. * @param writer the writer to which to output the results. + * @param clearCache determines whether the cache is cleared before loading each page + * @param loopCount the number of times to loop through the list of pages * @throws IOException unable to read from input or write to writer. * @throws InterruptedException the thread was interrupted waiting for the page to load. */ - void loopUrls(BufferedReader input, OutputStreamWriter writer) + void loopUrls(BufferedReader input, OutputStreamWriter writer, + boolean clearCache, int loopCount) throws IOException, InterruptedException { Tab tab = mActivity.getTabControl().getCurrentTab(); WebView webView = tab.getWebView(); - String page; + List<String> pages = new LinkedList<String>(); + + String page; while (null != (page = input.readLine())) { - Uri uri = Uri.parse(page); - webView.clearCache(true); - final Intent intent = new Intent(Intent.ACTION_VIEW, uri); - writer.write(uri.toString()); + pages.add(page); + } + + int iteration = mStatus.getIteration(); + Iterator<String> iterator = pages.iterator(); + for (int i = 0; i < mStatus.getPage(); ++i) { + iterator.next(); + } - long startTime = System.nanoTime(); - mInst.runOnMainSync(new Runnable() { + if (mStatus.getIsRecovery()) { + Log.e(TAG, "Recovering after crash: " + iterator.next()); + } + + while (iteration < loopCount) { + while(iterator.hasNext()) { + page = iterator.next(); + mStatus.setUrl(page); + mStatus.write(); + Log.i(TAG, "Loading url: " + page); + Uri uri = Uri.parse(page); + if (clearCache) { + webView.clearCache(true); + } + final Intent intent = new Intent(Intent.ACTION_VIEW, uri); - public void run() { - mActivity.onNewIntent(intent); + if (writer != null) { + writer.write(uri.toString()); + writer.flush(); } - }); - waitForLoad(); - long stopTime = System.nanoTime(); + long startTime = System.nanoTime(); + mInst.runOnMainSync(new Runnable() { + + public void run() { + mActivity.onNewIntent(intent); + } + + }); + waitForLoad(); + long stopTime = System.nanoTime(); - String url = webView.getUrl(); - Log.i(TAG, "Loaded url: " + url); - writer.write("|" + (stopTime - startTime) + newLine); + String url = webView.getUrl(); + Log.d(TAG, "Loaded url: " + url); + + if (writer != null) { + writer.write("|" + (stopTime - startTime) + newLine); + writer.flush(); + } + + mStatus.incrementPage(); + } + mStatus.incrementIteration(); + mStatus.resetPage(); + iterator = pages.iterator(); } } @@ -233,7 +396,7 @@ public class PopularUrlsTest extends ActivityInstrumentationTestCase2<BrowserAct try { BufferedReader bufferedReader = getInputStream(); try { - loopUrls(bufferedReader, writer); + loopUrls(bufferedReader, writer, true, 10); } finally { if (bufferedReader != null) { bufferedReader.close(); @@ -245,5 +408,18 @@ public class PopularUrlsTest extends ActivityInstrumentationTestCase2<BrowserAct } } } + + public void testStability() throws IOException, InterruptedException { + setUpBrowser(); + + BufferedReader bufferedReader = getInputStream(); + try { + loopUrls(bufferedReader, null, true, 1); + } finally { + if (bufferedReader != null) { + bufferedReader.close(); + } + } + } } |