Skip to content

sasamuku/rspec_tree

Repository files navigation

RspecTree

RspecTree is a command-line tool for displaying the structure of RSpec test files in a tree format. It uses prism, the default parser introduced in Ruby 3.4, to parse and traverse the AST.

Installation

Install the gem and add to the application's Gemfile by executing:

$ bundle add rspec_tree

If bundler is not being used to manage dependencies, install the gem by executing:

$ gem install rspec_tree

Usage

Display All Describes, Contexts, and Examples

Use the all option to print all describe, context, and example blocks in a file:

$ rspec_tree all /path/to/your_spec.rb
desc: SampleClass
├──desc: First describe
├────ctx: First context
├──────ctx: First nested context
├────────it: should do something
├──────it: should do something
├──desc: Second describe
├────ctx: Second context
├──────it: should do something else

Display Only Describes and Contexts

Use the ctx option to print only describe and context blocks:

$ rspec_tree ctx /path/to/your_spec.rb
desc: SampleClass
├──desc: First describe
├────ctx: First context
├──────ctx: First nested context
├──desc: Second describe
├────ctx: Second context

Display Help Information

Run the help command to see all available commands:

$ rspec_tree help
Commands:
  rspec_tree all [file]      # Print all (describe, context, it, etc.)
  rspec_tree ctx [file]      # Print only describe and context
  rspec_tree help [COMMAND]  # Describe available commands or one specific command

Development

After checking out the repo, run bin/setup to install dependencies. Then, run rake spec to run the tests. You can also run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number in version.rb, and then run bundle exec rake release, which will create a git tag for the version, push git commits and the created tag, and push the .gem file to rubygems.org.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/sasamuku/rspec_tree. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.

License

The gem is available as open source under the terms of the MIT License.

Code of Conduct

Everyone interacting in the RspecTree project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.

About

tree command for RSpec files

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published