RSpec - 简介


RSpec 是 Ruby 编程语言的单元测试框架。RSpec 与 JUnit 等传统 xUnit 框架不同,因为 RSpec 是Behave驱动的开发工具。这意味着,用 RSpec 编写的测试重点关注正在测试的应用程序的“Behave”。RSpec 并不强调应用程序如何工作,而是强调它的Behave方式,换句话说,应用程序实际执行的操作。

RSpec 环境

首先,您需要在计算机上安装 Ruby。但是,如果您之前还没有这样做,那么您可以从主 Ruby 网站 - Ruby下载并安装 Ruby 。

如果您要在 Windows 上安装 Ruby,您应该在此处获得适用于 Windows 的 Ruby 安装程序 - http://www.rubyinstaller.org

对于本教程,您只需要文本编辑器,例如记事本和命令行控制台。此处的示例将在 Windows 上使用 cmd.exe。

要运行 cmd.exe,只需单击“开始”菜单并键入“cmd.exe”,然后按 Return 键即可。

在 cmd.exe 窗口的命令提示符处,键入以下命令以查看您正在使用的 Ruby 版本 -

ruby -v

您应该看到以下输出,与此类似 -

ruby 2.2.3p173 (2015-08-18 revision 51636) [x64-mingw32]

本教程中的示例将使用 Ruby 2.2.3,但任何高于 2.0.0 的 Ruby 版本都可以。接下来,我们需要为您的 Ruby 安装安装 RSpec gem。gem 是一个 Ruby 库,您可以在自己的代码中使用它。为了安装 gem,您需要使用gem命令。

现在让我们安装 Rspec gem。返回 cmd.exe 窗口并输入以下内容 -

gem install rspec

您应该有一个已安装的依赖 gem 的列表,这些是 rspec gem 正常运行所需的 gem。在输出的末尾,您应该看到类似这样的内容 -

Done installing documentation for diff-lcs, rspec-support, rspec-mocks,
   rspec-expectations, rspec-core, rspec after 22 seconds 
6 gems installed

如果您的输出看起来不完全相同,请不要担心。此外,如果您使用的是 Mac 或 Linux 计算机,您可能需要使用sudo运行gem install rspec命令,或者使用 HomeBrew 或 RVM 等工具来安装 rspec gem。

Hello World

首先,我们创建一个目录(文件夹)来存储 RSpec 文件。在 cmd.exe 窗口中,输入以下内容 -

cd \

然后输入 -

mkdir rspec_tutorial

最后,输入 -

cd rspec_tutorial

从这里,我们将创建另一个名为spec的目录,通过输入 -

mkdir spec

我们将把 RSpec 文件存储在这个文件夹中。RSpec 文件称为“规格”。如果这让您感到困惑,您可以将规范文件视为测试文件。RSpec 使用术语“spec”,它是“规格”的缩写形式。

由于 RSpec 是一个 BDD 测试工具,因此目标是关注应用程序的功能以及它是否遵循规范。在Behave驱动开发中,规范通常用“用户故事”来描述。RSpec 旨在明确目标代码是否Behave正确,换句话说,是否遵循规范。

让我们回到 Hello World 代码。打开文本编辑器并添加以下代码 -

class HelloWorld

   def say_hello 
      "Hello World!"
   end
   
end

describe HelloWorld do 
   context “When testing the HelloWorld class” do 
      
      it "should say 'Hello World' when we call the say_hello method" do 
         hw = HelloWorld.new 
         message = hw.say_hello 
         expect(message).to eq "Hello World!"
      end
      
   end
end

接下来,将其保存到您上面创建的 spec 文件夹中名为 hello_world_spec.rb 的文件中。现在回到 cmd.exe 窗口,运行以下命令 -

rspec spec spec\hello_world_spec.rb

命令完成后,您应该看到如下所示的输出 -

Finished in 0.002 seconds (files took 0.11101 seconds to load) 
1 example, 0 failures

恭喜,您刚刚创建并运行了第一个 RSpec 单元测试!

在下一节中,我们将继续讨论 RSpec 文件的语法。