| 
							
								 | 
							
							<!DOCTYPE HTML>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<html lang="en">
 | 
						
						
						
						
							 | 
							
								 | 
							
							    <head>
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <meta charset="UTF-8">
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <title>运行测试 - Rust 程序设计语言 简体中文版</title>
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <meta name="description" content="Rust 程序设计语言 简体中文版">
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <meta name="viewport" content="width=device-width, initial-scale=1">
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <base href="">
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <link rel="stylesheet" href="book.css">
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <link href='https://fonts.googleapis.com/css?family=Open+Sans:300italic,400italic,600italic,700italic,800italic,400,300,600,700,800' rel='stylesheet' type='text/css'>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <link rel="shortcut icon" href="favicon.png">
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- Font Awesome -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <link rel="stylesheet" href="highlight.css">
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <link rel="stylesheet" href="tomorrow-night.css">
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- MathJax -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script type="text/javascript" src="https://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- Fetch JQuery from CDN but have a local fallback -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script src="https://code.jquery.com/jquery-2.1.4.min.js"></script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							            if (typeof jQuery == 'undefined') {
 | 
						
						
						
						
							 | 
							
								 | 
							
							                document.write(unescape("%3Cscript src='jquery.js'%3E%3C/script%3E"));
 | 
						
						
						
						
							 | 
							
								 | 
							
							            }
 | 
						
						
						
						
							 | 
							
								 | 
							
							        </script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							    </head>
 | 
						
						
						
						
							 | 
							
								 | 
							
							    <body class="light">
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- Set the theme before any content is loaded, prevents flash -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script type="text/javascript">
 | 
						
						
						
						
							 | 
							
								 | 
							
							            var theme = localStorage.getItem('theme');
 | 
						
						
						
						
							 | 
							
								 | 
							
							            if (theme == null) { theme = 'light'; }
 | 
						
						
						
						
							 | 
							
								 | 
							
							            $('body').removeClass().addClass(theme);
 | 
						
						
						
						
							 | 
							
								 | 
							
							        </script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- Hide / unhide sidebar before it is displayed -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script type="text/javascript">
 | 
						
						
						
						
							 | 
							
								 | 
							
							            var sidebar = localStorage.getItem('sidebar');
 | 
						
						
						
						
							 | 
							
								 | 
							
							            if (sidebar === "hidden") { $("html").addClass("sidebar-hidden") }
 | 
						
						
						
						
							 | 
							
								 | 
							
							            else if (sidebar === "visible") { $("html").addClass("sidebar-visible") }
 | 
						
						
						
						
							 | 
							
								 | 
							
							        </script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <div id="sidebar" class="sidebar">
 | 
						
						
						
						
							 | 
							
								 | 
							
							            <ul class="chapter"><li><a href="ch01-00-introduction.html"><strong>1.</strong> 介绍</a></li><li><ul class="section"><li><a href="ch01-01-installation.html"><strong>1.1.</strong> 安装</a></li><li><a href="ch01-02-hello-world.html"><strong>1.2.</strong> Hello, World!</a></li></ul></li><li><a href="ch02-00-guessing-game-tutorial.html"><strong>2.</strong> 猜猜看教程</a></li><li><a href="ch03-00-common-programming-concepts.html"><strong>3.</strong> 通用编程概念</a></li><li><ul class="section"><li><a href="ch03-01-variables-and-mutability.html"><strong>3.1.</strong> 变量和可变性</a></li><li><a href="ch03-02-data-types.html"><strong>3.2.</strong> 数据类型</a></li><li><a href="ch03-03-how-functions-work.html"><strong>3.3.</strong> 函数如何工作</a></li><li><a href="ch03-04-comments.html"><strong>3.4.</strong> 注释</a></li><li><a href="ch03-05-control-flow.html"><strong>3.5.</strong> 控制流</a></li></ul></li><li><a href="ch04-00-understanding-ownership.html"><strong>4.</strong> 认识所有权</a></li><li><ul class="section"><li><a href="ch04-01-what-is-ownership.html"><strong>4.1.</strong> 什么是所有权</a></li><li><a href="ch04-02-references-and-borrowing.html"><strong>4.2.</strong> 引用 & 借用</a></li><li><a href="ch04-03-slices.html"><strong>4.3.</strong> Slices</a></li></ul></li><li><a href="ch05-00-structs.html"><strong>5.</strong> 结构体</a></li><li><ul class="section"><li><a href="ch05-01-method-syntax.html"><strong>5.1.</strong> 方法语法</a></li></ul></li><li><a href="ch06-00-enums.html"><strong>6.</strong> 枚举和模式匹配</a></li><li><ul class="section"><li><a href="ch06-01-defining-an-enum.html"><strong>6.1.</strong> 定义枚举</a></li><li><a href="ch06-02-match.html"><strong>6.2.</strong> <code>match</code>控制流运算符</a></li><li><a href="ch06-03-if-let.html"><strong>6.3.</strong> <code>if let</code>简单控制流</a></li></ul></li><li><a href="ch07-00-modules.html"><strong>7.</strong> 模块</a></li><li><ul class="section"><li><a href="ch07-01-mod-and-the-filesystem.html"><strong>7.1.</strong> <code>mod</code>和文件系统</a></li><li><a href="ch07-02-controlling-visibility-with-pub.html"><strong>7.2.</strong> 使用<code>pub</code>控制可见性</a></li><li><a href="ch07-03-importing-names-with-use.html"><strong>7.3.</strong> 使用<code>use</code>导入命名</a></li></ul></li><li><a href="ch08-00-common-collections.html"><strong>8.</strong> 通用集合类型</a></li><li><ul class="section"><li><a href="ch08-01-vectors.html"><strong>8.1.</strong> vector</a></li><li><a href="ch08-02-strings.html"><strong>8.2.</strong> 字符串</a></li><li><a href="ch08-03-hash-maps.html"><strong>8.3.</strong> 哈希 map</a></li></ul></li><li><a href="ch09-00-error-handling.html"><strong>9.</strong> 错误处理</a></li><li><ul class="section"><li><a href="ch09-01-unrecoverable-errors-with-panic.html"><strong>9.1.</strong> <code>panic!</code>与不可恢复的错误</a></li><li><a href="ch09-02-recoverable-errors-with-result.html"><strong>9.2.</strong> <code>Result</code>与可恢复的错误</a></li><li><a href="ch09-03-to-panic-or-not-to-panic.html"><strong>9.3.</strong> <code>panic!</code>还是不<code>panic!</code></a></li></ul></li><li><a href="ch10-00-generics.html"><strong>10.</strong> 泛型、trait 和生命周期</a></li><li><ul class="section"><li><a href="ch10-01-syntax.html"><strong>10.1.</strong> 泛型数据类型</a></li><li><a href="ch10-02-traits.html"><strong>10.2.</strong> trait:定义共享的行为</a></li><li><a href="ch10-03-lifetime-syntax.html"><strong>10.3.</strong> 生命周期与引用有效性</a></li></ul></li><li><a href="ch11-00-testing.html"><strong>11.</strong> 测试</a></li><li><ul class="section"><li><a href="ch11-01-writing-tests.html"><strong>11.1.</strong> 编写测试</a></li><li><a href="ch11-02-running-tests.html" class="active"><strong>11.2.</strong> 运行测试</a></li><li><a href="ch11-03-test-organization.html"><strong>11.3.</strong> 测试的组织结构</a></li></ul></li><li><a href="ch12-00-an-io-project.html"><strong>12.</strong> 一个 I/O 项目</a></li><li><ul class="section"><li><a href="ch12-01-accepting-command-line-arguments.html"><strong>12.1.</strong> 接受命令行参数</a></li><li><a href="ch12-02-reading-a-file.html"><strong>12.2.</strong> 读取文件</a></li><li><a href="ch12-03-improving-error-handling-and-modularity.html"><strong>12.3.</strong> 增强错误处理和模块化</a></li><li><a href="ch12-04-testing-the-librarys-functionality.html"><strong>12.4.</strong> 测试库的功能</a></li><li><a href="ch12-05-working-with-environment-variables.html"><strong>12.5.</strong> 处理环境变量</a></li><li><a href="ch12-06-writing-to-stderr-instead-of-stdout.html"><strong>12.6.</strong> 输出到<code>stderr</code>而不是<code>stdout</code></a></li></ul></li></ul>
 | 
						
						
						
						
							 | 
							
								 | 
							
							        </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <div id="page-wrapper" class="page-wrapper">
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							            <div class="page">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                <div id="menu-bar" class="menu-bar">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <div class="left-buttons">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                        <i id="sidebar-toggle" class="fa fa-bars"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                        <i id="theme-toggle" class="fa fa-paint-brush"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <h1 class="menu-title">Rust 程序设计语言 简体中文版</h1>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <div class="right-buttons">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                        <i id="print-button" class="fa fa-print" title="Print this book"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							                <div id="content" class="content">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <a class="header" href="#运行测试" name="运行测试"><h2>运行测试</h2></a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<blockquote>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p><a href="https://github.com/rust-lang/book/blob/master/src/ch11-02-running-tests.md">ch11-02-running-tests.md</a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<br>
 | 
						
						
						
						
							 | 
							
								 | 
							
							commit cf52d81371e24e14ce31a5582bfcb8c5b80d26cc</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							</blockquote>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>类似于<code>cargo run</code>会编译代码并运行生成的二进制文件,<code>cargo test</code>在测试模式下编译代码并运行生成的测试二进制文件。<code>cargo test</code>生成的二进制文件默认会并行的运行所有测试并在测试过程中捕获生成的输出,这样就更容易阅读测试结果的输出。</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>可以通过指定命令行选项来改变这些运行测试的默认行为。这些选项的一部分可以传递给<code>cargo test</code>,而另一些则需要传递给生成的测试二进制文件。分隔这些参数的方法是<code>--</code>:<code>cargo test</code>之后列出了传递给<code>cargo test</code>的参数,接着是分隔符<code>--</code>,之后是传递给测试二进制文件的参数。</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<a class="header" href="#并行运行测试" name="并行运行测试"><h3>并行运行测试</h3></a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>测试使用线程来并行运行。为此,编写测试时需要注意测试之间不要相互依赖或者存在任何共享状态。共享状态也可能包含在运行环境中,比如当前工作目录或者环境变量。</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>如果你不希望它这样运行,或者想要更加精确的控制使用线程的数量,可以传递<code>--test-threads</code>参数和线程的数量给测试二进制文件。将线程数设置为 1 意味着没有任何并行操作:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test -- --test-threads=1
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<a class="header" href="#捕获测试输出" name="捕获测试输出"><h3>捕获测试输出</h3></a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>Rust 的测试库默认捕获并丢弃标准输出和标准错误中的输出,除非测试失败了。例如,如果在测试中调用了<code>println!</code>而测试通过了,你将不会在终端看到<code>println!</code>的输出。这个行为可以通过向测试二进制文件传递<code>--nocapture</code>参数来禁用:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test -- --nocapture
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<a class="header" href="#通过名称来运行测试的子集" name="通过名称来运行测试的子集"><h3>通过名称来运行测试的子集</h3></a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>有时运行整个测试集会耗费很多时间。如果你负责特定位置的代码,你可能会希望只与这些代码相关的测试。<code>cargo test</code>有一个参数允许你通过指定名称来运行特定的测试。</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>列表 11-3 中创建了三个如下名称的测试:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<figure>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<span class="filename">Filename: src/lib.rs</span>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code class="language-rust">#[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							fn add_two_and_two() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    assert_eq!(4, 2 + 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							#[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							fn add_three_and_two() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    assert_eq!(5, 3 + 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							#[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							fn one_hundred() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    assert_eq!(102, 100 + 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<figcaption>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>Listing 11-3: Three tests with a variety of names</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							</figcaption>
 | 
						
						
						
						
							 | 
							
								 | 
							
							</figure>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>使用不同的参数会运行不同的测试子集。没有参数的话,如你所见会运行所有的测试:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.0 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 3 tests
 | 
						
						
						
						
							 | 
							
								 | 
							
							test add_three_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test one_hundred ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test add_two_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>可以传递任意测试的名称来只运行那个测试:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test one_hundred
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.0 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 1 test
 | 
						
						
						
						
							 | 
							
								 | 
							
							test one_hundred ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>也可以传递名称的一部分,<code>cargo test</code>会运行所有匹配的测试:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test add
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.0 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 2 tests
 | 
						
						
						
						
							 | 
							
								 | 
							
							test add_three_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test add_two_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>模块名也作为测试名的一部分,所以类似的模块名也可以用来指定测试特定模块。例如,如果将我们的代码组织成一个叫<code>adding</code>的模块和一个叫<code>subtracting</code>的模块并分别带有测试,如列表 11-4 所示:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<figure>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<span class="filename">Filename: src/lib.rs</span>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code class="language-rust">mod adding {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    #[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							    fn add_two_and_two() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							        assert_eq!(4, 2 + 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							    }
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							    #[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							    fn add_three_and_two() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							        assert_eq!(5, 3 + 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							    }
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							    #[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							    fn one_hundred() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							        assert_eq!(102, 100 + 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							    }
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							mod subtracting {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    #[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							    fn subtract_three_and_two() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							        assert_eq!(1, 3 - 2);
 | 
						
						
						
						
							 | 
							
								 | 
							
							    }
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<figcaption>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>Listing 11-4: Tests in two modules named <code>adding</code> and <code>subtracting</code></p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							</figcaption>
 | 
						
						
						
						
							 | 
							
								 | 
							
							</figure>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>执行<code>cargo test</code>会运行所有的测试,而模块名会出现在输出的测试名中:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.0 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 4 tests
 | 
						
						
						
						
							 | 
							
								 | 
							
							test adding::add_two_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test adding::add_three_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test subtracting::subtract_three_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test adding::one_hundred ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>运行<code>cargo test adding</code>将只会运行对应模块的测试而不会运行任何 subtracting 模块中的测试:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test adding
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.0 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 3 tests
 | 
						
						
						
						
							 | 
							
								 | 
							
							test adding::add_three_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test adding::one_hundred ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							test adding::add_two_and_two ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<a class="header" href="#除非指定否则忽略某些测试" name="除非指定否则忽略某些测试"><h3>除非指定否则忽略某些测试</h3></a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>有时一些特定的测试执行起来是非常耗费时间的,所以对于大多数<code>cargo test</code>命令,我们希望能排除它。无需为<code>cargo test</code>创建一个用来在运行所有测试时排除特定测试的参数并每次都要记得使用它,我们可以对这些测试使用<code>ignore</code>属性:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p><span class="filename">Filename: src/lib.rs</span></p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code class="language-rust">#[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							fn it_works() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    assert!(true);
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							#[test]
 | 
						
						
						
						
							 | 
							
								 | 
							
							#[ignore]
 | 
						
						
						
						
							 | 
							
								 | 
							
							fn expensive_test() {
 | 
						
						
						
						
							 | 
							
								 | 
							
							    // code that takes an hour to run
 | 
						
						
						
						
							 | 
							
								 | 
							
							}
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>现在运行测试,将会发现<code>it_works</code>运行了,而<code>expensive_test</code>没有:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test
 | 
						
						
						
						
							 | 
							
								 | 
							
							   Compiling adder v0.1.0 (file:///projects/adder)
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.24 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 2 tests
 | 
						
						
						
						
							 | 
							
								 | 
							
							test expensive_test ... ignored
 | 
						
						
						
						
							 | 
							
								 | 
							
							test it_works ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 1 passed; 0 failed; 1 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							   Doc-tests adder
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 0 tests
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>我们可以通过<code>cargo test -- --ignored</code>来明确请求只运行那些耗时的测试:</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<pre><code>$ cargo test -- --ignored
 | 
						
						
						
						
							 | 
							
								 | 
							
							    Finished debug [unoptimized + debuginfo] target(s) in 0.0 secs
 | 
						
						
						
						
							 | 
							
								 | 
							
							     Running target/debug/deps/adder-abcabcabc
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							running 1 test
 | 
						
						
						
						
							 | 
							
								 | 
							
							test expensive_test ... ok
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured
 | 
						
						
						
						
							 | 
							
								 | 
							
							</code></pre>
 | 
						
						
						
						
							 | 
							
								 | 
							
							<p>通过这种方式,大部分时间运行<code>cargo test</code>将是快速的。当需要检查<code>ignored</code>测试的结果而且你也有时间等待这个结果的话,可以选择执行<code>cargo test -- --ignored</code>。</p>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							                </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							                <!-- Mobile navigation buttons -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							                
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <a href="ch11-01-writing-tests.html" class="mobile-nav-chapters previous">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                        <i class="fa fa-angle-left"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    </a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							                
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <a href="ch11-03-test-organization.html" class="mobile-nav-chapters next">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                        <i class="fa fa-angle-right"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    </a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							            </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							            
 | 
						
						
						
						
							 | 
							
								 | 
							
							                <a href="ch11-01-writing-tests.html" class="nav-chapters previous" title="You can navigate through the chapters using the arrow keys">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <i class="fa fa-angle-left"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                </a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							            
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							            
 | 
						
						
						
						
							 | 
							
								 | 
							
							                <a href="ch11-03-test-organization.html" class="nav-chapters next" title="You can navigate through the chapters using the arrow keys">
 | 
						
						
						
						
							 | 
							
								 | 
							
							                    <i class="fa fa-angle-right"></i>
 | 
						
						
						
						
							 | 
							
								 | 
							
							                </a>
 | 
						
						
						
						
							 | 
							
								 | 
							
							            
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        </div>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- Local fallback for Font Awesome -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							            if ($(".fa").css("font-family") !== "FontAwesome") {
 | 
						
						
						
						
							 | 
							
								 | 
							
							                $('<link rel="stylesheet" type="text/css" href="_FontAwesome/css/font-awesome.css">').prependTo('head');
 | 
						
						
						
						
							 | 
							
								 | 
							
							            }
 | 
						
						
						
						
							 | 
							
								 | 
							
							        </script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <!-- Livereload script (if served using the cli tool) -->
 | 
						
						
						
						
							 | 
							
								 | 
							
							        
 | 
						
						
						
						
							 | 
							
								 | 
							
							
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script src="highlight.js"></script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							        <script src="book.js"></script>
 | 
						
						
						
						
							 | 
							
								 | 
							
							    </body>
 | 
						
						
						
						
							 | 
							
								 | 
							
							</html>
 |