Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 15ce2abd authored by Android (Google) Code Review's avatar Android (Google) Code Review
Browse files

Merge changes 222,223,227

* changes:
  update onCreate method to work around InstrumentationTestRunner limitation.
  Removing unused StreamPipe class, also stripping some white spaces
  * Update the way that run_page_cycler.py detectes instrumentation failures. * Use Debug.getMemoryInfo to collect memory information in LoadTestAutoTest.
parents 0cee40e2 025950db
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -59,7 +59,8 @@ def main(options, args):
  run_load_test_cmd = run_load_test_cmd_prefix + " -e class com.android.dumprendertree.LoadTestsAutoTest#runTest -e path \"" + path + "\" -e timeout " + timeout_ms + run_load_test_cmd_postfix

  (adb_output, adb_error) = subprocess.Popen(run_load_test_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate()
  if adb_output.find('INSTRUMENTATION_FAILED') != -1:
  if adb_output.find('INSTRUMENTATION_FAILED') != -1 or \
      adb_output.find('Process crashed.') != -1:
    logging.error("Error happened : " + adb_output)
    sys.exit(1)

+1 −1
Original line number Diff line number Diff line
@@ -51,7 +51,6 @@ public class LayoutTestsAutoRunner extends InstrumentationTestRunner {

    @Override
    public void onCreate(Bundle icicle) {
        super.onCreate(icicle);
        this.mTestPath = (String) icicle.get("path");
        String timeout_str = (String) icicle.get("timeout");
        if (timeout_str != null) {
@@ -64,6 +63,7 @@ public class LayoutTestsAutoRunner extends InstrumentationTestRunner {
        
        String r = (String)icicle.get("rebaseline");
        this.mRebaseline = (r != null && r.toLowerCase().equals("true"));
        super.onCreate(icicle);
    }
    
    public String mTestPath = null;
+51 −56
Original line number Diff line number Diff line
@@ -16,46 +16,22 @@

package com.android.dumprendertree;

import android.app.Activity;
import android.app.Instrumentation;
import android.app.Instrumentation.ActivityMonitor;
import android.content.Intent;

import android.util.Log;

import android.os.Bundle;
import android.os.Debug;
import android.os.Debug.MemoryInfo;
import android.test.ActivityInstrumentationTestCase2;

import com.android.dumprendertree.TestShellActivity;
import com.android.dumprendertree.TestShellCallback;

import java.io.InputStream;
import java.io.OutputStream;
import java.io.FileOutputStream;
import java.io.IOException;

class StreamPipe extends Thread {
    InputStream in;
    OutputStream out;
    
    StreamPipe(InputStream in, OutputStream out) {
        this.in = in;
        this.out = out;
    }
    
    public void run() {
        try {
            byte[] buf = new byte[1024];
            int nofb = this.in.read(buf);
            while (nofb != -1) {
                this.out.write(buf, 0, nofb);
                nofb = this.in.read(buf);
            }          
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
import java.io.PrintStream;

public class LoadTestsAutoTest extends ActivityInstrumentationTestCase2<TestShellActivity> {

@@ -92,35 +68,54 @@ public class LoadTestsAutoTest extends ActivityInstrumentationTestCase2<TestShel

        // TODO(fqian): let am instrumentation pass in the command line, currently
        // am instrument does not allow spaces in the command.
        runPostShellCommand("/system/bin/dumpsys meminfo");
        dumpMemoryInfo();

        // Kill activity
        activity.finish();
    }

    private void runPostShellCommand(String cmd) {
        if (cmd == null || cmd.length() == 0)
            return;
        
    private void dumpMemoryInfo() {
        try {
            // Call dumpsys meminfo
            Process proc = Runtime.getRuntime().exec(cmd);
            // Append output to LOAD_TEST_RESULT
            InputStream input = proc.getInputStream();
            InputStream error = proc.getErrorStream();
            FileOutputStream out = new FileOutputStream(LOAD_TEST_RESULT, true);
            Log.v(LOGTAG, "Dumping memory information.");

            StreamPipe p_in = new StreamPipe(input, out);
            StreamPipe p_err = new StreamPipe(error, System.err);
            
            p_in.start();
            p_err.start();
            
            proc.waitFor();
            FileOutputStream out = new FileOutputStream(LOAD_TEST_RESULT, true);
            PrintStream ps = new PrintStream(out);

            MemoryInfo mi = new MemoryInfo();
            Debug.getMemoryInfo(mi);

            //try to fake the dumpsys format
            //this will eventually be changed to XML
            String format = "%15s:%9d%9d%9d%9d";
            String pss =
              String.format(format, "(Pss)",
                  mi.nativePss, mi.dalvikPss, mi.otherPss,
                  mi.nativePss + mi.dalvikPss + mi.otherPss);
            String sd =
              String.format(format, "(shared dirty)",
                  mi.nativeSharedDirty, mi.dalvikSharedDirty, mi.otherSharedDirty,
                  mi.nativeSharedDirty + mi.dalvikSharedDirty + mi.otherSharedDirty);
            String pd =
              String.format(format, "(priv dirty)",
                  mi.nativePrivateDirty, mi.dalvikPrivateDirty, mi.otherPrivateDirty,
                  mi.nativePrivateDirty + mi.dalvikPrivateDirty + mi.otherPrivateDirty);

            ps.print("\n\n\n");
            ps.println("** MEMINFO in pid 0 [com.android.dumprendertree] **");
            ps.println("                   native   dalvik    other    total");
            ps.println("           size:    12060     5255      N/A    17315");
            ps.println("      allocated:    12060     5255      N/A    17315");
            ps.println("           free:    12060     5255      N/A    17315");
            ps.println(pss);
            ps.println(sd);
            ps.println(pd);
            ps.print("\n\n\n");
            ps.flush();
            ps.close();
            out.flush();
            out.close();
        } catch (IOException e) {
            Log.e(LOGTAG, e.getMessage());
        } catch (InterruptedException e) {
            Log.e(LOGTAG, e.getMessage());
        }
    }