《重构HTML:改善Web应用的设计(修订版)》——第2章 工具 2.1 备份、测试用机和源码控制

简介:

本节书摘来自异步社区《重构HTML:改善Web应用的设计(修订版)》一书中的第2章,第2.1节,作者: 【美】Elliotte Rusty Harold 更多章节内容可以访问云栖社区“异步社区”公众号查看。

第2章 工具

自动化工具是重构的重要组成部分。尽管可以使用文本编辑器手动执行重构,甚至有时出于演示的目的我也使用这种方式,但实际上绝大多数的时候我们都使用软件来辅助工作。据我所知,到本书写作时为止,还没有可用于HTML的主流的重构浏览器(refactoring browser)。但已经有很多工具可用在重构的过程中。本章会讲解一些工具。

2.1 备份、测试用机和源码控制

自始至终,我都会在本书中向你展示一些非常强大的工具和技术。伟大的教育家Stan Lee告诉我们:“能力越大,责任越大。”①使用这些技术必须对结果负责,不要让破坏变得不可弥补。我给你展示的工具中有些可能会“行为不端”,有些被弄糊涂时还有会出现边际效应。品质不良的HTML实在太多了,因此这里讨论的工具做不到面面俱到。因此,重构HTML至少需要5个步骤。

(1) 确定问题。

(2) 修复问题。

(3) 检验已修复的问题。

(4) 确保没有引入新问题。

(5) 部署解决方案。

错误在所难免,因此不要在任何一个在线的网站上使用这些技术。在做任何改动之前,先准备好一份网站的本地副本。完成本地副本的修改之后,仔细检查所有页面才进行部署。

现在许多大型网站都已经使用测试用机(staging server)或开发用机,在公开发布之前可以部署和检查内容。如果只是个人静态的小网站,直接复制一份到本地硬盘上进行修改就可以了。但无论如何都只在副本中工作,并在部署之前检查所有的变化。如何检查变化则是下一节要讲述的内容。

当然,就算是经过了最仔细的检查,还是难以避免一些错误,而这些错误由最终用户首先发现。有时网站在测试用机上运作得很好,但到了生产机中就有可能因为未知的配置区别,而碰到各种不可思议的问题。因此,对生产环境的网站进行整体备份,以便新部署的网站不能按预期运作时进行恢复,这是一个非常不错的做法。定期、可靠、经过测试的备份是不可或缺的。

最后,你应该非常谨慎地把包括HTML、CSS和图片的代码存储在源码控制系统中。程序员使用源码控制系统有数十年了,但Web开发者和设计者对它还相对陌生,现在是改变的时候了。网站越复杂,那些微乎其微的问题就越有可能被忽略。在重构时,能够恢复到前一个甚至是数月乃至数年之前的版本是非常关键的,这样才能找到是哪次改变引入了错误。源码控制同时提供以时间为标识的备份,因此可以还原到指定时间点的状态。

在Web开发中,我强烈推荐使用Subversion,很大程度上是因为它非常好地支持目录间文件的移动,并且对Unicode的出众支持和对二进制文件的得体支持也非常有帮助。大部分的源码控制系统在默认情况下都为程序员配置妥当,不用去关心文件在目录间的移动。但是Web开发者频繁地改变网站结构(实际上过于频繁了),因此系统必须能够追踪文件移动的历史。如果上级已经帮你配置了如CVS、Visual SourceSafe、ClearCase或者Perforce等其他源码控制系统,你大可随遇而安。但从长远看来,Subversion可能会做得更好,并且可以减少问题的引发。

如何管理Subversion这个主题可以写一本书,而实际上也已经有很多这样的书了(我喜欢的是Mike Mason著的Pragmatic Version Control Using Subversion[The Pragmatic Bookshelf,2006])。很多大型网站专门雇佣负责管理源码控制仓库的人。但先别担心,毕竟配置Subversion或其他源码控制仓库的难度,并不会超过配置Apache或其他Web服务器。只需阅读少量文档,修改某些配置文件,或者求助于新闻组,或者通过Google搜索就可以解决难题。这都是切实可行的,而且这些时间值得付出。

如果有必要,你可以使用命令行在Subversion中提交或获取文件。但如果能使用如BBEdit这种内置支持Subversion的编辑器,事情会变得更简单。如Dreamweaver这种本身不支持Subversion的编辑器也有插件支持Subversion。此外,像TortoiseSVN和SCPlugin这种有界面的产品,可以在Windows系统上的资源管理器或是Mac系统上的Finder上直接集成Subversion。

一些CMS(内容管理系统)也有内置的版本控制。如果你使用的CMS正好有版本控制,或许就没有使用外部仓库的必要了。比如,MediaWiki把所有页面的所有修改都存储起来,这样就可以查看指定页面在任何时间任何位置的状况,而且还能够还原。这是维基百科所安装的MediaWiki模块中很重要的一个,因为修改是一个很现实的问题。不过即便是不对外开放编辑权限的私有网站,也能在保存的完整的历史记录中得到好处。Wiki是Web中使用版本控制最普遍的一种,其他一些(如Siteline等)CMS也提供这样的功能。

相关文章
|
1天前
|
JSON 前端开发 JavaScript
快照测试在前端自动化测试中的应用
在前端自动化测试中,快照测试常用于检验组件渲染与布局。
|
2天前
|
测试技术 API
探索软件测试中的自动化工具与挑战
本文探讨了软件测试领域中自动化工具的应用与挑战。通过分析目前主流的自动化测试工具,探讨了其在提高测试效率、减少人工成本、增强测试覆盖率等方面的优势。然而,自动化测试也面临着诸如脆弱性、维护成本高等挑战。最后,提出了一些应对挑战的建议,以期为软件测试领域的自动化工作提供一些启示。
10 1
|
2天前
|
SQL 安全 数据处理
Web 测试神器:HackBar 保姆级教程
Web 测试神器:HackBar 保姆级教程
|
3天前
|
敏捷开发 JavaScript 测试技术
深入理解与应用软件测试中的Mock技术
【5月更文挑战第5天】 在现代软件开发过程中,单元测试作为保障代码质量的重要环节,其独立性和可靠性至关重要。Mock技术应运而生,为开发者提供了一种在隔离环境下模拟外部依赖的方法。本文将深入探讨Mock技术的概念、实现方式及其在软件测试中的应用,旨在帮助读者更好地理解和运用这一强大的测试工具,以提升测试效率和软件质量。
|
6天前
|
安全 IDE Java
Java串口通信技术探究2:RXTX库单例测试及应用
Java串口通信技术探究2:RXTX库单例测试及应用
25 4
|
7天前
|
数据采集 机器学习/深度学习 人工智能
探索AI在软件测试中的应用与挑战
【5月更文挑战第2天】本文将探讨人工智能(AI)在软件测试领域的应用及其带来的挑战。我们将详细讨论AI如何改变软件测试的方式,包括自动化测试、预测性测试、智能化缺陷检测等。同时,我们也将探讨AI在软件测试中面临的挑战,如数据质量问题、模型的可解释性、以及对现有测试流程的影响等。
|
7天前
|
机器学习/深度学习 人工智能 测试技术
提升软件测试效率与准确性的策略与工具
【5月更文挑战第2天】 在软件开发生命周期中,测试阶段是确保产品质量的关键。然而,传统的测试方法往往耗时且容易出错。本文将探讨一系列现代软件测试策略和工具,旨在提高测试效率和准确性。我们将分析自动化测试框架、持续集成(CI)、测试驱动开发(TDD)以及人工智能(AI)在测试中的应用,并讨论如何结合这些技术和方法来优化测试流程。
|
8天前
|
敏捷开发 监控 测试技术
探索自动化测试工具Selenium Grid的高效集成策略
【4月更文挑战第30天】在现代Web应用的快速迭代和持续部署中,测试自动化已成为确保产品质量的关键。Selenium Grid作为一款支持多种浏览器和操作系统的测试工具,提供了并行执行测试用例的能力,极大地提升了测试效率。本文将深入探讨如何高效地将Selenium Grid集成到现有的测试框架中,以及实施过程中的最佳实践,帮助团队最大化测试覆盖率,同时降低资源消耗。
|
8天前
|
Java 测试技术 开发者
深入理解与应用单元测试:软件质量的守护者
【4月更文挑战第30天】 在现代软件开发过程中,单元测试作为保障代码健康的重要环节,其地位日益凸显。本文将探讨单元测试的核心概念、实施单元测试的重要性以及如何高效地设计并执行单元测试。通过实例分析,我们将揭示单元测试在确保软件产品质量和加速开发周期中的关键作用。
|
8天前
|
敏捷开发 测试技术 持续交付
探索自动化测试在敏捷开发中的应用移动应用的未来:跨平台开发与操作系统的融合
【4月更文挑战第30天】随着软件开发周期的不断缩短,传统的软件测试方法逐渐显得力不从心。本文将深入探讨自动化测试在敏捷开发环境中的关键作用,分析其如何提高测试效率、减少人力资源成本,并确保软件产品的质量与稳定性。通过案例分析,我们还将讨论实施自动化测试的最佳实践和面临的挑战,为追求高效敏捷开发的组织提供参考。