`
chasinggoodness
  • 浏览: 16536 次
  • 性别: Icon_minigender_2
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

[摘译] 测试与ANT方法

阅读更多

昨天读到一篇朋友推荐过来Brian Marick的博客,很有意思。

博客中主要说了作为一个测试咨询师如何使用ANT这个方法跳脱常规的习惯,帮助客户找到问题所在。

链接如下:
http://www.exampler.com/blog/2007/11/01/latour-1-testing-as-an-example/

如果想省点眼力可以往下看我的翻译,嘿嘿。

ANT
就是 Actor Network Theory 的简称,大概也就是说参与者网络理论吧。是法国的哲学家/社会学家Bruno Latour 提出来的。

开始原文逐字翻译如下:

我是一个咨询师,在一个项目中有大概一个星期了。在项目中我跟别人合作 - 结队,测试,还有其他。在这个过程中,我需要做的是发现他们没有发现的问题,给出他们没有尝试过的建议,这一切都是为了帮助他们更好的构建他们的软件。

一个艰苦的工作:这些项目很复杂,很多东西都在变动。对咨询师来说,他们很容易只看到习惯于见到的东西。更糟的是:他们看到不存在的东西,就因为他们这些东西是他们最擅长看到的。
所以,作为一个咨询师,他们需要在找到一些思维上的技巧,这样可以帮他们摆脱常规与习惯。我使用ANT作为一个诀窍。

一个实例:在敏捷项目中的测试角色

ANT群体共同做的一件事情是:把注意力放在事情本身上,看他们是如何变动的。

70年代中后期,Bruno Latour -- 一个几乎不懂英语的而更是不懂生物化学的哲学家 -- 来到了加利福尼亚圣地亚哥的Salk Institute。他不光是几乎不懂学院里的人们都在干什么,他甚至还故意的忘记他知道的东西。那时候,他只想在学院里像一个人类学家到访一个完全陌生 和未知的部落一样一切从零开始。

正如你可以想象得到的一样,他的观察结果很奇怪。比如说,他看到在实验室里只有一个地方会定期的被放置装订好的被叫做报纸的东西。
(为了便于理解,我把图留下了)<o:p></o:p>

<o:p> </o:p>

The Salk Institute

在其他地方,那些被叫做技师的人们负责管理那些好像是用来在纸上做标记(划线,打点绘图,标识数字等等诸如此类)的机器,机器看上去好像很昂贵并且 结实的说。这两类纸会被送到第三个地方,就是科学家们办公室。科学家们会把2这两类纸 -- 报纸和试验结果 -- 放到一块来做比较。在作比较的过程中与结束后,他们会写一些东西到另一批新的纸上,然后送到有打字员的地方,这些打字员会把字打好(就是格式弄得 好点),然后把他们寄到叫做出版商的人那里,出版商会把他们跟其他在一起装订好,再把这些报纸送到。。。 总之接下来还有送到更多的实验室去。<o:p></o:p>

对于Latour来说,这看上去实验室就像是一个把一堆纸变成更多堆纸的地方。<o:p></o:p>

现在Karl Popper, (这个人可能是科学界最具影响力的哲学家) 把Latour的所见描述为附带现象,这种附带现象不是科学所要研究的,科学所要研究的是:<o:p></o:p>

1. 一个理论家要提出理论。无独有偶,那些例子好像总是用非常棒的、早已为人所熟知的理论家。<o:p></o:p>

2. 有些人-- 或许是非常厉害的理论家,当然也可能就是别的什么人 -- 从那些理论里得到一些预言:在X情况下,这个世界可能会出现Y<o:p></o:p>

3. 一个实际动手的人 -- 通常你是不会听过这些人的 -- 就会创造出X状况,并且观察是不是Y出现了。<o:p></o:p>

4. 如果这个Y并没发生,理论学家只好丢弃掉他/她的那个理论,从头来过。<o:p></o:p>

5. 如果Y发生了,那还不足以肯定这个理论的正确性。没有太多被确认确有其事的预言能够符合逻辑的证明一个理论是正确的。然而,如果这个理论还真是经受得住足够多的具有挑战性的测试,科学家们就可以开始在他们的工作做使用这个理论了。<o:p></o:p>

Popper同学的观点对我来说还蛮重要的。因为一些软件测试人员类很明显的在测试中使用了Popper的观点。<o:p></o:p>

1. 程序员是一个理论家,提出了一个类似对于任何输入到文本框的X值,程序就会计算f(X)”<o:p></o:p>

2 . 测试人员把它当作一种预言。所以程序应该计算f(X),如果输入是叫做SQL注入的任何一种的话”<o:p></o:p>

3. 测试人员搭好环境,尝试SQL注入<o:p></o:p>

4. 如果程序不如预期那样工作,那么程序员需要回去改动他们的东西,再来试一试<o:p></o:p>

5. 如果程序通过了测试,这个并不能说明它就完全对了-- 还没有通过足够多的测试来证明它是无bug的。但是如果通过了足够多的测试,经理们就吃了定心丸:行了,发布吧<o:p></o:p>

问题是,这在一个敏捷团队中的效果。有时候,我会想一个问题(大概2002年的时候),在测试人员与敏捷支持这种有很多紧张局面。两边都说了一些比较不经 大脑的话。在当时的背景下,测试人员的惯常的由程序员的程序里的缺陷驱动” -- 程序员的自我 -- 对于团队里的团结合作并无益处。然而团结合作灾民解团队中尤其重要。 有些人可能会说程序员需要少些自我,但我更倾向于结合人类本身的特点,而不是跟它做对

科学仿佛不是一个很确切的比喻。(此外,读了Feyerabend Lakatos的东西以后,我还是满怀疑那些对于科学的沉溺跟一个真正的科学家是如何接受理论是不是相关)。

在某个时刻,我想起了一本比较详细的Latour的书,里面描述的Salk经历(Laboratory Life, Steven Wooglar一起写的)。在把报纸越变越多的过程中,科学家们也会把草稿给别的科学家看。他们会凑在一起讨论那些草稿。交谈的内容可能会如下:

Morin
很可能是这个东西的一个评论家,你知道她是怎么看待抗生素治疗的。如果你想通过她这关,你需要加强这方面的论据。
或者
我可以帮你搞定SAS的那部分数据,让统计分析看上去更可靠。
或者
如果你把化验X的结果放进去,会有更多人感兴趣,我可以把我的技师借给你。<o:p></o:p>

那么结果是,其中一个人预见这个论文面世以后可能面临的问题,并且提出意见,使论文能更好的得到接受。然而,我不认为着当时我意识到了,这个方式,是Richard P. Gabriel从创造性写作协会引入设计模式协会的一个合作方式。(Writers’ Workshops and the Work of Making Things.<o:p></o:p>

我意识到了,这个是一个把测试人员的技能使用到产品与团队团结合作的氛围的方式。所以,我开始在我的咨询工作中运用这个方法。给什么样的建议要看是什么样的团队。我可能会把测试人员放到支持产品owner这个角色里面。他们可能会帮助产 品owner更明晰和全面的了解她想要什么,然后他们就可以把她所表达的那些东西转换成更清晰的测试场景描述,程序员可以在测试驱动开发中使用。或者我会 把测试人员放到帮助程序员了解领域知识这个角色,一次一个测试。(这个会影响到你写的测试的类型,以及使用他们的顺序)。等等。<o:p></o:p>

我想这个思考的方式在敏捷世界中是非常普遍的。没有我,它可能也会这么发生。-- 我绝不是唯一一个这么想的人。这不重要:重要的是如果没有吸收Latour看问题的方式的精髓,我可能不会这么看敏捷团队合作的问题。


分享到:
评论

相关推荐

    《2017年美国胃肠病学会临床实践更新委员会:重症酒精性肝炎的医疗管理》摘译.rar

    该文件的摘译版为医疗专业人员以及对这一领域感兴趣的人士提供了关于诊断、评估和治疗SAH的关键信息。以下是这份指南中的核心知识点: 1. **定义与流行病学**: - 酒精性肝炎是长期过量饮酒导致的肝脏炎症,重症型...

    美国医院流行病学会和感染性疾病协会成人艰难梭菌感染临床指南(2021)摘译整理.pdf

    美国医院流行病学会和感染性疾病协会成人艰难梭菌感染临床指南(2021)摘译整理.pdf

    VS Code MSDN手册 01.安装和使用 摘译.pdf

    **中文版与汉化包** 对于中文用户,可以安装中文语言包。语言包可以通过VS Code内部的Marketplace搜索"Chinese (Simplified) Language Pack for Visual Studio Code"或直接访问下载链接:...

    《2017年美国胃肠病学会临床实践更新委员会:重症酒精性肝炎的医疗管理》摘译.pdf

    【摘要】:本文摘译自2017年美国胃肠病学会临床实践更新委员会的《重症酒精性肝炎的医疗管理》指南,旨在提供对这一严重病症的诊疗建议。重症酒精性肝炎(Severe Alcoholic Hepatitis, SAH)是由于长期过度饮酒导致...

    [摘译]史蒂夫·乔布斯的脑子里在想什么

    -----------------------------------------------------------------------------------------------------------------------------本文摘译自Wired.com(Wired杂志网络版)的执行主编LeanderKahney于今年上半年...

    摘译 (1982年)

    1982年,国内外的工程技术领域中出现了几项重要的仪器设备研究成果,主要包括激光分析仪、...这些技术的突破为后续的科学研究和工业应用提供了重要的工具和方法,同时也为相关的工程技术领域的发展奠定了坚实的基础。

    Siebel编码最佳实践Siebel Scripting Best Practices Resource Document

    - **Applet PreInvokeMethod**:捕获Applet触发的方法,用于与用户的桌面、用户、Applet外观交互。 - **WebApplet PreInvokeMethod**:当需要访问当前记录或活动BC之外的记录时使用。 - **Service PreInvokeMethod**...

    wstg-translations-pt:将OWASP Web安全测试指南的4.2版翻译成葡萄牙语

    苏马里奥 Reservado para o Sumario。 将OWASP Web安全测试指南的4.2版翻译成葡萄牙语。 从原文摘译自的原始英语版本。

    Characteristica Universalis

    - 本部分强调了与传统逻辑处理方法不同的路径,即利用图形、图表和图像来代表现实世界中最一般的结构,这与标准的命题逻辑方式相区别。 3. **皮尔士的实验方法(Peirce's Experimental Method)**: - 文章中提到...

    地震安全手册.pdf

    美国国家紧急事务管理局编,译言摘译。 地震自救救人必备

    ThinkPad_T500&W500;笔记本拆卸教程,硬件维护手册中文版

    这些型号包括了T500的多种型号和W500的多种型号,尽管本教程摘译自联想官方的硬件维护手册,但主要关注了各部件的拆卸方法。 1. 电池拆卸:拆卸电池是拆卸笔记本的第一步,防止带电作业可能带来的危险。拆卸电池...

    毕业论文格式

    - 科技文章摘译:中文翻译至少2000字,展示对外文文献的理解。 2. 论文书写要求: - 字数:正文通常要求3-4万字,约35页。 - 语言:要求层次清晰,表达准确,避免冗余和不必要的叙述。 - 标题和层次:层次分明...

    信息时代给翻译课教学的几点启示.pdf

    4. **推广变译技巧**:在信息爆炸的时代,全译不再是唯一的选择,教师应培养学生的变译能力,如编译、摘译、缩译等,以适应快速阅读的需求。 5. **提升技术素养**:学生应掌握现代信息技术,如桌面排版系统、办公...

    2015级本科新生大学英语、计算机分级考试要求资料.pdf

    - 基本要求:能读懂一般性文章,每分钟70词阅读速度,能读懂国内英文报刊,掌握中心意思,理解事实和细节,使用有效阅读方法。 - 较高要求:能读懂英语国家大众性文章,每分钟70词,快速阅读每分钟120词,能进行...

    大学英语课程教学要求中文版.doc

    一、教学性质与目标 大学英语教学不仅是高等教育的一部分,而且是一门必修的基础课程,采用外语教学理论,注重英语语言知识、应用技能、跨文化交际和学习策略的融合。教学目标是培养学生的英语综合应用能力,尤其是...

    大学英语课程教学要求(中文版).pdf

    一、教学性质与目标 大学英语教学不仅是高等教育的一部分,而且是一门基础必修课,采用外语教学理论,注重英语语言知识、应用技能、跨文化交际和学习策略的融合。教学目标是提升学生的英语综合应用能力,尤其是听说...

Global site tag (gtag.js) - Google Analytics