您还未登录! 登录 | 注册 | 帮助  

您的位置: 首页 > 软件测试管理 > 缺陷管理 > 正文

记一个Android Installer的Bug

发表于:2017-01-09 作者:网络转载 来源:

  此Bug,经测试截止到Android在5.0版本上都还没有解决。并且一些大厂的APP,比如新浪微博都会有此问题。
  问题现象:
  用Android系统自带的Installer安装完应用后,会有以下两个不同表现:
  1,用户直接在installer界面打开应用。然后按home键后台运行,此时如果再点击该应用的launcher图标或者快捷方式进入,会发现该应用又会从该应用第一个页面重新开始启动。
  2,用户在installer界面安装完后,直接点击完成,然后找到launcher图标点击启动应用。此时按home键后台,再次点击图标进入,发现应用会呈现上次按home键前呈现的Activity。
  测试实验:
  经测试发现,只要是从一个应用去启动另一个应用,都会有此问题,以下我会用一个例子说明。
  现有App1和App2.
  App1中有一个Activity,有如下代码去打开App2.
  PackageManager packageManager = getPackageManager();Intent intent;
  intent = packageManager.getLaunchIntentForPackage("cc.ninty.app2");
  if(intent==null) {
  System.out.println("APP not found!");
  }
  startActivity(intent);
  App2中有两个Activity,Activity1和Activity2,用Activity1去自动startActivity2.
  以上三个Activity的launch mode都为默认的standard。此时执行App1,并监控这三个Activity的taskid。
  可以发现通过App1启动的App2中的两个Activity的taskid与App1不同,并且以后每次点击APP2的launcher图标都会发现Activity1和Activity2又会被重新创建一次,并且taskid与前一次相同。
  问题原因:
  Android从最初开始一直有次bug并且一直未修复,以下是找的一些资料。
  https://code.google.com/p/android/issues/detail?id=2373
  https://code.google.com/p/android/issues/detail?id=26658
  http://stackoverflow.com/questions/16283079/re-launch-of-activity-on-home-button-but-only-the-first-time/16447508#16447508
  规避方案:
  因第二次通过launcher或者快捷方式启动应用,会重新创建Activity1,但此时的Activity1不是该task的root(也即该task第一个拥有的activity),所以可以通过在Activity1的onCreate方法中写以下判断:
  if ( !isTaskRoot() )  {
  finish();
  return;
  }
  表示如果task中还有其他Activity则不进行重复创建。