关闭

每个Java项目最重要的十件事

发表于:2010-3-23 10:17

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:未知    来源:51Testing软件测试网采编

#
java

  这是我在做每个项目时的明细表,我强烈建议您也这样做。原因是:(1)新的开发者很快的就能够加快这个项目的进程,(2)用户能够容易的安装你的产品,而且也很容易去维护。

  1.版本控制:应该说您需要有某种形式的版本控制系统。如今的版本控制系统应该选择Subversion ,您只需要一台服务器主机。开放源代码的项目时,我使用code.google.com ,商业项目时我使用Hosted-Projects 。Hosted-Projects,每月只需几美元,你在网上有一个备份。您需要检查你的repository,也包括所有的依赖库。

  2.命令行编译脚本:我大部分的时间都在用Eclipse,他可以为我做所有的编译,单元测试和代码覆盖(EclEmma)。不过您需要命令行脚本去不断的build(通常是使用Ant 脚本)。你的脚本应分为:

  (1)编译代码
  (2)编译测试
  (3)生成javadoc
  (4)运行测试与代码覆盖:我使用Emma 或cobertura。
  (5)生成报告:测试的通过/失败和覆盖
  (6)建立一个分布的JAR。

  3.连续Build:我见过很多项目,由于储存库的头部并没有被编译,导致无休止的生产力损坏。始终有一个规则,无论如何至少要让存储库编译(通过测试更为理想的)。使用持续集成服务器,例如cruisecontrol 或Hudson。我宁愿选择Hudson,因为安装它很简单,而且功能非常强大,为您的上层管理提供了很多很好的图形显示。您要连续获得JARs,javadoc,测试报告,覆盖面的报告它能提供生成的脚本。对于code-base的状态基本上没有疑议,如果你的老板想尝试最新的代码,他可以下载继续Build。

  4.自动分级推动:设置连续Build,如果测试通过就自动的将代码转到分级服务器。我通常会使用Tomcat 服务器,只需要更新Web-INF目录与最新的代码,Tomcat 就会自动的告知新的文件和刷新。这给了人们展示产品的平台。您可以让您的QA使用这个服务器,也可以使用单独的一个。我经常会有很多的自动化测试,所以我将网站直接给客户,并告诉他们这是“Alpha”服务器。这是非常有用的,当您的工作的一项功能完成,客户得到这一部分,对该功能的意见能给你正面的推动,如果到最后客户才能看到,项目就很难进行改变。

  5.测试和覆盖:即使您是新的自动化测试和单元测试,我仍建议你还是要按照清单上来做。自动化的测试个给下个阶段带来了整体的进步。您从自动化的测试得到的好处是巨大的,并且关于测试的介绍也出版了书籍,所以我们不在这里详细的讲解。

  6.默认的嵌入式Web服务器:如果您正在建设一个Web应用程序,我推荐Jeety 作为您的Web容器。Jetty 最酷的地方是您可以在您的main函数中新建服务。使用Tomcat时,你要导入一个war文件,并将它添加到Tomcat 的目录中,然后等待Tomacat “安装”,这样就会比较麻烦。但使用Jeety 您可以通过一个main函数开始您的应用(就像一个正常的桌面APP )并通过你的main函数来启动Jeety。您的开发者更容易去开发/调试,您的客户也更容易去部署。

  7.默认情况下嵌入式数据库没有什么比一个复杂的数据库安装说明更复杂。所以我使用一个嵌入式数据库,例如HSQLDB。在开发和测试中,我让系统采用一个内存数据库,然后我才使用这个数据库的硬盘版本。但在这两种情况下客户/开发做的没有不同,这是最重要的。如果生产环境需要大负载,我再提供命令行选项,切换到外部数据库如Oracle数据库。

  8.自动安装模式:应用程序启动的第一件事就检查schema是否安装。 如果没有它会自动安装模式。 我通常使用的Hibernate ,如果需要他会为我做所有的事,升级架构,以较新的版本。所以在数据库中我从来没有担心过架构问题。

  9.guice 依赖注入:如果您想要一个可维护性,可测性和容易理解的code-base,您需要使用依赖注入(DI)作为一个设计模式。一个自动化的DI框架,使您的工作更轻松。我使用guice我想这是最先进的DI投资,同样还有picocontainer 和spring 。

  10.易于安装/运行:现在考虑的是让顾客更容易的去尝试你的产品。我喜欢给我的客户看一个JAR文件,并告诉他们“双击”来启动JVM,Web服务器,数据库,安装架构,并推出网络浏览器(基于本地)。或您的应用通过Java Web Start开始,这样你就可以在web页面中一键式安装,这样就不需要安装手册了。

  a)把主要class放在JAR MANIFAST,这样只要双击就可以加载你的应用。

  b)把所有的JAR依赖放在主要的JAR文件中,使用JarJar或者One-Jar-Classloader 。

  c)给应用提供:内存数据;安装schema;加载Web的容器;安装自动提供一个amin用户等等……

  这给您带来了什么好处?您将有快乐和富有成效的开发流程和快乐的顾客,而且可以很容易为你的产品吸引到客户。

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号