spec/spec_helper.rb in washbullet-0.3.1 vs spec/spec_helper.rb in washbullet-0.4.0

- old
+ new

@@ -1,82 +1,62 @@ -# This file was generated by the `rspec --init` command. Conventionally, all -# specs live under a `spec` directory, which RSpec adds to the `$LOAD_PATH`. -# The generated `.rspec` file contains `--require spec_helper` which will cause this -# file to always be loaded, without a need to explicitly require it in any files. -# -# Given that it is always loaded, you are encouraged to keep this file as -# light-weight as possible. Requiring heavyweight dependencies from this file -# (such as loading up an entire rails app) will add to the boot time of your -# test suite on EVERY test run, even for an individual file that may not need -# all of that loaded. -# -# The `.rspec` file also contains a few flags that are not defaults but that -# users commonly want. -# -# See http://rubydoc.info/gems/rspec-core/RSpec/Core/Configuration -RSpec.configure do |config| -# The settings below are suggested to provide a good initial experience -# with RSpec, but feel free to customize to your heart's content. -=begin - # 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 +require 'pry' +require 'json' - # Many RSpec users commonly either run the entire suite or an individual - # file, and it's useful to 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 +require 'washbullet' +require 'webmock/rspec' +require 'vcr' - # Use the documentation formatter for detailed output, - # unless a formatter has already been configured - # (e.g. via a command-line flag). - config.formatter = 'doc' if config.formatters.none? +def test_api_key + ENV.fetch('API_KEY', '<API_KEY>') +end + +VCR.configure do |config| + config.cassette_library_dir = 'spec/vcr' + config.hook_into :webmock + config.configure_rspec_metadata! + + config.filter_sensitive_data('<API_KEY>') do + test_api_key end - # 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 + config.before_record do |interaction| + next if interaction.response.body.empty? - # 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 - config.order = :random + response = JSON.parse(interaction.response.body) - # 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 + response['iden'] = '<IDENTIFIER>' if response.has_key?('iden') - # rspec-expectations config goes here. You can use an alternate - # assertion/expectation library such as wrong or the stdlib/minitest - # assertions if you prefer. + %w(devices contacts subscriptions).each do |key| + response[key] = response[key].map {|entity| + entity.merge!({'iden' => '<IDENTIFIER>'}) + + if entity['fingerprint'] + entity['fingerprint'] = JSON.parse(entity['fingerprint']) + entity['fingerprint'].merge!({'android_id' => '<ANDROID_ID>'}) + end + + if entity['channel'] + entity['channel'].merge!({'iden' => '<IDENTIFIER>'}) + end + + entity + } if response[key] + end + + interaction.response.body = response.to_json + end +end + +RSpec.configure do |config| config.expect_with :rspec do |expectations| - # Enable only the newer, non-monkey-patching expect syntax. - # For more details, see: - # - http://myronmars.to/n/dev-blog/2012/06/rspecs-new-expectation-syntax - expectations.syntax = :expect + expectations.include_chain_clauses_in_custom_matcher_descriptions = true 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 - - # Prevents you from mocking or stubbing a method that does not exist on - # a real object. This is generally recommended. mocks.verify_partial_doubles = true end -=end + + config.filter_run :focus + config.run_all_when_everything_filtered = true + config.disable_monkey_patching! + config.warnings = true end