专栏名称: 51Testing软件测试网
51Testing软件测试网,人气最旺的软件测试技术门户,提供软件测试社区交流,软件测试博客,人才服务,测试沙龙,测试杂志,测试资料下载等全方位信息服务,是国内最专业的软件测试就业培训、企业服务供应商...
目录
相关文章推荐
51好读  ›  专栏  ›  51Testing软件测试网

美好的一天,从解决一个诡异的小 Bug 开始!

51Testing软件测试网  · 公众号  · 测试  · 2017-03-27 17:30

正文


  一个困扰了我两天的 bug,今天终于算是解决了,其实就删了一个方法的调用,这里简单记录一下。

  App 所做的功能是视频播放,之前的大半年是运行在 Android 4.4.2 系统上的,上周换了新设备,搭载的 Android 5.1.1 系统,这个 bug 就出现了。有人纳闷,为什么之前没做系统适配,到现在才发现问题,这里我只能告诉你,公司的产品做的是某种设备的定制开发,专门用在一个行业用的。想必这么说就明白了。

  表现的问题是新设备上无法播放视频了,Log 信息是:

  libijkffmpeg.so: unused DT entry: type 0x6ffffffe arg 0x4cac4

  ...

  libijkffsdl.so: unused DT entry: type 0x6ffffffe arg 0xe42c

  ...

  libijkplayer.so: unused DT entry: type 0x6ffffffe arg 0x9410

  ...

  J4ALoader: Ignore: 'android.media.PlaybackParams' need API 22

  ...

  这里贴张图:

  ijkplayer Log

  这些 Log 指向了 libijkplayer 相关的 so 文件的问题,

  首先再次引入了 ijk 相关的 so 文件,gradle 文件里相关配置都做了,仍不行,网上浏览了多篇加载 so 文件的文章,反复确认加载过程无误。

  其次在 Google、GitHub issues、Stack Overflow 等等找寻解决方法,git 上虽有类似问题的字眼,但也无具体的解决办法,有的也是清理工程,重新编译,自然又好了。。。WTF...

  这一天就过去了......

  第二天再折腾,还是各种无解。中午老大问那个问题好了吗,不行的话就重新找个播放器框架。纳尼,再找个新的合适的框架谈何容易,这个在去年试了多少框架,踩了多少坑才做好的,再重新做,又得重构代码结构了。当然我只是淡淡的回了个“哦”。

  说什么也不甘心,必须把它整好了。还有即将在这家公司离职了,不能留着这个遗憾离开啊,说我能力不行搞不定离开的。O(∩_∩)O哈哈~

  一步一步分析,多种情况下查看现象和 Log,还是一样的结果。喝杯茶,换换脑子 ~,起身到外面溜达了一圈,有了一个 idea,好吧,重新建个工程,仍用此框架做视频播放,要是还不行,那就是设备真不支持这个框架,只能放弃了。哎呀 ~ 竟然可以播放了。有希望了~~

  比较两个工程不同的地方,gradle 配置文件,播放流程等等,最后发现了是个过渡动画的地方不一致。直接去了,不用动画了,要啥自行车!!果然好了,能播放了。

  到此时也就知道了为什么不能播放视频了,其实跟 ijk 的 so 库有没有加载没有关系,Log 的信息引导错了问题调查的方向,不过也不能怪 Log 有问题,还是我们自己的失误丢失了某些东西。我的问题是只在播放界面做了要实现怎样的动画,而没在前一个界面做跳转时为其指定。下面贴出要实现的正确代码。

  step 1. 跳转前

  Intent intent = new Intent(context, GSYPlayerActivity.class);

  intent.putExtra(GSYPlayerActivity.TRANSITION, true);

  if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {

  Pair pair = new Pair<>(mBtnOpenVideo, GSYPlayerActivity.IMG_TRANSITION);

  activityOptions = ActivityOptionsCompat.makeSceneTransitionAnimation(

  context, pair);

  ActivityCompat.startActivity(context, intent, activityOptions.toBundle());

  } else {

  context.startActivity(intent);

  context.overridePendingTransition(R.anim.abc_fade_in, R.anim.abc_fade_out);

  }

  step 2. 跳转后,在过渡动画里开始播放(videoPlayer.startPlayLogic())

  ...

  isTransition = getIntent().getBooleanExtra(TRANSITION, false);

  ...

  private void initTransition() {

  if (isTransition && Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

  postponeEnterTransition();

  ViewCompat.setTransitionName(videoPlayer, IMG_TRANSITION);

  addTransitionListener();

  startPostponedEnterTransition();

  } else {

  videoPlayer.startPlayLogic();

  }

  }

  @TargetApi(Build.VERSION_CODES.LOLLIPOP)

  private boolean addTransitionListener() {

  transition = getWindow().getSharedElementEnterTransition();

  if (transition != null) {

  transition.addListener(new OnTransitionListener() {

  @Override

  public void onTransitionEnd(Transition transition) {

  super.onTransitionEnd(transition);

  videoPlayer.startPlayLogic();

  transition.removeListener(this);

  }

  });

  return true;

  }

  return false;

  }

  看到这里,应该懂动画的该吐槽我了。望轻吐,我承认我对此了解不深~~

  好了写完这篇文章,我要去补一补动画这块的知识了~

  最后总结一下吧:

  • 还是解决 bug 的技巧:首先定位问题表现,看看规律,排除其他外部干扰,之后断点跟踪···

  • 对待 bug 有点耐心,抱怨的心态永远解决不了问题。

  • 使用第三方框架认真理解作者的源码,出问题了对比原作的 simple,看自己丢了什么,大不了再新建工程重新来过。为什么别人都没问题就你的出问题了,先找自己的原因。

  解决 bug,任重而道远......

 
推荐阅读

点击阅读☞分层设计与分层测试

点击阅读☞一个腾讯员工的面经分享,教你如何进名企!

点击阅读☞测试开发之路:一个小小软件测试工程师的回首

点击阅读☞中小企业如何开展自动化测试?

点击阅读☞浅谈研发测试团队的定位及意义

点击左下角“阅读原文”查看更多内容!