Skip to content

Commit

Permalink
Merge pull request NetEase#14 from NetEase/feature/start_time
Browse files Browse the repository at this point in the history
Merge Feature/start_time in master
  • Loading branch information
bingohuang committed Dec 23, 2013
2 parents 1e26fa7 + 1d89a09 commit ab8e504
Show file tree
Hide file tree
Showing 2 changed files with 84 additions and 3 deletions.
6 changes: 6 additions & 0 deletions src/com/netease/qa/emmagee/activity/MainPageActivity.java
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,12 @@ public void onClick(View v) {
Intent intent = getPackageManager()
.getLaunchIntentForPackage(packageName);
Log.d(LOG_TAG, packageName);
//clear logcat
try {
Runtime.getRuntime().exec("logcat -c");
} catch (IOException e) {
Log.d(LOG_TAG, e.getMessage());
}
try {
startActivity(intent);
} catch (NullPointerException e) {
Expand Down
81 changes: 78 additions & 3 deletions src/com/netease/qa/emmagee/service/EmmageeService.java
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,16 @@
*/
package com.netease.qa.emmagee.service;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
Expand Down Expand Up @@ -117,6 +121,13 @@ public class EmmageeService extends Service {
private CurrentInfo currentInfo;
private BatteryInfoBroadcastReceiver batteryBroadcast = null;

// get start time
private static final int MAX_START_TIME_COUNT = 5;
private static final String START_TIME = "#startTime";
private int getStartTimeCount = 0;
private boolean isGetStartTime = true;
private String startTime = "";

@Override
public void onCreate() {
Log.i(LOG_TAG, "onCreate");
Expand Down Expand Up @@ -250,13 +261,14 @@ private void createResultCsv() {
File resultFile = new File(resultFilePath);
resultFile.createNewFile();
out = new FileOutputStream(resultFile);
osw = new OutputStreamWriter(out, "GBK");
osw = new OutputStreamWriter(out, "UTF-8");
bw = new BufferedWriter(osw);
long totalMemorySize = memoryInfo.getTotalMemory();
String totalMemory = fomart.format((double) totalMemorySize / 1024);
bw.write("指定应用的CPU内存监控情况\r\n" + "应用包名:," + packageName + "\r\n" + "应用名称: ," + processName + "\r\n" + "应用PID: ," + pid + "\r\n"
+ "机器内存大小(MB):," + totalMemory + "MB\r\n" + "机器CPU型号:," + cpuInfo.getCpuName() + "\r\n" + "机器android系统版本:,"
+ memoryInfo.getSDKVersion() + "\r\n" + "手机型号:," + memoryInfo.getPhoneType() + "\r\n" + "UID:," + uid + "\r\n");
+ memoryInfo.getSDKVersion() + "\r\n" + "手机型号:," + memoryInfo.getPhoneType() + "\r\n" + "UID:," + uid + "\r\n"
+ "启动时间:," + START_TIME + "\r\n");
bw.write("时间" + "," + "应用占用内存PSS(MB)" + "," + "应用占用内存比(%)" + "," + " 机器剩余内存(MB)" + "," + "应用占用CPU率(%)" + "," + "CPU总使用率(%)" + ","
+ "流量(KB)" + "," + "电量(%)" + "," + "电流(mA)" + "," + "温度(C)" + "," + "电压(V)" + "\r\n");
} catch (IOException e) {
Expand Down Expand Up @@ -351,8 +363,11 @@ public void run() {
if (!isServiceStop) {
dataRefresh();
handler.postDelayed(this, delaytime);
if (isFloating)
if (isFloating) {
windowManager.updateViewLayout(viFloatingWindow, wmParams);
}
// get app start time from logcat on every task running
getStartTimeFromLogcat();
} else {
Intent intent = new Intent();
intent.putExtra("isServiceStop", true);
Expand All @@ -363,6 +378,39 @@ public void run() {
}
};

/**
* Try to get start time from logcat.
*/
private void getStartTimeFromLogcat() {
if (!isGetStartTime || getStartTimeCount >= MAX_START_TIME_COUNT) {
return;
}
try {
// filter logcat by Tag:ActivityManager and Level:Info
String logcatCommand = "logcat -v time -d ActivityManager:I *:S";
Process process = Runtime.getRuntime().exec(logcatCommand);
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(process.getInputStream()));
// StringBuilder strBuilder = new StringBuilder();
String line = "";

while ((line = bufferedReader.readLine()) != null) {
// strBuilder.append(line);
// strBuilder.append("\r\n");
if (line.matches(".*Displayed.*\\+(.*)ms.*")) {
// TODO:regular pattern:Activity,startTime
startTime = line.substring(line.lastIndexOf("+") + 1, line.lastIndexOf("ms") + 2);
Toast.makeText(EmmageeService.this, "启动时间:" + startTime, Toast.LENGTH_LONG).show();
isGetStartTime = false;
}
}
getStartTimeCount++;
// Log.w(LOG_TAG, "Start Time Log:" + strBuilder.toString());
// Log.w(LOG_TAG, "getStartCount:" + getStartTimeCount);
} catch (IOException e) {
Log.d(LOG_TAG, e.getMessage());
}
}

/**
* refresh the performance data showing in floating window.
*
Expand Down Expand Up @@ -447,6 +495,8 @@ public void onDestroy() {
windowManager.removeView(viFloatingWindow);
handler.removeCallbacks(task);
closeOpenedStream();
// replace the start time in file
replaceFileString(resultFilePath, START_TIME, startTime);
isStop = true;
unregisterReceiver(batteryBroadcast);
boolean isSendSuccessfully = false;
Expand All @@ -465,6 +515,31 @@ public void onDestroy() {
stopForeground(true);
}

/**
* Replaces all matches for replaceType within this replaceString in file on the filePath
* @param filePath
* @param replaceType
* @param replaceString
*/
private void replaceFileString(String filePath, String replaceType, String replaceString) {
try {
File file = new File(filePath);
BufferedReader reader = new BufferedReader(new FileReader(file));
String line = "", oldtext = "";
while ((line = reader.readLine()) != null) {
oldtext += line + "\r\n";
}
reader.close();
// replace a word in a file
String newtext = oldtext.replaceAll(replaceType, replaceString);
BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(filePath), "UTF-8"));
writer.write(newtext);
writer.close();
} catch (IOException e) {
Log.d(LOG_TAG, e.getMessage());
}
}

@Override
public IBinder onBind(Intent intent) {
return null;
Expand Down

0 comments on commit ab8e504

Please sign in to comment.