簡體   English   中英

如何使用Rspec僅運行最新的/給定的測試?

[英]How to run only the latest/a given test using Rspec?

假設我有一個包含20個測試的大規格文件,因為我正在測試一個大型模型,而我沒有其他方法可以這樣做:

describe Blah
  it "should do X" do ... end
  it "should do Y" do ... end
  ...
  it "should do Z" do ... end
end

運行單個文件比運行整個測試套件要快,但是仍然很長。 有沒有辦法運行最后一個(即文件末尾的一個,這里是“ Z應該做”)?

如果這不可能,是否有辦法指定我要在文件中運行的測試?

規范可以按文件或定義運行。

Usage: spec (FILE(:LINE)?|DIRECTORY|GLOB)+ [options]

實際上,可能是這樣。 運行此規范文件中的定義(標識最后一行的行)。

spec spec/models/customer_spec.rb:25

可以通過rails根目錄中的“ spec”檢查完整的語法。

Usage: spec (FILE(:LINE)?|DIRECTORY|GLOB)+ [options]

-p, --pattern [PATTERN]          Limit files loaded to those matching this pattern. Defaults to '**/*_spec.rb'
                                 Separate multiple patterns with commas.
                                 Applies only to directories named on the command line (files
                                 named explicitly on the command line will be loaded regardless).
-D, --diff [FORMAT]              Show diff of objects that are expected to be equal when they are not
                                 Builtin formats: unified|u|context|c
                                 You can also specify a custom differ class
                                 (in which case you should also specify --require)
-c, --colour, --color            Show coloured (red/green) output
-e, --example [NAME|FILE_NAME]   Execute example(s) with matching name(s). If the argument is
                                 the path to an existing file (typically generated by a previous
                                 run using --format failing_examples:file.txt), then the examples
                                 on each line of that file will be executed. If the file is empty,
                                 all examples will be run (as if --example was not specified).

                                 If the argument is not an existing file, then it is treated as
                                 an example name directly, causing RSpec to run just the example
                                 matching that name
-s, --specification [NAME]       DEPRECATED - use -e instead
                                 (This will be removed when autotest works with -e)
-l, --line LINE_NUMBER           Execute example group or example at given line.
                                 (does not work for dynamically generated examples)
-f, --format FORMAT[:WHERE]      Specifies what format to use for output. Specify WHERE to tell
                                 the formatter where to write the output. All built-in formats
                                 expect WHERE to be a file name, and will write to $stdout if it's
                                 not specified. The --format option may be specified several times
                                 if you want several outputs

                                 Builtin formats:
                                 silent|l                 : No output
                                 progress|p               : Text-based progress bar
                                 profile|o                : Text-based progress bar with profiling of 10 slowest examples
                                 specdoc|s                : Code example doc strings
                                 nested|n                 : Code example doc strings with nested groups indented
                                 html|h                   : A nice HTML report
                                 failing_examples|e       : Write all failing examples - input for --example
                                 failing_example_groups|g : Write all failing example groups - input for --example

                                 FORMAT can also be the name of a custom formatter class
                                 (in which case you should also specify --require to load it)
-r, --require FILE               Require FILE before running specs
                                 Useful for loading custom formatters or other extensions.
                                 If this option is used it must come before the others
-b, --backtrace                  Output full backtrace
-L, --loadby STRATEGY            Specify the strategy by which spec files should be loaded.
                                 STRATEGY can currently only be 'mtime' (File modification time)
                                 By default, spec files are loaded in alphabetical order if --loadby
                                 is not specified.
-R, --reverse                    Run examples in reverse order
-t, --timeout FLOAT              Interrupt and fail each example that doesn't complete in the
                                 specified time
-H, --heckle CODE                If all examples pass, this will mutate the classes and methods
                                 identified by CODE little by little and run all the examples again
                                 for each mutation. The intent is that for each mutation, at least
                                 one example *should* fail, and RSpec will tell you if this is not the
                                 case. CODE should be either Some::Module, Some::Class or
                                 Some::Fabulous#method}
-d, --dry-run                    Invokes formatters without executing the examples.
-O, --options PATH               Read options from a file
-G, --generate-options PATH      Generate an options file for --options
-U, --runner RUNNER              Use a custom Runner.
-u, --debugger                   Enable ruby-debugging.
-X, --drb                        Run examples via DRb. (For example against script/spec_server)
    --port PORT                  Port for DRb server. (Ignored without --drb)
-v, --version                    Show version
    --autospec
-h, --help                       You're looking at it

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM