繁体   English   中英

如何轻松单元测试Blackberry代码?

[英]How can I easily unit test Blackberry code?

对于我的大学课程,我们正在开发一个多线程Blackberry应用程序,它允许我们使用蓝牙扫描运行我们应用程序的其他设备,然后通过Wifi接口通过TCP传输文件,实现NAT遍历,同时记录我们的GPS位置。 (这是RIM赞助的计算机网络课程,如果还不明显的话。)

我喜欢测试驱动开发,并且正在用它来开发我的家庭作业。 但是,由于非法修饰符,我在测试期间扩展或以其他方式调用的任何Blackberry类都会给出一个ClassFormatError 我认为这个错误是由于带有Blackberry代码的jar必须是专门为其专有JVM编译的。

到目前为止,我已经使用代理模式并实现了代理的模拟对象 然而,由于我继承了许多原生Blackberry类,因此这变得非常繁琐。

我还想避免在可能的情况下启动Blackberry模拟器。 启动它可能需要几分钟,这对单元测试来说是不切实际和烦人的。

有没有简单的方法来单元测试我的Blackberry代码?

样机测试

你是关于模拟的正确方法,但我不建议你在J2SE平台上测试Blackberry功能。 我认为应该使用代理和模型,以防本机源中没有可用的测试数据,例如:

“扫描其他设备” - 没有其他设备,但你想测试扫描功能
“通过Wifi界面的TCP” - 你想在Storm上测试它(没有WiFi)
“记录我们的GPS位置” - 设备位置是静态的,但您想测试其他位置

然后你可以使用Blackberry平台模拟这样的功能:
黑莓GPS位置样机

您仍然可以使用相同的名称和签名从头开始在J2SE上重现BlackBerry API类。 那假定您必须自己实现所有类功能。

在没有模拟器的情况下测试j2me

这将是一个非常好的选择,但到目前为止,我看不到如何做到这一点。

测试涉及应用程序运行,这涉及平台模拟。 如果没有运行整个UI模拟器,可以测试j2me代码,但我不知道。

您可以做的是在Java Standard Edition上测试一些业务逻辑,并尽可能减少代码更改。

你仍然需要在模拟器上运行平台相关的功能测试,但是你可以在一个应用程序中完成它,这将是一组单元测试,就像ChrisW已经说过的那样。 只需逐个运行测试方法并在屏幕上输出结果:
方法1 - 通过 - 0.03秒
方法2 - 通过 - 1.30秒
方法3 - 通过 - 0.25秒

J2MEUnit

http://j2meunit.sourceforge.net/

J2MEUnit是一个Java 2 Micro Edition(J2ME)库,包含J2ME应用程序的单元测试框架。 它基于原始JUnit的源代码,这是Java,J2SE标准(桌面)版本的成功单元测试框架。

使用J2MEUnit和Eclipse对J2ME应用程序进行单元测试
设置和学习J2MEUnit的快速教程

使用JMUnit

http://jmunit.sourceforge.net/

JMUnit是基于JUnit的Java ME(J2ME)的单元测试框架。 它具有以下功能:
- 适用于Sun仿真器和实际设备。
- 很小(即使在旧的MIDP 1.0设备上也可以运行测试)。
- 具有用于检查测试失败的全面Assert方法集合。
- 支持TestCases和TestSuite。
- 包括用于在连续构建中运行JMUnit测试的Ant任务。
- 性能监控类的灵感来自JUnitPerf。

编写和运行JMUnit测试

BUNIT

基于jmunit的RIM Blackberry单元测试库

http://sourceforge.net/projects/b-unittesting/
BlackBerry支持社区论坛:如何对我的Blackberry应用程序进行单元测试

额外

如何 - 使用BlackBerry Simulator自动进行测试

当我想对一些Windows Mobile代码进行单元测试时,我在模拟器/模拟器和/或设备本身上运行它们。

这是不切实际的,因为我不打算在实现每个测试/功能后启动一个需要近一分钟启动的模拟器。

我可以启动它,将软件加载到它上面,然后运行测试...让它运行...重新加载新的应用程序软件而不重新启动 ,然后重新运行它。 也许黑莓不允许这样做?

此外,我可以一次性运行一整套测试(无需在每个测试/功能之间重新启动)。 也许这与TDD不相容,如果你的习惯是:

  1. 写一个测试用例
  2. 运行它以确保它失败
  3. 写下实现
  4. 再次运行,以确保这次成功
  5. (如上所述重复下一个要实现的功能)

它可能会发生。 设备驱动程序例如:繁琐的调试,因为系统可能需要每次启动,因为如果它们有问题,它们会挂起系统,因为调试器不是用户友好的...这样的环境交互性较小,所以更加强调:

  • 第一次正确使用(所以你不必调试)
  • 一次实现(并编写测试并随后测试)更大(可能是整个)的功能块

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM