- 浏览: 557424 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (401)
- 默认类别 (1)
- AJAX (0)
- Coffee House (81)
- cvs (1)
- cygwin (2)
- Eclipse (1)
- EJB (0)
- ERP (1)
- Hibernate (16)
- Html (8)
- iBatis (0)
- IDE (0)
- J2SE (7)
- Javascript (11)
- Jboss (0)
- Jdbc (4)
- Jni--Communication (1)
- Management (10)
- NetWork (0)
- Oracle (0)
- PowerDesigner (0)
- Proxool (1)
- Question (0)
- SoftwareEngineering (12)
- Spring (13)
- SqlServer (22)
- Struts (0)
- Tutorial (1)
- VFP (0)
- Web Service (0)
- WebWork (6)
- WSAD (1)
- test (1)
最新评论
-
zyp731:
虽然很简单,但是很适用,我就找了好久,非常不喜欢大黑点的那种样 ...
ERWIN改变关系之间连线的样式 -
Love_洋果子:
写的很实在,我们老总及老大就很注重测试部门,所以自己做的很开心 ...
再谈测试 -
娴静女生:
2010年开始用新浪微博ID:http://t.sina.co ...
微博大家在写吗? -
saapaa:
hgq0011 写道 大家有开通微博吗?
...
微博大家在写吗? -
lxtxlyb:
文章太给力了,但是我现在有个问题,同一个tomcat下面,其他 ...
spring+hibernate初始化出错,错误真是隐蔽得很,让人郁闷,,,
软件开发是一项非常复杂的工程,每一个环节都容不得半点的马虎,否则前功尽弃,后悔莫及。需求分析如果没有做到位,很有可能导致做出来的东西不是用户想要的功能;开发如果不严谨,很有可能产生非常隐蔽的bug,测试过程也没有测试出来,导致用户在使用过程中有问题,报障平台越来越多的故障;测试如果不完整,只限于表面的测试,复杂的业务逻辑没有深入的测试,也会导致上线、升级失败。
早两天的升级,由于核心的算法有问题,导致全网用户使用过程中出现问题,给顾客带来很大的损失,我们遭到顾客的投诉。今天的故障越来越多,同事分析了一个故障,根据日志分析,说明是我程序有问题。我当时也很纳闷,明明在测试环境是没有问题的,有点不大可能的感觉,但既然问题出来了,我们一定要认真的对待,去找到问题的根源,避免造成更大的损失,给团队带来负面影响。下午,我仔细的分析了日志,也仔细的把核心算法看了一下,凭直觉这个情况是会发生,然后在测试环境模拟,真的会产生这个问题。我对问题进行了修复,发出邮件提出相关建议和程序更新包。
领导看到我邮件,也非常的重视此事,鉴于问题非常严重今晚务必把问题解决了,并且升级系统。其他同事也在想是否在其它的情况,还会出现问题。果然,经过大家的结合业务分析,可能还会有些情况没有考虑全面。此时,我们继续完善我们的测试案例,把相关的情况都考虑进去了。我一边修改我的代码,一边做单元测试和功能测试。我这边没有问题了,提交给测试同事测试,经过反复测试,确保没有问题。我们对一些影响非常大的点,进行了升级,目前没有什么问题了。这个时候我才真的松了一口气,当时的压力非常大,提醒自己一定要冷静,要清醒,问题一定要修复,解决。
回顾整个事情,我的开发过程中存在了逻辑问题,有些情况没有考虑的周全,写代码还是要沉下心来写,不要急躁,不要浮燥。测试也出现了问题,没有一个完整的测试案例作为指导,测试人员也不知道,到底要怎样测试,才能覆盖整个代码。我们一次又一次的测试,每一次的业务需求都要准备全面的测试案例,这样我们才能确保,我们的程序是高可用的,用户满意的。
评论
时间相对宽松才行,关键是看上级的素质,有些根本就不懂,认为开发+测试=开发。
编程人员基于传统的单元测试的书本知识来写测试是作用很有限的。当你花很长时间(比如2天)写下功能代码,然后再考虑写单元测试,这时候写出的所谓单元测试往往是限于你的编程思路中,其实是重复无用的东西。传统的测试只好纠缠于所谓覆盖率问题,让人难以自拔。
这是因为传统的单元测试思路的所谓“单元”,纠缠于个别功能代码,而不是反映需求。
我觉得我们的项目不是简单的单元测试。应该也包括功能测试,集成测试,回归测试。
由于当前只是满足业务部门,对功能进行调整,也就是修改原有代码。单元的测试时间不会间隔那么长时间的,每前进一点就会测试的。我想请问的是关于用例覆盖率,怎样才能够做好测试,做好案例覆盖,您有什么好的见解呢?我个人觉得回归测试就是要每一个每一功能都要测试,每一个案例都要覆盖到,才能够保障软件的可用。
敏捷开发强调是先写测试,用测试来驱动出设计思路,测试代码是针对设计而不是针对你的实现代码!这是非常关键的。由于是比较高层次的测试思路(即根本不考虑你的实现代码),当你写30个纯粹为了驱动出设计才写的测试,并且每10分钟之内就回归一次(每一次自动随机产生测试数据),那么这些测试之间相互牵制就会发现大量深层次bug。特别是,要打乱测试顺序、并且可能的话开100个线程并发测试,可以发现大量深层次bug。
您说的测试驱动设计,来指导开发。当然非常好。但是,我们的系统不是简单的可以模拟随机数,就可以测试的。系统要和第三方的设备通讯,所以测试比较复杂。我觉得您说的“当你写30个纯粹为了驱动出设计才写的测试”也是测试案例的一种体现。如果你所说的30个为测试驱动设计的测试,能够把所有的情况考虑到,那么把它转换成测试人员的测试案例,那么也能够保障软件是可用的。
核心的观念是:1.测试不是用来证明你的实现代码的,测试应该驱动设计的。2. 测试应该每1~10分钟进行一次(你可以选择大部分时间仅执行最近7天的测试,但是每天也要至少进行5次全面回归测试)。3. 在有任何编程想法前都坚持先写测试然后才实现,而不是相反。4. 你编程每一个1个小时都应该写下一个测试,而不是2、3天才写一个测试。5.一个项目的测试驱动必须达到一定强度,也许100也许3000,总之不会很少。
真正的测试驱动开发,轻松、自然、有趣,你会有勇气去修改自己的代码,有勇气让别人随时修改你自己的代码,有勇气随时(闲时)重构系统结构。看似摸着石头过河,实则永远追求统一。你不再盲目纠缠于理论,不再简单地靠过分纠缠理论的是是非非来“保证”你的代码的正确性。
不但对于功能代码,对于GUI也要自动化测试。一个基本的原则是:如果你的代码注释掉了之后仍然可以让自动测试程序通过,那么就说明这些未经测试驱动的代码就是有毒的代码早就应该删掉。
要想进行测试驱动开发,首先要抛开传统的单元测试观念。
您所在的公司都是这样开发的?那真的很羡慕,很幸福。
能请教你们怎样实现自动化测试?我觉得非常的有难度。
其实很难,特别是实施起来。TDD太消耗时间咯
其实,也存在性价比的权衡?
没有完美的办法,事实上,单元测试有时候没有一点用。但是不能没有,没有的话,心里没有底。
主要我觉得还是集成测试用例的覆盖度,可是不可能完全OK,在开发代码的同时,需要开发人员自信测试,比如不同的操作系统,浏览器(如果是Web程序的话)。最后是,知识库的归档,包括Troubleshooting,开发技巧等等。
省力更省心。哈哈。还能通一通多年的老便(pian)秘
mock1234 常年在 javaeye上宣传TDD,是个好同志啊
成本很低,
自动测试机器人很多, 随便弄一个合适的, 写一些简单的脚本就可以了.
你这种只适合节约劳动力的那种。如果有非常复杂的业务逻辑的,要经过人工干预的,那就不适合了。
成本很低,
自动测试机器人很多, 随便弄一个合适的, 写一些简单的脚本就可以了.
没关系,向前看。
在这bug的解决上,你做了很多的工作,并解决了问题。
如果你能在这件事上让你的领导看到你分析解决问题的能力,而不是一个处处要人替你擦屁股的人。那么你就是得大与失的。谁没犯过错啊(但也不能老犯)。
无论如何,你在此次的经历,会让你受益良多。
是的,我也觉得我的压力蛮大的。
因为我不但要负责这个系统业务需求的更新,BUG的修改工作。而且负责另外一个项目的技术工作,这个也是公司今年最大的项目,实施最困难的一个。目前,还有很多的问题待解决。
我也觉得我应该向前看,要乐观与豁达,虽然我不善于插鞋,但我依然尽最大的努力,饱满的热情投入到工作中,完成项目。在项目中获取更多的快乐,更多的经验。项目成功后,也可以感到自豪,感到欣慰,那么多网点都在用我们的系统。:)
没关系,向前看。
在这bug的解决上,你做了很多的工作,并解决了问题。
如果你能在这件事上让你的领导看到你分析解决问题的能力,而不是一个处处要人替你擦屁股的人。那么你就是得大与失的。谁没犯过错啊(但也不能老犯)。
无论如何,你在此次的经历,会让你受益良多。
但几乎所有程序员都会以工作量大,deadline紧等客观存在理由来规避责任。
其实如老板懂行的话就明白有bug是正常的,产品有缺陷主要是QA的责任,不全是程序员的责任。
大家都知道自己查自己的代码是不可能找到全部bug的。
如果老板不懂这些或对你有了成见。 两条路:咬牙忍了,与老板沟通;或跳槽,让他另请高明。
(另加据题外话,与老板搞好关系在任何时间地点都是非常重要的,有时比技术还重要)
需求是大方向的描叙,整体的功能当然没有问题。因为系统比较复杂,有一种情况我没有考虑周全,导致系统有BUG。
经过观察,我觉得领导的意思是把责任定位在我身上。
第一:第二天我的大领导发邮件关于昨天故障的问题。中午时候碰到他,他说邮件不是针对我的,是针对整个团队的。
第二:我的直接领导对我说--你看领导发话了,你看我多被动了。
第三:在聚餐上,我平时不喝酒。但那天领导那桌,同事叫我过去喝。我也有意想借此机会,向协助完成工作的同事表示谢意。我和大领导和了小半杯红酒,领导说:做事要注意方式方法。我点头应允。然后又和其他同事每人干了一小杯。我有点醉意了。
我应该汲取教训,尽量的规避这些事情。
但几乎所有程序员都会以工作量大,deadline紧等客观存在理由来规避责任。
其实如老板懂行的话就明白有bug是正常的,产品有缺陷主要是QA的责任,不全是程序员的责任。
大家都知道自己查自己的代码是不可能找到全部bug的。
如果老板不懂这些或对你有了成见。 两条路:咬牙忍了,与老板沟通;或跳槽,让他另请高明。
(另加据题外话,与老板搞好关系在任何时间地点都是非常重要的,有时比技术还重要)
第三方QA可以是客户雇来验收你们的产品,也可以是你们自己雇来保证代码质量。
做产品的追求质量是对的,但也得有个成本限度。
(其实那是老板考虑到问题,
程序员嘛,保证自己的饭碗,
从工作中学到东西这两点才是要关心的)
自己权衡吧。
很多公司用第三方QA的。
第三方?那出了问题谁负责呢?
很多公司用第三方QA的。
bugfree只有天堂里才有。
Agile的特性之一是迅速反应,fix the bug, 而不是bug free.
楼主不要过分追求完美了。
时间长了你就会发现,很多时候你很紧张的bug,你老板却不当回事。
小bug当然没有问题,但是bug造成公司损失,顾客利益受到伤害,那就非常的严重和危险了。所以我们要有策略性的应对,去解决我们开发,部署过程中的问题,规避风险。
bugfree只有天堂里才有。
Agile的特性之一是迅速反应,fix the bug, 而不是bug free.
楼主不要过分追求完美了。
时间长了你就会发现,很多时候你很紧张的bug,你老板却不当回事。
小bug当然没有问题,但是bug造成公司损失,顾客利益受到伤害,那就非常的严重和危险了。所以我们要有策略性的应对,去解决我们开发,部署过程中的问题,规避风险。
bugfree只有天堂里才有。
Agile的特性之一是迅速反应,fix the bug, 而不是bug free.
楼主不要过分追求完美了。
还有,做测试的与写代码的不应该都是你吧。
各个公司情况不同,很多时候你很紧张的bug,你老板却不当回事。
编程人员基于传统的单元测试的书本知识来写测试是作用很有限的。当你花很长时间(比如2天)写下功能代码,然后再考虑写单元测试,这时候写出的所谓单元测试往往是限于你的编程思路中,其实是重复无用的东西。传统的测试只好纠缠于所谓覆盖率问题,让人难以自拔。
这是因为传统的单元测试思路的所谓“单元”,纠缠于个别功能代码,而不是反映需求。
我觉得我们的项目不是简单的单元测试。应该也包括功能测试,集成测试,回归测试。
由于当前只是满足业务部门,对功能进行调整,也就是修改原有代码。单元的测试时间不会间隔那么长时间的,每前进一点就会测试的。我想请问的是关于用例覆盖率,怎样才能够做好测试,做好案例覆盖,您有什么好的见解呢?我个人觉得回归测试就是要每一个每一功能都要测试,每一个案例都要覆盖到,才能够保障软件的可用。
敏捷开发强调是先写测试,用测试来驱动出设计思路,测试代码是针对设计而不是针对你的实现代码!这是非常关键的。由于是比较高层次的测试思路(即根本不考虑你的实现代码),当你写30个纯粹为了驱动出设计才写的测试,并且每10分钟之内就回归一次(每一次自动随机产生测试数据),那么这些测试之间相互牵制就会发现大量深层次bug。特别是,要打乱测试顺序、并且可能的话开100个线程并发测试,可以发现大量深层次bug。
您说的测试驱动设计,来指导开发。当然非常好。但是,我们的系统不是简单的可以模拟随机数,就可以测试的。系统要和第三方的设备通讯,所以测试比较复杂。我觉得您说的“当你写30个纯粹为了驱动出设计才写的测试”也是测试案例的一种体现。如果你所说的30个为测试驱动设计的测试,能够把所有的情况考虑到,那么把它转换成测试人员的测试案例,那么也能够保障软件是可用的。
核心的观念是:1.测试不是用来证明你的实现代码的,测试应该驱动设计的。2. 测试应该每1~10分钟进行一次(你可以选择大部分时间仅执行最近7天的测试,但是每天也要至少进行5次全面回归测试)。3. 在有任何编程想法前都坚持先写测试然后才实现,而不是相反。4. 你编程每一个1个小时都应该写下一个测试,而不是2、3天才写一个测试。5.一个项目的测试驱动必须达到一定强度,也许100也许3000,总之不会很少。
真正的测试驱动开发,轻松、自然、有趣,你会有勇气去修改自己的代码,有勇气让别人随时修改你自己的代码,有勇气随时(闲时)重构系统结构。看似摸着石头过河,实则永远追求统一。你不再盲目纠缠于理论,不再简单地靠过分纠缠理论的是是非非来“保证”你的代码的正确性。
不但对于功能代码,对于GUI也要自动化测试。一个基本的原则是:如果你的代码注释掉了之后仍然可以让自动测试程序通过,那么就说明这些未经测试驱动的代码就是有毒的代码早就应该删掉。
要想进行测试驱动开发,首先要抛开传统的单元测试观念。
您所在的公司都是这样开发的?那真的很羡慕,很幸福。
能请教你们怎样实现自动化测试?我觉得非常的有难度。
其实,也存在性价比的权衡?
发表评论
-
百万级数据能这么干
2010-11-18 18:08 2405今天一上午就和供应商展开了激烈的火拼. 我作为 ... -
最痛苦的调试
2010-04-19 22:38 530我们的项目需要多方供应商的合作,有底层硬件的开发,有 ... -
再谈测试
2010-04-15 00:10 891我毕业刚出来 ... -
[转载]软件项目开发正确的验收方法
2008-12-21 16:17 2362来自http://www.szedu.com.cn/z ... -
系统性能调优感悟
2008-10-20 19:03 596很惭愧我们的系统在UAT时,常常出现数据库进程死锁的现 ... -
工期逼近,释放压力
2008-05-03 23:27 1678现在我们几乎天天加班(星期天休息),为了赶时间,为了能 ... -
系统开发和应用系统检查流程图
2008-02-13 14:18 1879最近公司各部门都在整理部门的流程,所以我也就画了开 ... -
系统上线感悟
2007-08-07 22:13 3899... -
私活就那么难搞定吗?
2007-05-13 11:38 19124... -
项目(框架)架构的抉择
2006-11-17 13:25 4834项目(框架 ... -
开发效率的挑战
2006-10-30 15:57 1254开发效率的挑战 早些天一同事让我帮它开发一个客户资料管理系统 ...
相关推荐
- 构建稳定可靠的智能浇花系统需要大量的测试和验证,这对算力和算法提出了较高要求。 - 利用先进的机器学习算法对花卉生长环境进行预测和优化,提高系统性能。 3. **商业化前景**: - 这样的智能养花解决方案...
在网络普及的今天,网上购物因其价低,省心,便利......受到越来越多网民的青睐。淘宝网作为中国最大的C2C网购网站,其丰富的商品,多彩的种类,透明的价格......给了网购用户更多的选择,是目前...省心、省力、省钱。
★一键式操作,省心省力 ★体积小,极速室秒级启动,极速反应,强大功能★定时|热键|系统条件触发的自动任务★定时备份/同步,支持文件,文件夹,系统文件夹,注册表★100+种任务类型,20+种定时/条件执行方法★任务...
用于升级,很好用用于电脑的快速升级工具一个可以让人省心省力的电脑助手
"小强多个模版替换为你发布信息省心省力"这个标题暗示了一个工具或软件,它的主要功能是帮助用户快速地进行多模板替换操作,从而简化信息发布的流程。 模版替换的基本原理是创建一个或多个预设模板,这些模板包含...
通过上述方法,我们可以轻松实现数字小键盘在开机时自动启动,这对于频繁使用数字输入的用户而言,无疑是一种既省力又省心的优化措施。不过,为了确保操作的安全性和准确性,执行任何注册表修改前,请确保充分了解其...
在IT行业中,社交媒体管理工具是不可或缺的一部分,特别是对于个人用户来说,如何高效地管理自己的社交网络账号至关重要。本文将详细探讨“新浪微博批量删关注工具”的相关知识点,帮助用户更好地理解和利用此类工具...
省心电脑挂机锁是杭州恒溢信息科技股份有限公司开发的一款用于电脑挂机锁屏的免费软件,主要功能如下: 一: 提供多种锁屏挂机方式,1 手动挂机锁屏,输入密码后直接挂机锁屏,2 设置热键挂机锁屏,进入设置热键界面后...
burp suite(省心版)
省心锁屏软件是挂机锁中一款非常优秀的挂机并锁屏的软件,它可以设定锁屏时间,锁屏组合键,及电脑不操作多长时间自动锁定,可自定义锁屏图片及文字,所有的设置保存以后无须再设置。电脑启动时会同时启动帮你管理你...
省心锁屏软件是电脑锁屏软件中一款非常优秀的锁屏软件,它针对挂机用户设计的,当用户要离开电脑时软件会自动帮你锁定你的电脑防止别人非法进入,它可以设定锁屏时间,锁屏组合键,及电脑不操作多长时间自动锁定,所有的...
一个是文件夹加密大士,一个是文件夹加密高级版,(另提供“省心文件加密普通版”下载地址) 文件夹加密大士: 1: 我们提供5种加密方式,让你的加密方式灵活多样, 2: 我们提供强大的急救功能,只要你在加密的...
好用又省心的魔豆路由器.pdf
千万妈妈超省心的家教指南(完结)" "本畅销全球的家教书单, 千万妈妈超省心的家教指南(完结)" "本畅销全球的家教书单, 千万妈妈超省心的家教指南(完结)" "本畅销全球的家教书单, 千万妈妈超省心的家教指南...
CASS插件面积标注 省心
### 多种停车场管理系统共同发力,让停车省心又便捷 随着社会经济的快速发展和人民生活水平的不断提高,汽车已经成为很多家庭必备的交通工具之一。然而,随之而来的停车难问题也日益凸显,尤其是在城市中心区域。...
1. 从另一分支切换单个文件 大家是否曾销毁文件只为能重新开始? 或需要在另一分支的某文件中进行更改?而git指令可以实现从另一分支切换文件。 git checkout some-other-branch — yarn.lock 同时,也可以使用相同的...
随着信息技术的飞速发展,个人电脑已经成为...在这个数字化时代,每个人都应该注重自己的数据安全,而“省心挂机锁”正是一个值得推荐的选择,它不仅使我们的信息安全得到保障,也让我们的数字生活变得更加便捷和省心。
Windows下的MDK Keil ...设定后定时信息后交由freeRTOS自己调度,省心省时省力。 工程方面已经集成了freeRTOS的源码及相关定时器的使用示例,配合博文《FreeRTOS 体验教程:9.FreeRTOS的定时器初体验》食用效果更佳。