2014-08-15 16:33:31 +00:00
|
|
|
# -*- coding: binary -*-
|
2015-12-24 18:54:51 +00:00
|
|
|
require 'stringio'
|
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
ENV['RAILS_ENV'] = 'test'
|
2012-10-08 21:14:37 +00:00
|
|
|
|
2014-12-05 17:58:09 +00:00
|
|
|
unless Bundler.settings.without.include?(:coverage)
|
|
|
|
require 'simplecov'
|
|
|
|
end
|
2013-07-18 17:44:48 +00:00
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
# @note must be before loading config/environment because railtie needs to be loaded before
|
|
|
|
# `Metasploit::Framework::Application.initialize!` is called.
|
|
|
|
#
|
|
|
|
# Must be explicit as activerecord is optional dependency
|
|
|
|
require 'active_record/railtie'
|
2012-10-08 21:14:37 +00:00
|
|
|
|
2016-01-21 19:32:32 +00:00
|
|
|
require 'metasploit/framework/database'
|
|
|
|
# check if database.yml is present
|
|
|
|
unless Metasploit::Framework::Database.configurations_pathname.try(:to_path)
|
2016-01-19 19:28:58 +00:00
|
|
|
fail 'RSPEC currently needs a configured database'
|
|
|
|
end
|
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
require File.expand_path('../../config/environment', __FILE__)
|
2012-11-06 22:30:41 +00:00
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
# Don't `require 'rspec/rails'` as it includes support for pieces of rails that metasploit-framework doesn't use
|
2015-10-16 20:55:53 +00:00
|
|
|
require 'rspec/rails'
|
2014-08-15 16:33:31 +00:00
|
|
|
|
2014-11-05 21:41:43 +00:00
|
|
|
require 'metasploit/framework/spec'
|
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
FILE_FIXTURES_PATH = File.expand_path(File.dirname(__FILE__)) + '/file_fixtures/'
|
2012-10-08 21:14:37 +00:00
|
|
|
|
2014-09-12 15:52:57 +00:00
|
|
|
# Load the shared examples from the following engines
|
|
|
|
engines = [
|
|
|
|
Metasploit::Concern,
|
|
|
|
Rails
|
|
|
|
]
|
|
|
|
|
2012-10-08 21:14:37 +00:00
|
|
|
# Requires supporting ruby files with custom matchers and macros, etc,
|
|
|
|
# in spec/support/ and its subdirectories.
|
2014-09-12 15:52:57 +00:00
|
|
|
engines.each do |engine|
|
|
|
|
support_glob = engine.root.join('spec', 'support', '**', '*.rb')
|
|
|
|
Dir[support_glob].each { |f|
|
|
|
|
require f
|
|
|
|
}
|
2012-10-08 21:14:37 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
RSpec.configure do |config|
|
2015-12-31 22:57:17 +00:00
|
|
|
config.raise_errors_for_deprecations!
|
2015-10-16 20:55:53 +00:00
|
|
|
|
|
|
|
config.expose_dsl_globally = false
|
|
|
|
|
|
|
|
# These two settings work together to allow you to limit a spec run
|
|
|
|
# to individual examples or groups you care about by tagging them with
|
|
|
|
# `:focus` metadata. When nothing is tagged with `:focus`, all examples
|
|
|
|
# get run.
|
|
|
|
config.filter_run :focus
|
|
|
|
config.run_all_when_everything_filtered = true
|
|
|
|
|
|
|
|
# allow more verbose output when running an individual spec file.
|
|
|
|
if config.files_to_run.one?
|
|
|
|
# RSpec filters the backtrace by default so as not to be so noisy.
|
|
|
|
# This causes the full backtrace to be printed when running a single
|
|
|
|
# spec file (e.g. to troubleshoot a particular spec failure).
|
|
|
|
config.full_backtrace = true
|
2014-09-08 02:18:22 +00:00
|
|
|
end
|
2013-04-01 21:06:40 +00:00
|
|
|
|
2015-10-16 20:55:53 +00:00
|
|
|
# Print the 10 slowest examples and example groups at the
|
|
|
|
# end of the spec run, to help surface which specs are running
|
|
|
|
# particularly slow.
|
|
|
|
config.profile_examples = 10
|
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
# Run specs in random order to surface order dependencies. If you find an
|
|
|
|
# order dependency and want to debug it, you can fix the order by providing
|
|
|
|
# the seed, which is printed after each run.
|
|
|
|
# --seed 1234
|
2015-10-16 20:55:53 +00:00
|
|
|
config.order = :random
|
2014-10-27 19:25:34 +00:00
|
|
|
|
2014-08-15 16:33:31 +00:00
|
|
|
config.use_transactional_fixtures = true
|
2015-10-16 20:55:53 +00:00
|
|
|
|
|
|
|
# Seed global randomization in this process using the `--seed` CLI option.
|
|
|
|
# Setting this allows you to use `--seed` to deterministically reproduce
|
|
|
|
# test failures related to randomization by passing the same `--seed` value
|
|
|
|
# as the one that triggered the failure.
|
|
|
|
Kernel.srand config.seed
|
|
|
|
|
|
|
|
config.expect_with :rspec do |expectations|
|
|
|
|
# Enable only the newer, non-monkey-patching expect syntax.
|
|
|
|
expectations.syntax = :expect
|
|
|
|
end
|
|
|
|
|
|
|
|
# rspec-mocks config goes here. You can use an alternate test double
|
|
|
|
# library (such as bogus or mocha) by changing the `mock_with` option here.
|
|
|
|
config.mock_with :rspec do |mocks|
|
|
|
|
# Enable only the newer, non-monkey-patching expect syntax.
|
|
|
|
# For more details, see:
|
|
|
|
# - http://teaisaweso.me/blog/2013/05/27/rspecs-new-message-expectation-syntax/
|
|
|
|
mocks.syntax = :expect
|
|
|
|
|
|
|
|
mocks.patch_marshal_to_support_partial_doubles = false
|
|
|
|
|
|
|
|
# Prevents you from mocking or stubbing a method that does not exist on
|
|
|
|
# a real object.
|
|
|
|
mocks.verify_partial_doubles = true
|
|
|
|
end
|
2015-12-31 22:43:26 +00:00
|
|
|
|
|
|
|
# rspec-rails 3 will no longer automatically infer an example group's spec type
|
|
|
|
# from the file location. You can explicitly opt-in to the feature using this
|
|
|
|
# config option.
|
|
|
|
# To explicitly tag specs without using automatic inference, set the `:type`
|
|
|
|
# metadata manually:
|
|
|
|
#
|
|
|
|
# describe ThingsController, :type => :controller do
|
|
|
|
# # Equivalent to being in spec/controllers
|
|
|
|
# end
|
|
|
|
config.infer_spec_type_from_file_location!
|
2014-08-15 16:33:31 +00:00
|
|
|
end
|
2014-11-05 20:38:43 +00:00
|
|
|
|
2014-10-28 20:07:32 +00:00
|
|
|
Metasploit::Framework::Spec::Constants::Suite.configure!
|
2014-11-05 20:38:43 +00:00
|
|
|
Metasploit::Framework::Spec::Threads::Suite.configure!
|
2015-12-24 18:54:51 +00:00
|
|
|
|
|
|
|
def get_stdout(&block)
|
|
|
|
out = $stdout
|
|
|
|
$stdout = tmp = StringIO.new
|
|
|
|
begin
|
|
|
|
yield
|
|
|
|
ensure
|
|
|
|
$stdout = out
|
|
|
|
end
|
|
|
|
tmp.string
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_stderr(&block)
|
|
|
|
out = $stderr
|
|
|
|
$stderr = tmp = StringIO.new
|
|
|
|
begin
|
|
|
|
yield
|
|
|
|
ensure
|
|
|
|
$stderr = out
|
|
|
|
end
|
|
|
|
tmp.string
|
|
|
|
end
|