`
yanhua
  • 浏览: 89060 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

QClub的测试专题活动和奇遇咖啡的rails活动小记

阅读更多

昨天下午去参加了infoq组织的qclub,是百度赞助的,第一个讲座是百度的工程师讲解“自动化web测试”,我到的稍微晚了一些,没听完整,大概了解了一下的一些信息:

 

  • 底层使用的是selenium框架,之上有做了一些封装,做了一个框架,还有一个ide,可以用比较接近自然语言的方式定义测试用例。比较有特色的是有一个UIMap,把一些比较可能变化的部分放入这个UIMap里,变化来了以后修改这个Map映射就可以了,一般界面上元素的id或name是基本不变化的。
  • WEB自动化测试只是给基本的业务流程提供一个安全网,主要目的不是发现bug的,覆盖率不高,有些人工更方便的使用人工测试好了。从提问的环节得到的信息,其实百度各个组对于WEB自动化测试的覆盖率没有硬性的要求,好一点的可能达到20-30%的样子。
  • 除了一般的断言,可以通过截屏的方式验证结果——这个没弄懂怎么自动化。
第二个讲座是ThoughtWorks的员工讲TDD,这个我了解多一点,主讲人主要是在编码演示,感觉很好,下面是我个人的一些感受:
  • 首先保证代码的可读性这个很重要,虽然在讲座上没有强调这一点,不过我发现TestCase中的代码要清晰简洁且尽量接近自然语言的描述,实现的细节隐藏到其它的方法中。这就对方法的命名要求很高,在没有想好好的名字前为了表意明确方法名可能会很长。
  • 上面说到要隐藏技术细节,采用的是PageObject模式,有一个navigator(webdirver)来负责导航,另外有若干个page对象,比如通过xpath寻找元素的操作都可以封装到page对象中,这样TestCase中调用这些page的方法即可。
  • 最好采用自上而下的方式进行TDD,可以强迫你从需求和接口的角度考虑问题。
  • 尽管TDD强调在编写任何功能代码前都要先写测试,不过对于WEB测试来说由于运行一次的代价比较大,所以可以先在TestCase里列出场景,而不写任何测试代码,这样先让这个TestCase作为一个文档的作用存在。——其实我比较怀疑Web层做TDD的必要性,最后我觉得作为和BA沟通的文档比测试本身更重要。讲师也强调了和QA以及BA沟通讨论的必要性,有些不是很重要的小功能可以不写TestCase。
  • 演示用的是Java环境,主要是spring mvc,当然理论上tdd和具体的语言无关。
  • 我很喜欢现场编码演示的方式,讲座的核心目的是要证明TDD不是玩具,现场演示一下觉的说服力比较强。IntelliJ IDEA和mac用的很溜儿,是水平高还是工具好?应该是二者都有吧,流畅编码才不会影响思维,这也是我一直在努力提高的。
  • 到场的一半儿多是测试人员,对TDD不了解,但是对TDD的热情很高。

两场讲座完了以后是一个交流环节,参会人员分为十组,选出一个组长讨论一个话题。我有幸和六个女生凑成了一组,只有我一个男童鞋所以我做了组长。她们基本上都是做测试的,只有我是做开发的。我们组没确定什么主题,我是想让大家每个人聊一下自己的经验和工作中测试已经TDD的情况。
  • 我没有预料到的一点是现在很多公司的测试自动化和覆盖率比我想象的要高的多,现在大家对测试和产品质量都很重视,对好的工具和方法都表现出极大的热情。——当然,因为主题是测试,那些只有开发人员没有(或很少)测试人员的公司可能没人参加这个活动。另外,我们公司的架构部门、项目管理部门和测试部门 要吸取经验了,测试计划不自动化的情况应该做一些改进了,还有即使不能TDD,也尽量考虑一下架构的可测试性,UnitTest总要多写一些吧。
  • 在微软测试的一位童鞋告诉我他们有的项目组最高可以达到2:1的测试人员/开发人员的配置比,我一直以为我们将近1:1已经很高了,当然这也和微软以及他们做的软件的特殊性有关系。
  • 后来我们组加入了一个ThoughtWorks的员工,然后大家开始轮番请教问题(ThoughtWorks的人到哪里都会成为焦点,无比嫉妒羡慕佩服……)。有人问道需求变动太累害是不是不适合TDD,其实TDD本来是应对变化的,理论上更应采用TDD,我理解提问者的意思是那种面目全非的需求变化,你的TestCase都一点用处没有了,还怎么保障你功能的重构——ThoughtWorks的童鞋说出现这种情况应该考虑是不是在需求或BA那里出了问题了,应该不是TDD本身的问题,虽然这个答案有点含糊,不过确实如此,为什么会出现翻天覆地的需求改变呢?——业务没理解透或没搞定客户?我问了一个问题是非常简单的功能是不是可以不写TestCase,答案是可以不写,我又问如果可以不写,那测试覆盖率低了以后我怎么知道是不是核心业务开发人员也没有写TestCase呢?答案是这样的:应该雇佣好的开发人员。我在最后总结发言的时候开了个玩笑:需求变化太大不适合用TDD,是BA的问题,不能或不用写单测试人和团队的问题,反正TDD是没有问题的——其实我想说的是TDD做为敏捷中的一个实践环节,它必须有其它方面的配合,不能对一个实践给予太高的超出他能承受范围的期望,从上面两个问题可以看出它至少需要一个好的需求和业务人员的管理配合,需要一个水平不错观念统一的团队,需要雇佣那些对自己该写而没写TestCase的行为有非常强烈恶心感的人。(TDD和单元测试不是一回事儿,我发现我开始模糊这两个概念了,不过连单元测试都不会的人就不用提TDD了)。
  • 最后各个组长发言总结,大概都是两个意思——测试很重要;TDD很好不过用起来还是有些难。我也代表小组总结了一下,得了一个百度发的U盘,感谢一下。这次活动组织的比以前的好很多,感谢一下infoq(小霍童鞋对自己这次的组织也很满意,笑的肚子都疼了)。

============================================================

结束后我和活动上认识的两位朋友去了奇遇咖啡馆(IT界据说挺出名的一个咖啡馆,不过用户体验做的有一个缺点,我们半天没找到门)参加一个关于rails的沙龙,主题是怎么把一个大的rails应用分解成多个小的应用,实践来源于Idapted 的EQ英语用一幅图概括一下:



 
我感觉主要是将应用模块化,关键是各个应用之间的通讯:
  • 通过只读数据库。一个应用只能读另外一个应用中model对应的表,不能写。
  • 不同应用需要写可以通过webservice。
  • 页面集成,可以在页面通过rails的ajax fragment嵌入其它应用提供的页面片段。通过修改nginx的配置,所有应用处于同一域名下也就解决了ajax跨域的问题。(各个片段有点像portalet?不过不能通讯,只是显示)
session是保存在一个数据库里共享的,这就实现了SSO。有一个Core应用负责通用的功能,比如保存一些metadata,比如基于角色的权限控制也是在Core中管理(Core中保存有各个应用Controller的元数据,然后把各个Controller和角色对应起来)。最大的好处是:
  • 模块化使得开发变的容易了,开发一个应用可以独立的配置管理。现在他们已经有20多个应用了。当然,讲座中提到,粒度的划分很重要,要尽可能少的在应用间通讯。
  • 模块化有助于提高部署和伸缩性。那个应用访问量大的时候就可以给它多分配资源,主要是现在内存等资源很便宜。我个人觉的可能还有一个好处,比如我可以将个别应用升级到rails3而不影响其它应用
总之都是模块化的好处。

我对rails知识略知皮毛,大体上看到了这个架构,我的脑子里突然冒出很多东西——SOA、云计算、ESB、OSGI(Spring DM)……当然这是一个公司的私有架构。

我提了一点想法,如果各个应用(或叫模块)的依赖关系在配置一下,那可以给开发和部署带来一些便利……oh,my god,这不是maven的想法吗?

晚上10点才到家,又热又累,不过还是蛮有收获的。


PS:两场活动除了人之外,看到最多的就是Mac Book pro……还看到好几个iPad,无比嫉妒羡慕佩服流口水……

 

  • 大小: 26.7 KB
1
1
分享到:
评论

相关推荐

    OpenSocial规范

    郭应寿在QClub活动中分享了天际网采用OpenSocial的经验。天际网最初使用标准的J2EE架构,但随着用户数量的增长,原有的架构无法满足需求,特别是在处理用户关系表的扩展方面。因此,天际网转向了支持OpenSocial的新...

    停车场管理系统c语言.docx

    问题描述: 停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在停车场的最北端),若车场内已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入; 当停车场内某辆车要离开时,在它之后开入的车辆必须先退出车场为它让路,待该辆车开出大门外,其它车辆再按原次序进入车场,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。 1.基本要求 (1)以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。 (2)每一组输入数据包括三个数据项:汽车“到达”或“离去”信息、汽车牌照号码及到达或离去的时刻,对每一组输入数据进行操作后的输出数据为:若是车辆到达,则输出汽车在停车场内或便道上的停车位置;若是车离去;则输出汽车在停车场内停留的时间和应交纳的费用(在便道上停留的时间不收费)。 (3)栈以顺序结构实现,队列以链表实现。 2.重点难点 重点:针对停车场问题的特点,利

    精选毕设项目-人民好公仆小程序(生活+便民+政务).zip

    精选毕设项目-人民好公仆小程序(生活+便民+政务)

    精选毕设项目-相册;处理用户信息.zip

    精选毕设项目-相册;处理用户信息

    精选毕设项目-喵喵小说.zip

    精选毕设项目-喵喵小说

    精选毕设项目-图片预览带后端.zip

    精选毕设项目-图片预览带后端

    精选项目-爱靓女带后台.zip

    精选项目-爱靓女带后台

    法院综合安全监管平台解决方案PPT(53页).pptx

    在科技与司法的交响曲中,智慧法院应运而生,成为新时代司法服务的新篇章。它不仅仅是一个概念,更是对法院传统工作模式的一次深刻变革。智慧法院通过移动信息化技术,为法院系统注入了强大的生命力,有效缓解了案多人少的矛盾,让司法服务更加高效、便捷。 立案、调解、审判,每一个阶段都融入了科技的智慧。在立案阶段,智慧法院利用区块链技术实现可信存证,确保了电子合同的合法性和安全性,让交易双方的身份真实性、交易安全性得到了有力见证。这不仅极大地缩短了立案时间,还为后续审判工作奠定了坚实的基础。在调解阶段,多元调解服务平台借助人工智能、自然语言处理等前沿技术,实现了矛盾纠纷的快速化解。无论是矛盾类型的多元化,还是化解主体的多元化,智慧法院都能提供一站式、全方位的服务,让纠纷解决更加高效、和谐。而在审判阶段,智能立案、智能送达、智能庭审、智能判决等一系列智能化手段的应用,更是让审判活动变得更加智能化、集约化。这不仅提高了审判效率,还确保了审判质量的稳步提升。 更为引人注目的是,智慧法院还构建了一套完善的执行体系。移动执行指挥云平台的建设,让执行工作变得更加精准、高效。执行指挥中心和信息管理中心的一体化应用,实现了信息的实时传输和交换,为执行工作提供了强有力的支撑。而执行指挥车的配备,更是让执行现场通讯信号得到了有力保障,应急通讯能力得到了显著提升。这一系列创新举措的实施,不仅让执行难问题得到了有效解决,还为构建诚信社会、保障金融法治化营商环境提供了有力支撑。智慧法院的出现,让司法服务更加贴近民心,让公平正义的阳光更加温暖人心。

    西门子1200与3台台达DTK温控器通讯程序 功能:实现西门子1200 PLC对3台台达DTK温控器进行485通讯控制,在触摸屏上设定温度,读取温度 器件:西门子12

    西门子1200与3台台达DTK温控器通讯程序 功能:实现西门子1200 PLC对3台台达DTK温控器进行485通讯控制,在触摸屏上设定温度,读取温度 器件:西门子1200 1214DC DC DC.昆仑通态TPC7062Ti ,西门子KTP700 Basic PN,台达DTK 4848V12温控器。 说明:的是程序,带详细注释程序,西门子触摸屏程序,PLC设置和温控器设置,接线说明书。 #SIEMENS 西门子

    机械设计电阻绕线焊线一体机sw18全套技术资料100%好用.zip

    机械设计电阻绕线焊线一体机sw18全套技术资料100%好用.zip

    VB6编写的上位机采集2路温度 并形成曲线图 还可查看历史数据

    VB6编写的上位机源码,可实时显示曲线图,带有数据库,可以进行历史数据的保存 及 查看历史采集数据。

    精选毕设项目-新浪读书.zip

    精选毕设项目-新浪读书

    jQuery+Slick插件实现游戏人物轮播展示切换特效源码.zip

    jQuery+Slick插件实现游戏人物轮播展示切换特效源码是一款通过背景图片的切换来显示不同的人物效果,轮播效果通过slick幻灯片插件来制作。效果非常棒,有需要的朋友可以直接下载使用,适应各大网站

    精选毕设项目-地图查找附件.zip

    精选毕设项目-地图查找附件

    (蛐蛐voc数据)农作物病虫害识别目标检测数据集,VOC格式,蛐蛐数据集,纯手动标注,用来进行目标检测代码训练的数据

    (蛐蛐voc数据)农作物病虫害识别目标检测数据集,VOC格式,蛐蛐数据集,纯手动标注,用来进行目标检测代码训练的数据。

    MATLAB Simulink仿真模型 双馈风机并网频率控制仿真模型,利用下垂控制与惯性控制结合的综合惯性控制,实现电力系统的频率稳定,两台同步发电机组,具体参数可自行调节,频率波形比较可利用matl

    MATLAB Simulink仿真模型 双馈风机并网频率控制仿真模型,利用下垂控制与惯性控制结合的综合惯性控制,实现电力系统的频率稳定,两台同步发电机组,具体参数可自行调节,频率波形比较可利用matlab工作区画出。

    科研项目结题报告的撰写指南:结构、内容与注意事项

    一、结题报告的类型及主要结构 结题报告是一种专门用于科研课题结题验收的实用性报告类文体,也叫研究报告。它是研究者在课题研究结束后对科研课题研究过程和研究成果进行客观、全面、实事求是的描述,是课题研究所有材料中最主要的材料,也是科研课题结题验收的主要依据。   一篇规范、合格的结题报告,需要回答好3个问题:一是“为什么要选择这项课题进行研究?”二是“这项课题是怎样进行研究的?”三是“课题研究取得哪些研究成果?”  基本结构大致包括以下部分: 第一个问题 “为什么要选择这项课题进行研究?”  1.课题提出的背景;2.课题研究的意义(包括理论意义和现实意义,这个部分也可以合并归入“课题提出的背景”部分);第二个问题“这项课题是怎样进行研究的?”3.文献综述;4.课题研究的理论依据;5.课题研究的目标;6.课题研究的主要内容;7.课题研究的对象;8.课题研究的方法;9. 课题研究的主要过程(研究的步骤);   除了第9部分外,从第1到第8部分在填报课题立项申报表、在制定课题研究方案、在开题报告中,都有要求,内容基本相同。到了撰写结题报告时,只须稍作适当修改就可以了。而第9部分,则需要通过对

    1+X网络安全应急响应之应急准备:构建高效安全的应急响应体系

    内容概要:本文档重点讲述了网络安全应急响应的各项准备工作,涵盖了‘1+X’网络安全应急响应的职业技能等级证书概述、应急响应的基础知识、应急响应组织的建立、风险评估与改进、应急响应预案的制定以及详细的应急响应计划处置样例。文中详细介绍了各级职业技能的要求和任务,尤其关注如何未雨绸缪,制定完善的应急预案以应对潜在的网络安全风险;同时也探讨了如何在网络安全事件发生时,采取及时有效的应急处置措施。 适合人群:从事或有兴趣进入网络安全领域的从业人员,尤其是准备考取‘1+X’网络安全应急响应职业技能等级证书的相关人员。 使用场景及目标:帮助读者了解网络安全应急响应的基本概念及其在整个国家安全框架中的重要地位;指导读者学会如何建立健全高效的应急响应组织结构,如何进行全面的风险评估以及如何编制切实可行的应急预案;通过实例剖析,增强读者应对突发网络安全事件的能力。文档的目标在于提升读者在不同层面的专业技能,包括但不限于系统备份、日志分析、安全漏洞修复等方面的能力。 阅读建议:此文档结构清晰,内容详尽,非常适合有一定基础的技术从业者参考学习。建议读者逐章节深入了解,特别是关注自身岗位对应的技能细分类别。此外,结合实例深入理解和练习如何进行应急处置是非常有价值的,有助于提升自身的实战能力。

    电动汽车动力系统匹配计算模型:输入整车参数及性能要求,一键生成驱动系统的扭矩功率峰值转速等参数 2、整车动力经济性计算模型:包含NEDC WLTC CLTC工况,输入整车参数可生成工况电耗、百公里电

    电动汽车动力系统匹配计算模型:输入整车参数及性能要求,一键生成驱动系统的扭矩功率峰值转速等参数。 2、整车动力经济性计算模型:包含NEDC WLTC CLTC工况,输入整车参数可生成工况电耗、百公里电耗、匀速工况续航、百公里电耗等信息。 实际项目中使用的计算仿真模型. 两个模型打包

    chromedriver-linux64_122.0.6254.0.zip

    chromedriver-linux64_122.0.6254.0

Global site tag (gtag.js) - Google Analytics