DEV: Don't user before(:all)/after(:all) (#13389)

Leaking state and non-obvious order (before :all runs *before* RailsHelper.test_setup) are not worth it.
A replacement PR for #13370. Fixes some flaky specs, e.g.
```
bin/rspec './spec/components/freedom_patches/translate_accelerator_spec.rb[1:3]' './spec/jobs/clean_up_user_export_topics_spec.rb[1:1]' --tag ~type:multisite --seed 35994
```

Also included:
* DEV: No need for locale reset (we do it anyway in rails_helper in `test_setup`)
This commit is contained in:
Jarek Radosz 2021-06-15 17:25:06 +02:00 committed by GitHub
parent bfeaf75cd5
commit e36377d9ab
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 17 additions and 35 deletions

View File

@ -3,18 +3,14 @@
require "rails_helper" require "rails_helper"
describe "translate accelerator" do describe "translate accelerator" do
before(:all) do before do
@original_i18n_load_path = I18n.load_path.dup @original_i18n_load_path = I18n.load_path.dup
I18n.load_path += Dir["#{Rails.root}/spec/fixtures/i18n/translate_accelerator.*.yml"] I18n.load_path += Dir["#{Rails.root}/spec/fixtures/i18n/translate_accelerator.*.yml"]
I18n.reload! I18n.reload!
end end
after(:all) do
I18n.load_path = @original_i18n_load_path
I18n.reload!
end
after do after do
I18n.load_path = @original_i18n_load_path
I18n.reload! I18n.reload!
end end

View File

@ -1319,7 +1319,7 @@ HTML
end end
describe "censoring" do describe "censoring" do
after(:all) { Discourse.redis.flushdb } after { Discourse.redis.flushdb }
def expect_cooked_match(raw, expected_cooked) def expect_cooked_match(raw, expected_cooked)
expect(PrettyText.cook(raw)).to eq(expected_cooked) expect(PrettyText.cook(raw)).to eq(expected_cooked)
@ -1404,7 +1404,7 @@ HTML
end end
describe "watched words - replace & link" do describe "watched words - replace & link" do
after(:all) { Discourse.redis.flushdb } after { Discourse.redis.flushdb }
it "replaces words with other words" do it "replaces words with other words" do
Fabricate(:watched_word, action: WatchedWord.actions[:replace], word: "dolor sit*", replacement: "something else") Fabricate(:watched_word, action: WatchedWord.actions[:replace], word: "dolor sit*", replacement: "something else")

View File

@ -4,7 +4,7 @@ require 'rails_helper'
require 'theme_settings_parser' require 'theme_settings_parser'
describe ThemeSettingsParser do describe ThemeSettingsParser do
after(:all) do after do
ThemeField.destroy_all ThemeField.destroy_all
end end

View File

@ -1,12 +1,12 @@
# frozen_string_literal: true # frozen_string_literal: true
require "s3_helper" require "s3_helper"
require 'rails_helper' require "rails_helper"
describe Jobs::VacateLegacyPrefixBackups, type: :multisite do describe Jobs::VacateLegacyPrefixBackups, type: :multisite do
let(:bucket_name) { "backupbucket" } let(:bucket_name) { "backupbucket" }
before(:all) do before do
@s3_client = Aws::S3::Client.new(stub_responses: true) @s3_client = Aws::S3::Client.new(stub_responses: true)
@s3_options = { client: @s3_client } @s3_options = { client: @s3_client }
@objects = [] @objects = []
@ -15,9 +15,7 @@ describe Jobs::VacateLegacyPrefixBackups, type: :multisite do
@s3_client.stub_responses(:list_objects_v2, -> (context) do @s3_client.stub_responses(:list_objects_v2, -> (context) do
{ contents: objects_with_prefix(context) } { contents: objects_with_prefix(context) }
end) end)
end
before do
setup_s3 setup_s3
SiteSetting.s3_backup_bucket = bucket_name SiteSetting.s3_backup_bucket = bucket_name
SiteSetting.backup_location = BackupLocationSiteSetting::S3 SiteSetting.backup_location = BackupLocationSiteSetting::S3

View File

@ -5,19 +5,16 @@ require 'backup_restore/local_backup_store'
require_relative 'shared_examples_for_backup_store' require_relative 'shared_examples_for_backup_store'
describe BackupRestore::LocalBackupStore do describe BackupRestore::LocalBackupStore do
before(:all) do before do
@root_directory = Dir.mktmpdir @root_directory = Dir.mktmpdir
@paths = [] @paths = []
end
after(:all) do
FileUtils.remove_dir(@root_directory, true)
end
before do
SiteSetting.backup_location = BackupLocationSiteSetting::LOCAL SiteSetting.backup_location = BackupLocationSiteSetting::LOCAL
end end
after do
FileUtils.remove_dir(@root_directory, true)
end
subject(:store) { BackupRestore::BackupStore.create(root_directory: @root_directory) } subject(:store) { BackupRestore::BackupStore.create(root_directory: @root_directory) }
let(:expected_type) { BackupRestore::LocalBackupStore } let(:expected_type) { BackupRestore::LocalBackupStore }

View File

@ -6,7 +6,7 @@ require 'backup_restore/s3_backup_store'
require_relative 'shared_examples_for_backup_store' require_relative 'shared_examples_for_backup_store'
describe BackupRestore::S3BackupStore do describe BackupRestore::S3BackupStore do
before(:all) do before do
@s3_client = Aws::S3::Client.new(stub_responses: true) @s3_client = Aws::S3::Client.new(stub_responses: true)
@s3_options = { client: @s3_client } @s3_options = { client: @s3_client }
@ -65,9 +65,7 @@ describe BackupRestore::S3BackupStore do
last_modified: Time.zone.now last_modified: Time.zone.now
} }
end) end)
end
before do
SiteSetting.s3_backup_bucket = "s3-backup-bucket" SiteSetting.s3_backup_bucket = "s3-backup-bucket"
SiteSetting.s3_access_key_id = "s3-access-key-id" SiteSetting.s3_access_key_id = "s3-access-key-id"
SiteSetting.s3_secret_access_key = "s3-secret-access-key" SiteSetting.s3_secret_access_key = "s3-secret-access-key"
@ -82,7 +80,7 @@ describe BackupRestore::S3BackupStore do
context "S3 specific behavior" do context "S3 specific behavior" do
before { create_backups } before { create_backups }
after(:all) { remove_backups } after { remove_backups }
describe "#delete_old" do describe "#delete_old" do
it "doesn't delete files when cleanup is disabled" do it "doesn't delete files when cleanup is disabled" do

View File

@ -2,7 +2,7 @@
shared_context "backups" do shared_context "backups" do
before { create_backups } before { create_backups }
after(:all) { remove_backups } after { remove_backups }
# default backup files # default backup files
let(:backup1) { BackupFile.new(filename: "b.tar.gz", size: 17, last_modified: Time.parse("2018-09-13T15:10:00Z")) } let(:backup1) { BackupFile.new(filename: "b.tar.gz", size: 17, last_modified: Time.parse("2018-09-13T15:10:00Z")) }

View File

@ -4,14 +4,10 @@
require 'rails_helper' require 'rails_helper'
describe ThemeField do describe ThemeField do
after(:all) do after do
ThemeField.destroy_all ThemeField.destroy_all
end end
before do
I18n.locale = :en
end
describe "scope: find_by_theme_ids" do describe "scope: find_by_theme_ids" do
it "returns result in the specified order" do it "returns result in the specified order" do
theme = Fabricate(:theme) theme = Fabricate(:theme)

View File

@ -7,10 +7,6 @@ describe Theme do
Theme.clear_cache! Theme.clear_cache!
end end
before do
I18n.locale = :en
end
fab! :user do fab! :user do
Fabricate(:user) Fabricate(:user)
end end
@ -21,6 +17,7 @@ describe Theme do
let(:theme) { Fabricate(:theme, user: user) } let(:theme) { Fabricate(:theme, user: user) }
let(:child) { Fabricate(:theme, user: user, component: true) } let(:child) { Fabricate(:theme, user: user, component: true) }
it 'can properly clean up color schemes' do it 'can properly clean up color schemes' do
scheme = ColorScheme.create!(theme_id: theme.id, name: 'test') scheme = ColorScheme.create!(theme_id: theme.id, name: 'test')
scheme2 = ColorScheme.create!(theme_id: theme.id, name: 'test2') scheme2 = ColorScheme.create!(theme_id: theme.id, name: 'test2')