Commit 9eea3623 authored by Douwe Maan's avatar Douwe Maan

Merge branch 'frozen_string_spec_support' into 'master'

Add frozen_string_literal to spec/support

See merge request gitlab-org/gitlab-ce!31132
parents 32be68af d4ef3be3
......@@ -60,8 +60,7 @@ module Gitlab
def get_info(key)
value = info[key]
Gitlab::Utils.force_utf8(value) if value
value
value.is_a?(String) ? Gitlab::Utils.force_utf8(value) : value
end
def username_and_email
......
......@@ -22,7 +22,7 @@ module Gitlab
end
def force_utf8(str)
str.force_encoding(Encoding::UTF_8)
str.dup.force_encoding(Encoding::UTF_8)
end
def ensure_utf8_size(str, bytes:)
......
......@@ -13,7 +13,7 @@ describe 'User browses commits' do
it 'renders commit' do
visit project_commit_path(project, sample_commit.id)
expect(page).to have_content(sample_commit.message.gsub!(/\s+/, ' '))
expect(page).to have_content(sample_commit.message.gsub(/\s+/, ' '))
.and have_content("Showing #{sample_commit.files_changed_count} changed files")
.and have_content('Side-by-side')
end
......
......@@ -40,7 +40,11 @@ describe Gitlab::Auth::OAuth::AuthHash do
last_name: last_name_ascii,
name: name_ascii,
nickname: nickname_ascii,
uid: uid_ascii
uid: uid_ascii,
address: {
locality: 'some locality',
country: 'some country'
}
}
end
......@@ -51,6 +55,7 @@ describe Gitlab::Auth::OAuth::AuthHash do
it { expect(auth_hash.username).to eql nickname_utf8 }
it { expect(auth_hash.name).to eql name_utf8 }
it { expect(auth_hash.password).not_to be_empty }
it { expect(auth_hash.location).to eq 'some locality, some country' }
end
context 'email not provided' do
......
# frozen_string_literal: true
shared_examples_for 'group and project boards' do |route_definition, ee = false|
let(:root_url) { route_definition.gsub(":id", board_parent.id.to_s) }
......
# frozen_string_literal: true
shared_examples 'creating an issue resolving discussions through the API' do
it 'creates a new project issue' do
expect(response).to have_gitlab_http_status(:created)
......
# frozen_string_literal: true
shared_examples 'a 404 response when source is private' do
before do
source.update_column(:visibility_level, Gitlab::VisibilityLevel::PRIVATE)
......
# frozen_string_literal: true
shared_examples_for 'group and project milestones' do |route_definition|
let(:resource_route) { "#{route}/#{milestone.id}" }
let(:label_1) { create(:label, title: 'label_1', project: project, priority: 1) }
......
# frozen_string_literal: true
shared_context 'disabled repository' do
before do
project.project_feature.update!(
......
# frozen_string_literal: true
module SchemaPath
def self.expand(schema, dir = nil)
if Gitlab.ee? && dir.nil?
......
# frozen_string_literal: true
shared_examples_for 'allows the "read_user" scope' do |api_version|
let(:version) { api_version || 'v4' }
......
# frozen_string_literal: true
shared_examples 'an unauthorized API user' do
it { is_expected.to eq(403) }
end
......
# frozen_string_literal: true
# Specs for reference links containing HTML.
#
# Requires a reference:
......
# frozen_string_literal: true
RSpec.configure do |config|
config.after do
BatchLoader::Executor.clear_current
......
# frozen_string_literal: true
# rubocop:disable Style/GlobalVars
require 'capybara/rails'
require 'capybara/rspec'
......
# frozen_string_literal: true
CarrierWave.root = File.expand_path('tmp/tests/public', Rails.root)
RSpec.configure do |config|
......
# frozen_string_literal: true
module ChunkedIOHelpers
def sample_trace_raw
@sample_trace_raw ||= File.read(expand_fixture_path('trace/sample_trace'))
......
# frozen_string_literal: true
module CommitTrailersSpecHelper
extend ActiveSupport::Concern
......
# frozen_string_literal: true
shared_context 'a GitHub-ish import controller' do
let(:user) { create(:user) }
let(:token) { "asdasd12345" }
......
# frozen_string_literal: true
# Specifications for behavior common to all objects with an email attribute.
# Takes a list of email-format attributes and requires:
# - subject { "the object with a attribute= setter" }
......
# frozen_string_literal: true
require 'spec_helper'
shared_context 'Ldap::OmniauthCallbacksController' do
......
# frozen_string_literal: true
shared_examples 'authenticates sessionless user' do |path, format, params|
params ||= {}
......
# frozen_string_literal: true
# rubocop:disable Metrics/AbcSize
# Note: The ABC size is large here because we have a method generating test cases with
......
# frozen_string_literal: true
module DbCleaner
def delete_from_all_tables!(except: nil)
DatabaseCleaner.clean_with(:deletion, cache_tables: false, except: except)
......
# frozen_string_literal: true
module ExternalAuthorizationServiceHelpers
def enable_external_authorization_service_check
stub_application_setting(external_authorization_service_enabled: true)
......
# frozen_string_literal: true
shared_examples 'thread comments' do |resource_name|
let(:form_selector) { '.js-main-target-form' }
let(:dropdown_selector) { "#{form_selector} .comment-type-dropdown" }
......
# frozen_string_literal: true
require 'spec_helper'
shared_examples 'reportable note' do |type|
......
# frozen_string_literal: true
shared_examples 'creating an issue for a thread' do
it 'shows an issue with the title filled in' do
title_field = page.find_field('issue[title]')
......
# frozen_string_literal: true
shared_examples "an autodiscoverable RSS feed with current_user's feed token" do
it "has an RSS autodiscovery link tag with current_user's feed token" do
expect(page).to have_css("link[type*='atom+xml'][href*='feed_token=#{user.feed_token}']", visible: false)
......
# frozen_string_literal: true
shared_examples 'variable list' do
it 'shows list of variables' do
page.within('.js-ci-variable-list-section') do
......
# frozen_string_literal: true
module ForgeryProtection
def with_forgery_protection
ActionController::Base.allow_forgery_protection = true
......
# frozen_string_literal: true
module GoogleApi
module CloudPlatformHelpers
def stub_google_api_validate_token
......
# frozen_string_literal: true
module ApiHelpers
# Public: Prepend a request path with the path to the API
#
......@@ -30,11 +32,12 @@ module ApiHelpers
end
if query_string
full_path << (path.index('?') ? '&' : '?')
full_path << query_string
end
separator = path.index('?') ? '&' : '?'
full_path
full_path + separator + query_string
else
full_path
end
end
def expect_paginated_array_response(items)
......
# frozen_string_literal: true
module AssetsHelpers
# In a CI environment the assets are not compiled, as there is a CI job
# `compile-assets` that compiles them in the prepare stage for all following
......
# frozen_string_literal: true
require 'zlib'
class BareRepoOperations
......
# frozen_string_literal: true
module BoardHelpers
def click_card(card)
within card do
......
# frozen_string_literal: true
module CapybaraHelpers
# Execute a block a certain number of times before considering it a failure
#
......
# frozen_string_literal: true
# frozen_sting_literal: true
# This generates fake CI metadata .gz for testing
......
# frozen_string_literal: true
# Helper for setting cookies in Selenium/WebDriver
#
module CookieHelper
......
# frozen_string_literal: true
module CycleAnalyticsHelpers
include GitHelpers
......
# frozen_string_literal: true
module DatabaseConnectionHelpers
def run_with_new_database_connection
pool = ActiveRecord::Base.connection_pool
......
# frozen_string_literal: true
module DeviseHelpers
# explicitly tells Devise which mapping to use
# this is needed when we are testing a Devise controller bypassing the router
......
# frozen_string_literal: true
module DragTo
def drag_to(list_from_index: 0, from_index: 0, to_index: 0, list_to_index: 0, selector: '', scrollable: 'body', duration: 1000)
evaluate_script("simulateDrag({scrollable: $('#{scrollable}').get(0), duration: #{duration}, from: {el: $('#{selector}').eq(#{list_from_index}).get(0), index: #{from_index}}, to: {el: $('#{selector}').eq(#{list_to_index}).get(0), index: #{to_index}}});")
......
# frozen_string_literal: true
module DropzoneHelper
# Provides a way to perform `attach_file` for a Dropzone-based file input
#
......
# frozen_string_literal: true
module EmailHelpers
def sent_to_user(user, recipients: email_recipients)
recipients.count { |to| to == user.notification_email }
......
# frozen_string_literal: true
module ExclusiveLeaseHelpers
def stub_exclusive_lease(key = nil, uuid = 'uuid', renew: false, timeout: nil)
key ||= instance_of(String)
......
# frozen_string_literal: true
module ExpectNextInstanceOf
def expect_next_instance_of(klass, *new_args)
receive_new = receive(:new)
......
# frozen_string_literal: true
require 'rubocop/rspec/support'
# https://github.com/backus/rubocop-rspec/blob/master/spec/support/expect_offense.rb
......
# frozen_string_literal: true
module FakeBlobHelpers
class FakeBlob
include BlobLike
......
# frozen_string_literal: true
class FakeRenameReservedPathMigrationV1 < ActiveRecord::Migration[4.2]
include Gitlab::Database::RenameReservedPathsMigration::V1
......
# frozen_string_literal: true
class FakeU2fDevice
attr_reader :name
......
# frozen_string_literal: true
# These helpers allow you to manipulate with sorting features.
#
# Usage:
......
# frozen_string_literal: true
# These helpers allow you to manipulate with notes.
#
# Usage:
......
# frozen_string_literal: true
# These helpers allow you to manipulate with sorting features.
#
# Usage:
......
# frozen_string_literal: true
# Helper methods for Banzai filter specs
#
# Must be included into specs manually
......
# frozen_string_literal: true
module FilteredSearchHelpers
def filtered_search
page.find('.filtered-search')
......
# frozen_string_literal: true
module FixtureHelpers
def fixture_file(filename, dir: '')
return '' if filename.blank?
......
# frozen_string_literal: true
require_relative 'workhorse_helpers'
module GitHttpHelpers
......
# frozen_string_literal: true
module GitlabVerifyHelpers
def collect_ranges(args = {})
verifier = described_class.new(args.merge(batch_size: 1))
......
# frozen_string_literal: true
module GraphqlHelpers
MutationDefinition = Struct.new(:query, :variables)
......
# frozen_string_literal: true
require 'ostruct'
# Helper methods for controller specs in the Import namespace
......
# frozen_string_literal: true
# see app/assets/javascripts/test_utils/simulate_input.js
module InputHelper
......
# frozen_string_literal: true
require_relative './wait_for_requests'
module InspectRequests
......
# frozen_string_literal: true
module IssueHelpers
def visit_issues(project, opts = {})
visit project_issues_path project, opts
......
# frozen_string_literal: true
require 'action_dispatch/testing/test_request'
require 'fileutils'
......
# frozen_string_literal: true
module JiraServiceHelper
JIRA_URL = "http://jira.example.net".freeze
JIRA_API = JIRA_URL + "/rest/api/2"
......
# frozen_string_literal: true
module Spec
module Support
module Helpers
......
# frozen_string_literal: true
module KubernetesHelpers
include Gitlab::Kubernetes
......
# frozen_string_literal: true
module LdapHelpers
def ldap_adapter(provider = 'ldapmain', ldap = double(:ldap))
::Gitlab::Auth::LDAP::Adapter.new(provider, ldap)
......
# frozen_string_literal: true
require 'io/console'
module LiveDebugger
......
# frozen_string_literal: true
require_relative 'devise_helpers'
module LoginHelpers
......
# frozen_string_literal: true
# This is a helper class used by the GitLab Markdown feature spec
#
# Because the feature spec only cares about the output of the Markdown, and the
......
# frozen_string_literal: true
module MergeRequestDiffHelpers
def click_diff_line(line_holder, diff_side = nil)
line = get_line_components(line_holder, diff_side)
......
# frozen_string_literal: true
module MergeRequestHelpers
def visit_merge_requests(project, opts = {})
visit project_merge_requests_path project, opts
......
# frozen_string_literal: true
module MigrationsHelpers
def active_record_base
ActiveRecord::Base
......
# frozen_string_literal: true
module MobileHelpers
def resize_screen_xs
resize_window(575, 768)
......
# frozen_string_literal: true
module NoteInteractionHelpers
def open_more_actions_dropdown(note)
note_element = find("#note_#{note.id}")
......
# frozen_string_literal: true
module NotificationHelpers
extend self
......
# frozen_string_literal: true
module ProjectForksHelper
def fork_project(project, user = nil, params = {})
Gitlab::GitalyClient.allow_n_plus_1_calls do
......
# frozen_string_literal: true
module PrometheusHelpers
def prometheus_memory_query(environment_slug)
%{avg(container_memory_usage_bytes{container_name!="POD",environment="#{environment_slug}"}) / 2^20}
......
# frozen_string_literal: true
module ActiveRecord
class QueryRecorder
attr_reader :log, :skip_cached, :cached
......
# frozen_string_literal: true
module QuickActionsHelpers
def write_note(text)
Sidekiq::Testing.fake! do
......
# frozen_string_literal: true
module RakeHelpers
def run_rake_task(task_name, *args)
Rake::Task[task_name].reenable
......
# frozen_string_literal: true
module ReactiveCachingHelpers
def reactive_cache_key(subject, *qualifiers)
([subject.class.reactive_cache_key.call(subject)].flatten + qualifiers).join(':')
......
# frozen_string_literal: true
class Redis
ForbiddenCommand = Class.new(StandardError)
......
# frozen_string_literal: true
module ReferenceParserHelpers
def empty_html_link
Nokogiri::HTML.fragment('<a></a>').children[0]
......
# frozen_string_literal: true
module RepoHelpers
extend self
......
# frozen_string_literal: true
module RoutesHelpers
def fake_routes(&block)
@routes = @routes.dup
......
# frozen_string_literal: true
module SearchHelpers
def select_filter(name)
find(:xpath, "//ul[contains(@class, 'search-filter')]//a[contains(.,'#{name}')]").click
......
# frozen_string_literal: true
# This file is generated by generate-seed-repo-rb. Do not edit this file manually.
#
# Seed repo:
......
# frozen_string_literal: true
require_relative 'wait_for_requests'
# Select2 ajax programmatic helper
......
# frozen_string_literal: true
module SelectionHelper
def select_element(selector)
find(selector)
......
# frozen_string_literal: true
# Helper allows you to sort items
#
# Params
......
# frozen_string_literal: true
require 'active_support/core_ext/hash/transform_values'
require 'active_support/hash_with_indifferent_access'
require 'active_support/dependencies'
......
# frozen_string_literal: true
# Inspired by https://github.com/ljkbennett/stub_env/blob/master/lib/stub_env/helpers.rb
module StubENV
def stub_env(key_or_hash, value = nil)
......
# frozen_string_literal: true
module StubFeatureFlags
# Stub Feature flags with `flag_name: true/false`
#
......
# frozen_string_literal: true
module StubGitlabCalls
def stub_gitlab_calls
stub_user
......
# frozen_string_literal: true
module StubGitlabData
def gitlab_ci_yaml
File.read(Rails.root.join('spec/support/gitlab_stubs/gitlab_ci.yml'))
......
# frozen_string_literal: true
module StubMetrics
def authentication_metrics
Gitlab::Auth::Activity
......
# frozen_string_literal: true
module StubObjectStorage
def stub_object_storage_uploader(
config:,
......
# frozen_string_literal: true
module StubRequests
IP_ADDRESS_STUB = '8.8.8.9'.freeze
......
# frozen_string_literal: true
# Inspired by https://github.com/ljkbennett/stub_env/blob/master/lib/stub_env/helpers.rb
module StubWorker
def stub_worker(queue:)
......
# frozen_string_literal: true
module TermsHelper
def enforce_terms
stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false')
......
# frozen_string_literal: true
require 'rspec/mocks'
require 'toml-rb'
......
# frozen_string_literal: true
require 'fileutils'
module UploadHelpers
......
# frozen_string_literal: true
module WaitForRequests
extend self
......
# frozen_string_literal: true
module WaitHelpers
extend self
......
# frozen_string_literal: true
module WikiHelpers
extend self
......
# frozen_string_literal: true
module WorkhorseHelpers
extend self
......
# frozen_string_literal: true
module HttpIOHelpers
def stub_remote_url_206(url, file_path)
WebMock.stub_request(:get, url)
......
# frozen_string_literal: true
module ImportExport
module CommonUtil
def setup_symlink(tmpdir, symlink_name)
......
# frozen_string_literal: true
module ConfigurationHelper
# Returns a list of models from hashes/arrays contained in +project_tree+
def names_from_tree(project_tree)
......
# frozen_string_literal: true
require './spec/support/import_export/configuration_helper'
module ExportFileHelper
......
# frozen_string_literal: true
# This class can generate a lot of output if it fails,
# so squelch the instance variable output.
class ActiveSupport::Cache::NullStore
......
# frozen_string_literal: true
shared_examples 'issuables requiring filter' do |action|
it "doesn't load any issuables if no filter is set" do
expect_any_instance_of(described_class).not_to receive(:issuables_collection)
......
# frozen_string_literal: true
RSpec.configure do |config|
config.include_context 'JSON response', type: :controller
config.include_context 'JSON response', type: :request
......
# frozen_string_literal: true
RSpec::Matchers.define :abort_execution do
match do |code_block|
@captured_stderr = StringIO.new
......
# frozen_string_literal: true
# AccessMatchers
#
# The custom matchers contained in this module are used to test a user's access
......
# frozen_string_literal: true
# AccessMatchersForController
#
# For testing authorize_xxx in controller.
......
# frozen_string_literal: true
RSpec::Matchers.define :be_scheduled_delayed_migration do |delay, *expected|
match do |migration|
BackgroundMigrationWorker.jobs.any? do |job|
......
# frozen_string_literal: true
RSpec::Matchers.define :be_a_binary_string do |_|
match do |actual|
actual.is_a?(String) && actual.encoding == Encoding.find('ASCII-8BIT')
......
# frozen_string_literal: true
RSpec::Matchers.define :be_like_time do |expected|
match do |actual|
expect(actual).to be_within(1.second).of(expected)
......
# frozen_string_literal: true
RSpec::Matchers.define :be_url do |_|
match do |actual|
URI.parse(actual) rescue false
......
# frozen_string_literal: true
RSpec::Matchers.define :be_utf8 do |_|
match do |actual|
actual.is_a?(String) && actual.encoding == Encoding.find('UTF-8')
......
# frozen_string_literal: true
RSpec::Matchers.define :be_valid_commit do
match do |actual|
actual &&
......
# frozen_string_literal: true
RSpec::Matchers.define :disallow_request do
match do |middleware|
alert = middleware.env['rack.session'].to_hash
......
# frozen_string_literal: true
module ExceedQueryLimitHelpers
def with_threshold(threshold)
@threshold = threshold
......
# frozen_string_literal: true
RSpec::Matchers.define :execute_check do |expected|
match do |actual|
expect(actual).to eq(SystemCheck)
......
# frozen_string_literal: true
RSpec::Matchers.define :gitaly_request_with_path do |storage_name, relative_path|
match do |actual|
repository = actual.repository
......
# frozen_string_literal: true
RSpec::Matchers.define :gitlab_git_repository_with do |values|
match do |actual|
actual.is_a?(Gitlab::Git::Repository) &&
......
# frozen_string_literal: true
RSpec::Matchers.define :require_graphql_authorizations do |*expected|
match do |field|
expect(field.metadata[:authorize]).to eq(*expected)
......
# frozen_string_literal: true
RSpec::Matchers.define :have_emoji do |emoji_name|
match do |actual|
expect(actual).to have_selector("gl-emoji[data-name='#{emoji_name}']")
......
# frozen_string_literal: true
RSpec::Matchers.define :have_gitlab_http_status do |expected|
match do |actual|
expect(actual).to have_http_status(expected)
......
# frozen_string_literal: true
RSpec::Matchers.define :have_issuable_counts do |opts|
expected_counts = opts.map do |state, count|
"#{state.to_s.humanize} #{count}"
......
# frozen_string_literal: true
RSpec::Matchers.define :include_module do |expected|
match do
described_class.included_modules.include?(expected)
......
# frozen_string_literal: true
RSpec::Matchers.define :have_header_with_correct_id_and_link do |level, text, id, parent = ".md"|
match do |actual|
node = find("#{parent} h#{level} a#user-content-#{id}")
......
# frozen_string_literal: true
# MarkdownMatchers
#
# Custom matchers for our custom HTML::Pipeline filters. These are used to test
......
# frozen_string_literal: true
RSpec::Matchers.define :match_file do |expected|
match do |actual|
expect(Digest::MD5.hexdigest(actual)).to eq(Digest::MD5.hexdigest(File.read(expected)))
......
# frozen_string_literal: true
RSpec::Matchers.define :match_ids do |*expected|
match do |actual|
actual_ids = map_ids(actual)
......
# frozen_string_literal: true
RSpec::Matchers.define :increment do |counter|
match do |adapter|
expect(adapter.send(counter))
......
# frozen_string_literal: true
RSpec::Matchers.define :have_active_navigation do |expected|
match do |page|
expect(page).to have_selector('.sidebar-top-level-items > li.active', count: 1)
......
# frozen_string_literal: true
RSpec::Matchers.define :include_pagination_headers do |expected|
match do |actual|
expect(actual.headers).to include('X-Total', 'X-Total-Pages', 'X-Per-Page', 'X-Page', 'X-Next-Page', 'X-Prev-Page', 'Link')
......
# frozen_string_literal: true
RSpec::Matchers.define :make_queries_matching do |matcher, expected_count = nil|
supports_block_expectations
......
# frozen_string_literal: true
# These matchers are a syntactic hack to provide more readable expectations for
# an Enumerable object.
#
......
# frozen_string_literal: true
RSpec::Matchers.define :include_security_headers do |expected|
match do |actual|
expect(actual.headers).to include('X-Content-Type-Options')
......
# frozen_string_literal: true
module MigrationsHelpers
module TrackUntrackedUploadsHelpers
PUBLIC_DIR = File.join(Rails.root, 'tmp', 'tests', 'public')
......
# frozen_string_literal: true
OmniAuth.config.test_mode = true
# frozen_string_literal: true
RSpec.shared_examples 'additional metrics query' do
include Prometheus::MetricBuilders
......
# frozen_string_literal: true
module Prometheus
module MetricBuilders
def simple_query(suffix = 'a', **opts)
......
# frozen_string_literal: true
RSpec.shared_examples "protected tags > access control > CE" do
ProtectedRefAccess::HUMAN_ACCESS_LEVELS.each do |(access_type_id, access_type_name)|
it "allows creating protected tags that #{access_type_name} can create" do
......
# frozen_string_literal: true
module RedisHelpers
# config/README.md
......
# frozen_string_literal: true
RSpec.shared_examples "redis_shared_examples" do
include StubENV
......
# frozen_string_literal: true
require_relative "helpers/stub_configuration"
require_relative "helpers/stub_metrics"
require_relative "helpers/stub_object_storage"
......
# frozen_string_literal: true
RSpec.configure do |config|
config.include SeedHelper, :seed_helper
......
# frozen_string_literal: true
shared_context 'valid cluster create params' do
let(:params) do
{
......
# frozen_string_literal: true
# Specifications for behavior common to all objects with executable attributes.
# It can take a `default_params`.
......
# frozen_string_literal: true
shared_examples 'issuable update service' do
def update_issuable(opts)
described_class.new(project, user, opts).execute(open_issuable)
......
# frozen_string_literal: true
require "spec_helper"
shared_examples "migrating a deleted user's associated records to the ghost user" do |record_class, fields|
......
# frozen_string_literal: true
RSpec.configure do |config|
def builds_path
Rails.root.join('tmp/tests/builds')
......
# frozen_string_literal: true
shared_context :email_shared_context do
let(:mail_key) { "59d8df8370b7e95c5a49fbf86aeb2c93" }
let(:receiver) { Gitlab::Email::Receiver.new(email_raw) }
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.shared_context 'GroupProjectsFinder context' do
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.shared_context 'IssuesFinder context' do
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.shared_context 'MergeRequestsFinder multiple projects with merge requests context' do
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.shared_context 'UsersFinder#execute filter by project context' do
......
# frozen_string_literal: true
shared_context 'JSON response' do
let(:json_response) { JSON.parse(response.body) }
end
# frozen_string_literal: true
shared_context 'merge request allowing collaboration' do
include ProjectForksHelper
......
# frozen_string_literal: true
Service.available_services_names.each do |service|
shared_context service do
let(:dashed_service) { service.dasherize }
......
# frozen_string_literal: true
shared_context 'invalid urls' do
let(:urls_with_CRLF) do
["http://127.0.0.1:333/pa\rth",
......
# frozen_string_literal: true
RSpec.shared_examples 'chat slash commands service' do
describe "Associations" do
it { is_expected.to respond_to :token }
......
# frozen_string_literal: true
shared_examples_for 'common trace features' do
describe '#html' do
before do
......
# frozen_string_literal: true
shared_examples 'system note creation' do |update_params, note_text|
subject { described_class.new(project, user).execute(issuable, old_labels: []) }
......
# frozen_string_literal: true
require 'spec_helper'
shared_examples 'disabled when using an external authorization service' do
......
# frozen_string_literal: true
shared_examples 'issuable notes filter' do
let(:params) do
if issuable_parent.is_a?(Project)
......
# frozen_string_literal: true
shared_examples 'set sort order from user preference' do
describe '#set_sort_order_from_user_preference' do
# There is no issuable_sorting_field defined in any CE controllers yet,
......
# frozen_string_literal: true
shared_examples 'todos actions' do
context 'when authorized' do
before do
......
# frozen_string_literal: true
shared_examples 'handle uploads' do
let(:user) { create(:user) }
let(:jpg) { fixture_file_upload('spec/fixtures/rails_sample.jpg', 'image/jpg') }
......
# frozen_string_literal: true
shared_examples 'GET #show lists all variables' do
it 'renders the variables as json' do
subject
......
# frozen_string_literal: true
shared_examples 'dirty submit form' do |selector_args|
selectors = selector_args.is_a?(Array) ? selector_args : [selector_args]
......
# frozen_string_literal: true
# Specifications for behavior common to all objects with an email attribute.
# Takes a list of email-format attributes and requires:
# - subject { "the object with a attribute= setter" }
......
# frozen_string_literal: true
shared_examples_for 'fast destroyable' do
describe 'Forbid #destroy and #destroy_all' do
it 'does not delete database rows and associted external data' do
......
# frozen_string_literal: true
shared_examples 'comment on merge request file' do
it 'adds a comment' do
click_diff_line(find("[id='#{sample_commit.line_code}']"))
......
# frozen_string_literal: true
RSpec.shared_examples 'a creatable merge request' do
include WaitForRequests
......
# frozen_string_literal: true
RSpec.shared_examples 'an editable merge request' do
it 'updates merge request', :js do
find('.js-assignee-search').click
......
# frozen_string_literal: true
shared_examples 'issue sidebar stays collapsed on mobile' do
before do
resize_screen_xs
......
# frozen_string_literal: true
shared_examples 'issuable user dropdown behaviors' do
include FilteredSearchHelpers
......
# frozen_string_literal: true
RSpec.shared_examples 'Maintainer manages access requests' do
let(:user) { create(:user) }
let(:maintainer) { create(:user) }
......
# frozen_string_literal: true
shared_examples 'project features apply to issuables' do |klass|
let(:described_class) { klass }
......
# frozen_string_literal: true
shared_examples "protected branches > access control > CE" do
ProtectedRefAccess::HUMAN_ACCESS_LEVELS.each do |(access_type_id, access_type_name)|
it "allows creating protected branches that #{access_type_name} can push to" do
......
# frozen_string_literal: true
shared_examples 'top right search form' do
it 'does not show top right search form' do
expect(page).not_to have_selector('.search')
......
# frozen_string_literal: true
shared_examples 'file finder' do
let(:query) { 'files' }
let(:search_results) { subject.find(query) }
......
# frozen_string_literal: true
require 'spec_helper'
shared_examples 'a finder with external authorization service' do
......
# frozen_string_literal: true
RSpec.shared_examples 'Gitlab::Verify::BatchVerifier subclass' do
describe 'batching' do
let(:first_batch) { objects[0].id..objects[0].id }
......
# frozen_string_literal: true
RSpec.shared_examples 'issuable state' do
it 'exposes all the existing issuable states' do
expect(described_class.values.keys).to include(*%w[opened closed locked])
......
# frozen_string_literal: true
RSpec.shared_examples 'members and requesters associations' do
describe '#members_and_requesters' do
it 'includes members and requesters' do
......
# frozen_string_literal: true
shared_examples 'helm commands' do
describe '#generate_script' do
let(:helm_setup) do
......
# frozen_string_literal: true
shared_examples 'cache counters invalidator' do
it 'invalidates counter cache for assignees' do
expect_any_instance_of(User).to receive(:invalidate_merge_request_cache_counts)
......
# frozen_string_literal: true
shared_examples 'issuables list meta-data' do |issuable_type, action = nil|
include ProjectForksHelper
......
# frozen_string_literal: true
RSpec.shared_examples 'issue tracker service URL attribute' do |url_attr|
it { is_expected.to allow_value('https://example.com').for(url_attr) }
......
# frozen_string_literal: true
shared_examples_for 'normalizes a DN' do
using RSpec::Parameterized::TableSyntax
......
# frozen_string_literal: true
shared_examples 'redirecting a legacy path' do |source, target|
include RSpec::Rails::RequestExampleGroup
......
# frozen_string_literal: true
shared_examples 'backfill migration for project repositories' do |storage|
describe '#perform' do
let(:storage_versions) { storage == :legacy ? [nil, 0] : [1, 2] }
......
# frozen_string_literal: true
require 'timeout'
shared_examples 'malicious regexp' do
......
# frozen_string_literal: true
# Specifications for behavior common to all Mentionable implementations.
# Requires a shared context containing:
# - subject { "the mentionable implementation" }
......
# frozen_string_literal: true
shared_examples 'milestone tabs' do
def go(path, extra_params = {})
params =
......
# frozen_string_literal: true
require 'spec_helper'
shared_examples_for 'AtomicInternalId' do |validate_presence: true|
......
# frozen_string_literal: true
require "spec_helper"
shared_examples_for "chat service" do |service_name|
......
# frozen_string_literal: true
shared_examples 'cluster application core specs' do |application_name|
it { is_expected.to belong_to(:cluster) }
it { is_expected.to validate_presence_of(:cluster) }
......
# frozen_string_literal: true
shared_examples 'cluster application helm specs' do |application_name|
let(:application) { create(application_name) }
......
# frozen_string_literal: true
shared_examples 'cluster application status specs' do |application_name|
describe '#status' do
let(:cluster) { create(:cluster, :provided_by_gcp) }
......
# frozen_string_literal: true
# This shared example requires a `builder` and `user` variable
shared_examples 'issuable hook data' do |kind|
let(:data) { builder.build(user: user) }
......
# frozen_string_literal: true
RSpec.shared_examples 'members notifications' do |entity_type|
let(:notification_service) { double('NotificationService').as_null_object }
......
# frozen_string_literal: true
shared_examples 'project hook data with deprecateds' do |project_key: :project|
it 'contains project data' do
expect(data[project_key][:name]).to eq(project.name)
......
# frozen_string_literal: true
require 'spec_helper'
shared_examples_for 'model with uploads' do |supports_fileuploads|
......
# frozen_string_literal: true
shared_context 'gitlab email notification' do
set(:group) { create(:group) }
set(:subgroup) { create(:group, parent: group) }
......
# frozen_string_literal: true
shared_examples_for "position formatter" do
let(:formatter) { described_class.new(attrs) }
......
# frozen_string_literal: true
RSpec.shared_examples "referenced feature visibility" do |*related_features|
let(:feature_fields) do
related_features.map { |feature| (feature + "_access_level").to_sym }
......
# frozen_string_literal: true
shared_examples 'custom attributes endpoints' do |attributable_name|
let!(:custom_attribute1) { attributable.custom_attributes.create key: 'foo', value: 'foo' }
let!(:custom_attribute2) { attributable.custom_attributes.create key: 'bar', value: 'bar' }
......
# frozen_string_literal: true
shared_examples 'diff discussions API' do |parent_type, noteable_type, id_name|
describe "GET /#{parent_type}/:id/#{noteable_type}/:noteable_id/discussions" do
it "includes diff discussions" do
......
# frozen_string_literal: true
shared_examples 'discussions API' do |parent_type, noteable_type, id_name, can_reply_to_individual_notes: false|
describe "GET /#{parent_type}/:id/#{noteable_type}/:noteable_id/discussions" do
it "returns an array of discussions" do
......
# frozen_string_literal: true
shared_examples 'issuable participants endpoint' do
let(:area) { entity.class.name.underscore.pluralize }
......
# frozen_string_literal: true
def get_issue
json_response.is_a?(Array) ? json_response.detect {|issue| issue['id'] == target_issue.id} : json_response
end
......
# frozen_string_literal: true
shared_examples 'noteable API' do |parent_type, noteable_type, id_name|
describe "GET /#{parent_type}/:id/#{noteable_type}/:noteable_id/notes" do
context 'sorting' do
......
# frozen_string_literal: true
shared_examples 'resolvable discussions API' do |parent_type, noteable_type, id_name|
describe "PUT /#{parent_type}/:id/#{noteable_type}/:noteable_id/discussions/:discussion_id" do
it "resolves discussion if resolved is true" do
......
# frozen_string_literal: true
# Specs for status checking.
#
# Requires an API request:
......
# frozen_string_literal: true
require 'spec_helper'
shared_examples 'a working graphql query' do
......
# frozen_string_literal: true
shared_examples 'note entity' do
subject { entity.as_json }
......
# frozen_string_literal: true
shared_examples 'boards create service' do
context 'when parent does not have a board' do
it 'creates a new board' do
......
# frozen_string_literal: true
shared_examples 'boards list service' do
context 'when parent does not have a board' do
it 'creates a new parent board' do
......
# frozen_string_literal: true
shared_examples 'issues list service' do
it 'delegates search to IssuesFinder' do
params = { board_id: board.id, id: list1.id }
......
# frozen_string_literal: true
shared_examples 'issues move service' do |group|
shared_examples 'updating timestamps' do
it 'updates updated_at' do
......
# frozen_string_literal: true
shared_examples 'lists destroy service' do
context 'when list type is label' do
it 'removes list from board' do
......
# frozen_string_literal: true
shared_examples 'lists list service' do
context 'when the board has a backlog list' do
let!(:backlog_list) { create(:backlog_list, board: board) }
......
# frozen_string_literal: true
shared_examples 'lists move service' do
let!(:planning) { create(:list, board: board, position: 0) }
let!(:development) { create(:list, board: board, position: 1) }
......
# frozen_string_literal: true
shared_examples 'check ingress ip executions' do |app_name|
describe '#execute' do
let(:application) { create(app_name, :installed) }
......
# frozen_string_literal: true
shared_examples 'gitlab projects import validations' do
context 'with an invalid path' do
let(:path) { '/invalid-path/' }
......
# frozen_string_literal: true
Dir[Rails.root.join("app/models/project_services/chat_message/*.rb")].each { |f| require f }
RSpec.shared_examples 'slack or mattermost notifications' do
......
# frozen_string_literal: true
RSpec.shared_examples 'snippet visibility' do
using RSpec::Parameterized::TableSyntax
......
# frozen_string_literal: true
# These shared examples expect a `snippets` array of snippets
RSpec.shared_examples 'paginated snippets' do |remote: false|
it "is limited to #{Snippet.default_per_page} items per page" do
......
# frozen_string_literal: true
# Specs for task state functionality for issues and merge requests.
#
# Requires a context containing:
......
# frozen_string_literal: true
shared_examples_for 'throttled touch' do
describe '#touch' do
it 'updates the updated_at timestamp' do
......
# frozen_string_literal: true
shared_context 'unique ips sign in limit' do
include StubENV
before do
......
# frozen_string_literal: true
shared_examples 'update invalid issuable' do |klass|
let(:params) do
{
......
# frozen_string_literal: true
RSpec.shared_examples 'updating mentions' do |service_class|
let(:mentioned_user) { create(:user) }
let(:service_class) { service_class }
......
# frozen_string_literal: true
shared_examples "matches the method pattern" do |method|
let(:target) { subject }
let(:args) { nil }
......
# frozen_string_literal: true
shared_context 'with storage' do |store, **stub_params|
before do
subject.object_store = store
......
# frozen_string_literal: true
RSpec.shared_examples 'url validator examples' do |schemes|
let(:validator) { described_class.new(attributes: [:link_url], **options) }
let!(:badge) { build(:badge, link_url: 'http://www.example.com') }
......
# frozen_string_literal: true
require 'sidekiq/testing/inline'
# If Sidekiq::Testing.inline! is used, SQL transactions done inside
......
# frozen_string_literal: true
RSpec.configure do |config|
config.before(:each, :broken_storage) do
allow(Gitlab::GitalyClient).to receive(:call) do
......
# frozen_string_literal: true
module TestReportsHelper
def create_test_case_rspec_success(name = 'test_spec')
Gitlab::Ci::Reports::TestCase.new(
......
# frozen_string_literal: true
module TraceHelpers
def create_legacy_trace(build, content)
File.open(legacy_trace_path(build), 'wb') { |stream| stream.write(content) }
......
# frozen_string_literal: true
require 'webmock'
require 'webmock/rspec'
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment