Uses the frozen_string_literal magic comment (will be the default in Ruby 3)

This commit is contained in:
erwanlr
2019-03-21 17:41:29 +00:00
parent 898e8d4546
commit 047a188b34
256 changed files with 512 additions and 5 deletions

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Controller::Aliases do
subject(:controller) { described_class.new }
let(:target_url) { 'http://ex.lo/' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Controller::Core do
subject(:core) { described_class.new }
let(:target_url) { 'http://ex.lo/' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Controller::CustomDirectories do
subject(:controller) { described_class.new }
let(:target_url) { 'http://ex.lo/' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Controller::Enumeration do
subject(:controller) { described_class.new }
let(:target_url) { 'http://wp.lab/' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Controller::PasswordAttack do
subject(:controller) { described_class.new }
let(:target_url) { 'http://ex.lo/' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
def it_calls_the_formatter_with_the_correct_parameter(version)
it 'calls the formatter with the correct parameter' do
expect(controller.formatter).to receive(:output)

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::ConfigBackups::KnownFilenames do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::ConfigBackups::Base do
subject(:config_backups) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DbExports::KnownLocations do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DbExports::Base do
subject(:db_exports) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::BackupDB do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::DebugLog do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::DuplicatorInstallerLog do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::EmergencyPwdResetScript do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::FullPathDisclosure do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::MuPlugins do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::Multisite do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::Readme do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::Registration do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::TmmDbMigrate do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::UploadDirectoryListing do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::UploadSQLDump do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::WPCron do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::InterestingFindings::Base do
subject(:files) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::MainTheme::CssStyle do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::MainTheme::UrlsInHomepage do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::MainTheme::WooFrameworkMetaGenerator do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::MainTheme::Base do
subject(:main_theme) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Medias::AttachmentBruteForcing do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Medias::Base do
subject(:media) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::PluginVersion::Readme do
subject(:finder) { described_class.new(plugin) }
let(:plugin) { WPScan::Model::Plugin.new('spec', target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
# If this file is tested alone (rspec path-to-this-file), then there will be an error about
# constants not being intilialized. This is due to the Dynamic Finders.

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::BodyPattern do
it_behaves_like WPScan::Finders::DynamicFinder::WpItems::Finder do
subject(:finder) { described_class.new(target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::Comment do
it_behaves_like WPScan::Finders::DynamicFinder::WpItems::Finder do
subject(:finder) { described_class.new(target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::ConfigParser do
xit

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::HeaderPattern do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::JavascriptVar do
it_behaves_like WPScan::Finders::DynamicFinder::WpItems::Finder do
subject(:finder) { described_class.new(target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::KnownLocations do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::QueryParameter do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::UrlsInHomepage do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::Xpath do
it_behaves_like WPScan::Finders::DynamicFinder::WpItems::Finder do
subject(:finder) { described_class.new(target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Plugins::Base do
subject(:plugins) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::ThemeVersion::Style do
subject(:finder) { described_class.new(theme) }
let(:theme) { WPScan::Model::Theme.new('spec', target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::ThemeVersion::WooFrameworkMetaGenerator do
subject(:finder) { described_class.new(theme) }
let(:theme) { WPScan::Model::Theme.new(slug, target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::ThemeVersion::Base do
subject(:theme_version) { described_class.new(theme) }
let(:theme) { WPScan::Model::Plugin.new(slug, target) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Themes::KnownLocations do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Themes::UrlsInHomepage do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Themes::Base do
subject(:themes) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::TimthumbVersion::BadRequest do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Model::Timthumb.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::TimthumbVersion::Base do
subject(:timthumb_version) { described_class.new(target) }
let(:target) { WPScan::Model::Timthumb.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Timthumbs::KnownLocations do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Timthumbs::Base do
subject(:timthumb) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::AuthorIdBruteForcing do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::AuthorPosts do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::LoginErrorMessages do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::OembedApi do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::RSSGenerator do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::WpJsonApi do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::YoastSeoAuthorSitemap do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Users::Base do
subject(:user) { described_class.new(target) }
let(:target) { WPScan::Target.new(url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::WpVersion::AtomGenerator do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::WpVersion::RDFGenerator do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::WpVersion::Readme do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::WpVersion::RSSGenerator do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::WpVersion::UniqueFingerprinting do
subject(:finder) { described_class.new(target) }
let(:target) { WPScan::Target.new(url).extend(CMSScanner::Target::Server::Apache) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
# If this file is tested alone (rspec path-to-this-file), then there will be an error about
# constants not being intilialized. This is due to the Dynamic Finders.

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::InterestingFinding do
it_behaves_like WPScan::References do
subject(:finding) { described_class.new('http://e.org/file.php', opts) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::Media do
subject(:media) { described_class.new(url) }
let(:url) { 'http://e.oeg/?attachment_id=2' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::Plugin do
subject(:plugin) { described_class.new(slug, blog, opts) }
let(:slug) { 'spec' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::Theme do
subject(:theme) { described_class.new(slug, blog, opts) }
let(:slug) { 'spec' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::Timthumb do
subject(:timthumb) { described_class.new(url, opts) }
let(:url) { 'http://wp.lab/wp-content/timthumb.php' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::WpItem do
subject(:wp_item) { described_class.new(slug, blog, opts) }
let(:slug) { 'test_item' }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::WpVersion do
describe '#new' do
context 'when invalid number' do

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Model::XMLRPC do
subject(:xml_rpc) { described_class.new('http//e.org/xmlrpc.php') }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe 'App::Views' do
let(:target_url) { 'http://ex.lo/' }
let(:target) { WPScan::Target.new(target_url) }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Browser do
subject(:browser) { described_class.instance(options) }
before { described_class.reset }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::DynamicFinders::Base do
subject(:dynamic_finders) { described_class }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::DynamicFinders::Plugin do
subject(:dynamic_finders) { described_class }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::DynamicFinders::Theme do
subject(:dynamic_finders) { described_class }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::DynamicFinders::Wordpress do
subject(:dynamic_finders) { described_class }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::Fingerprints do
describe '#unique_fingerprints' do
# Handled in #wp_unique_fingerprints

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::Plugin do
describe '#vulnerabilities' do
# Handled in spec/app/models/plugin_spec

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::Plugins do
subject(:plugins) { described_class }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::Theme do
describe '#vulnerabilities' do
# Handled in spec/app/models/theme_spec

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::Themes do
subject(:themes) { described_class }

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::WpItem do
describe '#vulnerabilities' do
# Handled in spec/app/models/plugin_spec

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::WpItems do
# Handled in plugins_spec & themes_spec
end

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::DB::Version do
describe '#vulnerabilities' do
# Handled in spec/app/models/wp_version_spec

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
# All Plugin Dynamic Finders returning a Version are tested here.
# When adding one to the spec/fixtures/db/dynamic_finder.yml, a few files have
# to be edited/created

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::BodyPattern do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::Comment do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::ConfigParser do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::HeaderPattern do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::JavascriptVar do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::QueryParameter do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::Version::Xpath do
module WPScan
module Finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::DynamicFinder::WpItems::Finder do
# Handled in spec/shared_examples/dynamic_finders/wp_items.rb
end

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
expected_all = df_expected_all['wordpress']
WPScan::DB::DynamicFinders::Wordpress.create_versions_finders

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Finders::Finder::WpVersion::SmartURLChecker do
xit
end

View File

@@ -1,3 +1,5 @@
# frozen_string_literal: true
describe WPScan::Target do
subject(:target) { described_class.new(url) }
let(:url) { 'http://ex.lo' }

Some files were not shown because too many files have changed in this diff Show More