Skip to content

RSpec matcher to check database index usage in specific queries

Notifications You must be signed in to change notification settings

PedroSena/rspec-index-usage

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RSpec Index Usage

RSpec matchers that check database index usage in ActiveRecord queries and code blocks.

Requirements

  • Ruby >= 2.7
  • ActiveRecord >= 6.0 (supports SQLite and PostgreSQL)

Installation

Add this line to your application's Gemfile:

gem 'rspec-index-usage'

And then execute:

$ bundle install

This will install the gem along with its runtime dependency on ActiveRecord >= 6.0.

Or install it yourself as:

$ gem install rspec-index-usage

Usage

Add to your Gemfile:

gem 'rspec-index-usage'

Then in your specs:

require 'rspec-index-usage'

# In your specs
# Using a query
expect(User.where(email: '[email protected]')).to use_index('index_users_on_email')

# Using a block
expect { User.where(email: '[email protected]').first }.to have_used_index('index_users_on_email')

# Using a block but specifying one particular database connection
# This is only needed when you have more than one database setup
expect { User.where(email: '[email protected]').first }.to have_used_index('index_users_on_email').on_connection(OtherDb.connection)

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/PedroSena/rspec-index-usage.

License

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

About

RSpec matcher to check database index usage in specific queries

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages