gentoo-ebuilds/dev-ruby/sassc-rails/files/sassc-rails-2.1.2-test-directories.patch
Hans de Graaff 4b9c551af5
dev-ruby/sassc-rails: add ruby31, fix tests
Signed-off-by: Hans de Graaff <graaff@gentoo.org>
2023-04-08 09:03:55 +02:00

73 lines
2.8 KiB
Diff

From 9b653021e7a5a192758968a81b0dc81c68f298d0 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
Date: Mon, 27 Feb 2023 16:38:38 +0100
Subject: [PATCH] Run test cases in separate test directories
This is in preparation to be able to run the tests in isolation, because
recent versions of Rails does not allow multiple to calls to
`initialize!`.
---
test/sassc_rails_test.rb | 15 +++++++++------
1 file changed, 9 insertions(+), 6 deletions(-)
diff --git a/test/sassc_rails_test.rb b/test/sassc_rails_test.rb
index a15110d..f8c36e4 100644
--- a/test/sassc_rails_test.rb
+++ b/test/sassc_rails_test.rb
@@ -4,14 +4,18 @@
class SassRailsTest < MiniTest::Test
attr_reader :app
+ attr_reader :test_dir
def setup
Rails.application = nil
+ @test_dir = Dir.mktmpdir("sassc-rails")
+ FileUtils.cp_r File.join(File.dirname(__FILE__), "dummy"), test_dir
+
@app = Class.new(Rails::Application)
@app.config.active_support.deprecation = :log
@app.config.eager_load = false
- @app.config.root = File.join(File.dirname(__FILE__), "dummy")
+ @app.config.root = File.join(test_dir, "dummy")
@app.config.log_level = :debug
# reset config back to default
@@ -30,8 +34,7 @@ def setup
end
def teardown
- directory = "#{Rails.root}/tmp"
- FileUtils.remove_dir(directory) if File.directory?(directory)
+ FileUtils.remove_dir(test_dir) if File.directory?(test_dir)
end
def render_asset(asset)
@@ -169,7 +172,7 @@ def test_line_comments_active_in_dev
css_output = render_asset("css_scss_handler.css")
assert_match %r{/* line 1}, css_output
- assert_match %r{.+test/dummy/app/assets/stylesheets/css_scss_handler.css.scss}, css_output
+ assert_match %r{.+#{test_dir}/dummy/app/assets/stylesheets/css_scss_handler.css.scss}, css_output
end
def test_context_is_being_passed_to_erb_render
@@ -287,7 +290,7 @@ def test_globbed_imports_work_when_globbed_file_is_changed
begin
initialize!
- new_file = File.join(File.dirname(__FILE__), 'dummy', 'app', 'assets', 'stylesheets', 'globbed', 'new_glob.scss')
+ new_file = File.join(test_dir, 'dummy', 'app', 'assets', 'stylesheets', 'globbed', 'new_glob.scss')
File.open(new_file, 'w') do |file|
file.puts '.new-file-test { color: #000; }'
@@ -314,7 +317,7 @@ def test_globbed_imports_work_when_globbed_file_is_added
css_output = render_asset("glob_test.css")
refute_match /changed-file-test/, css_output
- new_file = File.join(File.dirname(__FILE__), 'dummy', 'app', 'assets', 'stylesheets', 'globbed', 'new_glob.scss')
+ new_file = File.join(test_dir, 'dummy', 'app', 'assets', 'stylesheets', 'globbed', 'new_glob.scss')
File.open(new_file, 'w') do |file|
file.puts '.changed-file-test { color: #000; }'