`
yanhua
  • 浏览: 89264 次
  • 性别: 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的新...

    基于spring boot框架药品购买系统-a7imn57w.zip

    基于spring boot框架药品购买系统_a7imn57w.zip

    "基于滑模磁链的改进无位置控制技术:减小转矩脉动与抖振,降低电流THD并优化参数依赖",结合滑模和磁链的改进滑模磁链无位置控制,相比于传统的滑模观测器,能有效减小转矩脉动和抖振现象,降低电流THD

    "基于滑模磁链的改进无位置控制技术:减小转矩脉动与抖振,降低电流THD并优化参数依赖",结合滑模和磁链的改进滑模磁链无位置控制,相比于传统的滑模观测器,能有效减小转矩脉动和抖振现象,降低电流THD。 传统的磁链观测器对电气参数非常敏感,改进的磁链观测器将滑模控制率和磁链观测器结合,有效降低了对参数的依赖。 该模型针对特定的小电感电阻电机进行了验证。 ,核心关键词:滑模磁链无位置控制;改进滑模;磁链观测器;传统滑模观测器;电气参数依赖;电流THD;小电感电阻电机验证,好的,根据您提供的关键信息,提炼的标题如下: "结合滑模与磁链技术的改进型无位置控制策略,有效减小抖振与电流THD" 此标题直接体现了该策略结合了滑模和磁链技术,并有效减小了转矩脉动、抖振现象以及电流THD。希望符合您的要求。

    红外轮廓提取python代码

    红外轮廓提取python代码

    (源码)基于Raspberry Pi 3b的STM原子力显微镜控制系统.zip

    # 基于Raspberry Pi 3b的STM原子力显微镜控制系统 ## 项目简介 本项目是一个基于Raspberry Pi 3b的STM(扫描隧道显微镜)控制系统,旨在实现对原子力显微镜的高精度控制和图像采集。通过结合Arduino Uno和ADS1115、AD5764等硬件设备,项目实现了对显微镜的多种操作模式和图像处理功能。 ## 项目的主要特性和功能 1. 信号采集与控制 使用ADS1115进行z轴信号的采集。 通过Arduino Uno控制AD5764,实现对压电驱动器的精确控制。 2. 图像处理 实现3D图像的采集和处理。 3. 操作模式 支持两种操作模式 1. 恒高模式在扫描过程中保持高度恒定。 2. 恒流模式在扫描过程中保持电流恒定。 4. 粗略定位 使用步进电机进行粗略的初始定位。 ## 安装使用步骤 1. 硬件连接

    毕业设计&课程设计&毕设&课设-java-超市管理系统

    项目均经过测试,可正常运行! 环境说明: 开发语言:java JDK版本:jdk1.8 框架:springboot 数据库:mysql 5.7/8 数据库工具:navicat 开发软件:eclipse/idea

    在线课程管理系统 2024免费JAVA毕设

    2024免费毕业设计成品,包括源码+数据库+往届论文资料 录屏:https://www.bilibili.com/video/BV15S421o7Do 启动教程:https://www.bilibili.com/video/BV11ktveuE2d 讲解视频:https://www.bilibili.com/video/BV1YfkHYwEME 二次开发教程:https://www.bilibili.com/video/BV1Cw2rY1ErC

    【GO】关于一个分布式事务的中间件,目前通信是走的http协议.zip

    【GO】关于一个分布式事务的中间件,目前通信是走的http协议

    【爬虫】(天猫,淘宝,京东)爬虫,根据query词爬取数据(Python+Scrapy+MongoDB)_pgj.zip

    【爬虫】(天猫,淘宝,京东)爬虫,根据query词爬取数据(Python+Scrapy+MongoDB)_pgj

    基于三菱PLC与组态王技术的鸡舍温湿度智能控制系统在养鸡场的应用与优化-No.909解决方案,No.909 基于三菱PLC和组态王鸡舍温湿度控制养鸡场 ,三菱PLC; 温湿度控制; 鸡舍

    基于三菱PLC与组态王技术的鸡舍温湿度智能控制系统在养鸡场的应用与优化——No.909解决方案,No.909 基于三菱PLC和组态王鸡舍温湿度控制养鸡场 ,三菱PLC; 温湿度控制; 鸡舍养鸡场; 组态王控制系统; No.909,基于三菱PLC与组态王技术的鸡舍温湿度控制方案

    "三菱PLC与触摸屏联合开发气压传动焊条包装线技术详解",No.945 三菱PLC和触摸屏基于气压传动的焊条包装线的研发 ,核心关键词:三菱PLC; 触摸屏; 气压传动; 焊条包装线; 研

    "三菱PLC与触摸屏联合开发气压传动焊条包装线技术详解",No.945 三菱PLC和触摸屏基于气压传动的焊条包装线的研发 ,核心关键词:三菱PLC; 触摸屏; 气压传动; 焊条包装线; 研发; No.945,"三菱PLC与触摸屏在气压传动焊条包装线研发项目No.945中的应用"

    (源码)基于Spring Boot和Spring Integration的微服务购物系统.zip

    # 基于Spring Boot和Spring Integration的微服务购物系统 ## 项目简介 本项目是一个基于Spring Boot和Spring Integration的微服务购物系统,旨在提供一个高效、可扩展的在线购物平台。系统通过微服务架构实现各个功能模块的解耦,包括商品管理、购物车、订单处理、配送服务等。Spring Integration用于实现服务间的消息传递和集成。 ## 项目的主要特性和功能 1. 商品管理 商品的添加、删除和查询。 从京东网站抓取商品信息。 2. 购物车功能 添加商品到购物车。 从购物车中删除商品。 购物车结账生成订单。 3. 订单处理 订单的创建和状态管理。 订单的供应和结账流程。 4. 配送服务 根据订单生成配送信息。 配送状态的管理和查询。 5. 服务注册与发现

    基于Omron PLC与MCGS组态的自动化售货机控制系统研究与应用:No.848 实践探索与效果分析,No.848 基于Omron PLC和MCGS组态机控制 ,基于Omron PLC

    基于Omron PLC与MCGS组态的自动化售货机控制系统研究与应用:No.848 实践探索与效果分析,No.848 基于Omron PLC和MCGS组态机控制 ,基于Omron PLC; MCGS组态; 售货机控制; 848号项目,基于Omron PLC与MCGS组态的售货机控制系统研究No.848

    基于springboot+vue的人事工资管理系统设计与实现【源码+数据库】

    参考链接:https://www.bilibili.com/video/BV1ZYNHetEaY/?vd_source=bf2d43514ea61b1121399ab65421e37c 前端:Vue 后端:SpringBoot 数据库:MySQL 有数据库文件,项目完整 1、登录模块 可以登录成功和退出登录。 2、用户管理模块 可以添加、删除、修改、查询用户信息。 3、部门管理模块 可以添加、删除、修改、查询部门信息。 4、出勤管理模块 可以查询和编辑出勤信息。 5、工资管理模块 可以查询和编辑工资信息。 6、奖惩管理模块 可以添加、删除、修改、查询奖惩信息。 7、员工管理模块 可以添加、删除、修改、查询员工信息。

    昇腾硬件上面向算子开发场景的编程语言Ascend C的高阶类库ascendc-api-adv-master.zip

    昇腾硬件上面向算子开发场景的编程语言Ascend C的高阶类库ascendc-api-adv-master.zip

    "中央空调时间控制启停的优化:西门子1200PLC与TP900触摸屏模拟仿真程序在博途V16环境下的应用与探讨",中央空调改时间控制启停西门子1200PLC和TP900触摸屏模拟仿真程序博途V16

    "中央空调时间控制启停的优化:西门子1200PLC与TP900触摸屏模拟仿真程序在博途V16环境下的应用与探讨",中央空调改时间控制启停西门子1200PLC和TP900触摸屏模拟仿真程序博途V16 ,中央空调; 时间控制启停; 西门子1200PLC; TP900触摸屏; 模拟仿真程序; 博途V16,"中央空调的定时启停:Siemens 1200PLC与TP900触摸屏模拟仿真程序V16"

    Java多线程核心技术解析及常见面试题详解

    内容概要:这份PDF文档系统梳理了Java多线程的核心概念和技术,涵盖了基础知识、锁机制、线程池以及典型应用场景等关键主题。主要内容包括:多线程的基础知识点(并行与并发区分、线程和进程差异及其创建方式)、创建和使用线程的多种方式及其实现;详细讨论了几种常用的并发锁机制(synchronized、AQS、ReentrantLock等);深入介绍了不同类型的线程池及其配置参数的选择依据;探讨了常见的线程控制工具(如Semaphore和CountDownLatch);并讲解了一些高级话题(例如死锁检测与预防、ThreadLocal的作用)及相关的真实面试情景还原。 适用人群:对于具有一定Java编程经验、希望进一步掌握或复习多线程编程技巧的人士而言是非常有用的资料。特别适用于准备求职面试的技术人员。 使用场景及目标:该资料可以帮助开发者理解并发编程的基本原理,熟练运用各类同步原语和容器以构建高效的并发应用程序;此外,文中提供的面试指南有助于应聘者针对可能出现的技术难题做好充分准备。 其他说明:尽管本资料详尽地阐述了许多理论知识,但在实践中还需结合实际情况做出合理的优化决策。 适合人群:具有一定Java基础并且对多线程感兴趣的开发人员,尤其是那些想要深入了解多线程机制并对自己的职业发展有所规划的人。 使用场景及目标:帮助程序员加深对Java多线程编程技术的认知,提升应对复杂任务的能力;同时也是备战工作中可能遇到的各种多线程面试考题的有效参考资料。 阅读建议:此资源适合循序渐进地学习,先从简单的概念入手逐步过渡到较为复杂的主题,对于关键技术和实用的例子可以适当做一些练习加深理解和记忆。

    (源码)基于ASP.NET Core和Dapr的掩码文本项管理系统.zip

    # 基于ASP.NET Core和Dapr的掩码文本项管理系统 ## 项目简介 本项目是一个基于ASP.NET Core和Dapr的掩码文本项管理系统,旨在提供一个高效、安全的文本管理解决方案。通过使用Dapr框架,项目能够轻松实现微服务架构,并提供诸如状态管理、消息传递等功能。ASP.NET Core则提供了强大的Web应用开发能力,确保系统的高性能和可扩展性。 ## 项目的主要特性和功能 ### 1. 文本项管理 创建掩码文本项支持创建带有掩码的文本项,确保敏感信息的安全性。 更新掩码文本项允许用户更新已有的掩码文本项,保持数据的实时性和准确性。 获取掩码文本项提供根据ID获取特定掩码文本项的功能。 获取多个掩码文本项支持批量获取多个掩码文本项,方便用户进行数据分析和处理。 删除掩码文本项允许用户删除不再需要的掩码文本项,确保数据管理的整洁性。 ### 2. 集成事件处理

    Java的作业拼图游戏.zip

    C Java的作业拼图游戏.zip

    基于三菱PLC与组态王技术的七层电梯控制系统No.803:智能化控制策略与实践,No.803 基于三菱PLC和组态王7层电梯七层电梯控制 ,三菱PLC; 组态王; 七层电梯控制; 803编

    基于三菱PLC与组态王技术的七层电梯控制系统No.803:智能化控制策略与实践,No.803 基于三菱PLC和组态王7层电梯七层电梯控制 ,三菱PLC; 组态王; 七层电梯控制; 803编号,"三菱PLC与组态王协同控制的七层电梯系统"

Global site tag (gtag.js) - Google Analytics