Browse Source

Merge pull request #1 from baarkerlounger/get_specs_running

Get specs running
pull/2/head
baarkerlounger 3 years ago committed by GitHub
parent
commit
aa4b31b8fc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 98
      .rubocop.yml
  2. 20
      Gemfile
  3. 12
      Rakefile
  4. 25
      spec/features/two_factor_authenticatable_spec.rb
  5. 2
      spec/lib/two_factor_authentication/models/two_factor_authenticatable_spec.rb
  6. 4
      spec/rails_app/Rakefile
  7. 1
      spec/rails_app/app/assets/config/manifest.js
  8. 2
      spec/rails_app/app/models/guest_user.rb
  9. 2
      spec/rails_app/app/models/user.rb
  10. 2
      spec/rails_app/lib/sms_provider.rb
  11. 9
      spec/rails_app/script/rails
  12. 1
      spec/spec_helper.rb
  13. 2
      spec/support/sms_provider.rb

98
.rubocop.yml

@ -4,6 +4,24 @@ AllCops:
- '**/Rakefile'
UseCache: true
Layout/LineLength:
Description: Limit lines to 80 characters.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#80-character-limits
Enabled: true
Max: 100
AllowURI: true
URISchemes:
- http
- https
Layout/DotPosition:
Description: Checks the position of the dot in multi-line method calls.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#consistent-multi-line-chains
Enabled: true
EnforcedStyle: trailing
SupportedStyles:
- leading
- trailing
Lint/AssignmentInCondition:
Description: Don't use assignment in conditions.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#safe-assignment-in-condition
@ -12,11 +30,11 @@ Lint/AssignmentInCondition:
Lint/EachWithObjectArgument:
Description: Check for immutable argument given to each_with_object.
Enabled: true
Lint/HandleExceptions:
Lint/SuppressedException:
Description: Don't suppress exception.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#dont-hide-exceptions
Enabled: true
Lint/LiteralInCondition:
Lint/LiteralAsCondition:
Description: Checks of literals used in conditions.
Enabled: true
Lint/LiteralInInterpolation:
@ -46,15 +64,6 @@ Metrics/CyclomaticComplexity:
cases needed to validate a method.
Enabled: true
Max: 6
Metrics/LineLength:
Description: Limit lines to 80 characters.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#80-character-limits
Enabled: true
Max: 100
AllowURI: true
URISchemes:
- http
- https
Metrics/MethodLength:
Description: Avoid methods longer than 10 lines of code.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#short-methods
@ -82,21 +91,27 @@ Metrics/PerceivedComplexity:
Enabled: true
Max: 7
Rails/ScopeArgs:
Description: Checks the arguments of ActiveRecord scopes.
Naming/AccessorMethodName:
Description: Check the naming of accessor methods for get_/set_.
Enabled: false
Naming/FileName:
Description: Use snake_case for source file names.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#snake-case-files
Enabled: true
Rails/TimeZone:
# The value `strict` means that `Time` should be used with `zone`.
# The value `flexible` allows usage of `in_time_zone` instead of `zone`.
Exclude: []
Naming/PredicateName:
Description: Check the names of predicate methods.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#bool-methods-qmark
Enabled: true
EnforcedStyle: flexible
SupportedStyles:
- strict
- flexible
NamePrefix:
- is_
- has_
- have_
ForbiddenPrefixes:
- is_
Exclude:
- spec/**/*
Style/AccessorMethodName:
Description: Check the naming of accessor methods for get_/set_.
Enabled: false
Style/AndOr:
Description: Use &&/|| instead of and/or.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#no-and-or-or
@ -127,14 +142,6 @@ Style/CollectionMethods:
Style/Documentation:
Description: Document classes and non-namespace modules.
Enabled: false
Style/DotPosition:
Description: Checks the position of the dot in multi-line method calls.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#consistent-multi-line-chains
Enabled: true
EnforcedStyle: trailing
SupportedStyles:
- leading
- trailing
Style/DoubleNegation:
Description: Checks for uses of double negation (!!).
StyleGuide: https://github.com/bbatsov/ruby-style-guide#no-bang-bang
@ -146,11 +153,6 @@ Style/EmptyLiteral:
Description: Prefer literals to Array.new/Hash.new/String.new.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#literal-array-hash
Enabled: true
Style/FileName:
Description: Use snake_case for source file names.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#snake-case-files
Enabled: true
Exclude: []
Style/GuardClause:
Description: Check for conditionals that can be replaced with guard clauses
StyleGuide: https://github.com/bbatsov/ruby-style-guide#no-nested-conditionals
@ -160,7 +162,6 @@ Style/IfUnlessModifier:
Description: Favor modifier if/unless usage when you have a single-line body.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#if-as-a-modifier
Enabled: false
MaxLineLength: 80
Style/InlineComment:
Description: Avoid inline comments.
Enabled: false
@ -193,18 +194,6 @@ Style/PerlBackrefs:
Description: Avoid Perl-style regex back references.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#no-perl-regexp-last-matchers
Enabled: false
Style/PredicateName:
Description: Check the names of predicate methods.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#bool-methods-qmark
Enabled: true
NamePrefix:
- is_
- has_
- have_
NamePrefixBlacklist:
- is_
Exclude:
- spec/**/*
Style/RaiseArgs:
Description: Checks the arguments passed to raise/fail.
StyleGuide: https://github.com/bbatsov/ruby-style-guide#exception-class-messages
@ -272,7 +261,16 @@ Style/TrailingCommaInArguments:
- comma
- consistent_comma
- no_comma
Style/TrailingCommaInLiteral:
Style/TrailingCommaInArrayLiteral:
Description: 'Checks for trailing comma in array and hash literals.'
StyleGuide: 'https://github.com/bbatsov/ruby-style-guide#no-trailing-array-commas'
Enabled: true
EnforcedStyleForMultiline: no_comma
SupportedStyles:
- comma
- consistent_comma
- no_comma
Style/TrailingCommaInHashLiteral:
Description: 'Checks for trailing comma in array and hash literals.'
StyleGuide: 'https://github.com/bbatsov/ruby-style-guide#no-trailing-array-commas'
Enabled: true

20
Gemfile

@ -1,30 +1,34 @@
# frozen_string_literal: true
source 'https://rubygems.org'
# Specify your gem's dependencies in devise_ip_filter.gemspec
gemspec
rails_version = ENV["RAILS_VERSION"] || "default"
rails_version = ENV['RAILS_VERSION'] || 'default'
rails = case rails_version
when "master"
{github: "rails/rails"}
when "default"
"~> 5.2"
when 'master'
{ github: 'rails/rails' }
when 'default'
'~> 7.0.1'
else
"~> #{rails_version}"
end
gem "rails", rails
gem 'rails', rails
if Gem::Version.new(RUBY_VERSION) >= Gem::Version.new('2.2.0')
gem "test-unit", "~> 3.0"
gem 'test-unit', '~> 3.0'
end
group :test, :development do
gem 'pry'
gem 'sprockets-rails'
gem 'sqlite3'
end
group :test do
gem 'rack_session_access'
gem 'ammeter'
gem 'rack_session_access'
end

12
Rakefile

@ -1,14 +1,16 @@
require "bundler/gem_tasks"
# frozen_string_literal: true
APP_RAKEFILE = File.expand_path("../spec/rails_app/Rakefile", __FILE__)
require 'bundler/gem_tasks'
APP_RAKEFILE = File.expand_path('spec/rails_app/Rakefile', __dir__)
load 'rails/tasks/engine.rake'
require 'rspec/core/rake_task'
desc "Run all specs in spec directory (excluding plugin specs)"
RSpec::Core::RakeTask.new(:spec => 'app:db:test:prepare')
desc 'Run all specs in spec directory (excluding plugin specs)'
RSpec::Core::RakeTask.new(spec: 'app:db:test:prepare')
task :default => :spec
task default: :spec
# To test against a specific version of Rails
# export RAILS_VERSION=3.2.0; bundle update; rake

25
spec/features/two_factor_authenticatable_spec.rb

@ -12,7 +12,7 @@ feature "User of two factor authentication" do
end
it 'does not send an SMS before the user has signed in' do
expect(SMSProvider.messages).to be_empty
expect(SmsProvider.messages).to be_empty
end
it 'sends code via SMS after sign in' do
@ -21,8 +21,8 @@ feature "User of two factor authentication" do
expect(page).to have_content 'Enter the code that was sent to you'
expect(SMSProvider.messages.size).to eq(1)
message = SMSProvider.last_message
expect(SmsProvider.messages.size).to eq(1)
message = SmsProvider.last_message
expect(message.to).to eq(user.phone_number)
expect(message.body).to eq(user.reload.direct_otp)
end
@ -33,12 +33,13 @@ feature "User of two factor authentication" do
expect(page).to have_content('You are signed in as Marissa')
fill_in 'code', with: SMSProvider.last_message.body
fill_in 'code', with: SmsProvider.last_message.body
click_button 'Submit'
within('.flash.notice') do
expect(page).to have_content('Two factor authentication successful.')
end
expect(page).to have_selector(
".notice",
text: "Two factor authentication successful."
)
expect(current_path).to eq root_path
end
@ -67,7 +68,7 @@ feature "User of two factor authentication" do
expect(page).to_not have_content("Your Personal Dashboard")
fill_in "code", with: SMSProvider.last_message.body
fill_in "code", with: SmsProvider.last_message.body
click_button "Submit"
expect(page).to have_content("Your Personal Dashboard")
@ -85,9 +86,7 @@ feature "User of two factor authentication" do
fill_in "code", with: "incorrect#{rand(100)}"
click_button "Submit"
within(".flash.alert") do
expect(page).to have_content("Attempt failed")
end
expect(page).to have_selector(".alert", text: "Attempt failed")
end
expect(page).to have_content("Access completely denied")
@ -154,9 +153,9 @@ feature "User of two factor authentication" do
end
def sms_sign_in
SMSProvider.messages.clear()
SmsProvider.messages.clear()
visit user_two_factor_authentication_path
fill_in 'code', with: SMSProvider.last_message.body
fill_in 'code', with: SmsProvider.last_message.body
click_button 'Submit'
end

2
spec/lib/two_factor_authentication/models/two_factor_authenticatable_spec.rb

@ -138,7 +138,7 @@ describe Devise::Models::TwoFactorAuthenticatable do
it "returns uri with user's email" do
expect(instance.provisioning_uri).
to match(%r{otpauth://totp/houdini@example.com\?secret=\w{32}})
to match(%r{otpauth://totp/houdini%40example.com\?secret=\w{32}})
end
it 'returns uri with issuer option' do

4
spec/rails_app/Rakefile

@ -1,7 +1,9 @@
#!/usr/bin/env rake
# frozen_string_literal: true
# Add your own tasks in files placed in lib/tasks ending in .rake,
# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.
require File.expand_path('../config/application', __FILE__)
require File.expand_path('config/application', __dir__)
Dummy::Application.load_tasks

1
spec/rails_app/app/assets/config/manifest.js

@ -1,3 +1,2 @@
//= link_tree ../images
//= link_directory ../javascripts .js
//= link_directory ../stylesheets .css

2
spec/rails_app/app/models/guest_user.rb

@ -7,7 +7,7 @@ class GuestUser
attr_accessor :direct_otp, :direct_otp_sent_at, :otp_secret_key, :email,
:second_factor_attempts_count, :totp_timestamp
def update_attributes(attrs)
def update(attrs)
attrs.each do |key, value|
send(key.to_s + '=', value)
end

2
spec/rails_app/app/models/user.rb

@ -5,7 +5,7 @@ class User < ActiveRecord::Base
has_one_time_password
def send_two_factor_authentication_code(code)
SMSProvider.send_message(to: phone_number, body: code)
SmsProvider.send_message(to: phone_number, body: code)
end
def phone_number

2
spec/rails_app/lib/sms_provider.rb

@ -1,6 +1,6 @@
require 'ostruct'
class SMSProvider
class SmsProvider
Message = Class.new(OpenStruct)
class_attribute :messages

9
spec/rails_app/script/rails

@ -1,6 +1,9 @@
#!/usr/bin/env ruby
# This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application.
# frozen_string_literal: true
APP_PATH = File.expand_path('../../config/application', __FILE__)
require File.expand_path('../../config/boot', __FILE__)
# This command will automatically be run when you run "rails" with Rails 3
# gems installed from the root of your application.
APP_PATH = File.expand_path('../config/application', __dir__)
require File.expand_path('../config/boot', __dir__)
require 'rails/commands'

1
spec/spec_helper.rb

@ -24,3 +24,4 @@ RSpec.configure do |config|
end
Dir["#{Dir.pwd}/spec/support/**/*.rb"].each {|f| require f}
Dir["#{Dir.pwd}/spec/rails_app/lib/*.rb"].each {|f| require f}

2
spec/support/sms_provider.rb

@ -1,5 +1,5 @@
RSpec.configure do |c|
c.before(:each) do
SMSProvider.messages.clear
SmsProvider.messages.clear
end
end

Loading…
Cancel
Save