From dff63ef0ebd473e990fdb7dc601e173c015de788 Mon Sep 17 00:00:00 2001 From: Brandon Keepers Date: Wed, 24 Jan 2024 08:08:07 -0500 Subject: [PATCH 1/4] Rename test_help to autorestore --- lib/dotenv/{test_help.rb => autorestore.rb} | 2 ++ lib/dotenv/rails.rb | 8 ++++---- spec/dotenv/rails_spec.rb | 16 ++++++++-------- spec/spec_helper.rb | 2 +- test/{test_help_test.rb => autorestore_test.rb} | 10 ++-------- 5 files changed, 17 insertions(+), 21 deletions(-) rename lib/dotenv/{test_help.rb => autorestore.rb} (89%) rename test/{test_help_test.rb => autorestore_test.rb} (70%) diff --git a/lib/dotenv/test_help.rb b/lib/dotenv/autorestore.rb similarity index 89% rename from lib/dotenv/test_help.rb rename to lib/dotenv/autorestore.rb index 5133d4a8..81327790 100644 --- a/lib/dotenv/test_help.rb +++ b/lib/dotenv/autorestore.rb @@ -1,3 +1,5 @@ +# Automatically restore `ENV` to its original state after + if defined?(RSpec.configure) RSpec.configure do |config| # Save ENV before the suite starts diff --git a/lib/dotenv/rails.rb b/lib/dotenv/rails.rb index 5de070be..ba71343c 100644 --- a/lib/dotenv/rails.rb +++ b/lib/dotenv/rails.rb @@ -16,7 +16,7 @@ module Dotenv # Rails integration for using Dotenv to load ENV variables from a file class Rails < ::Rails::Railtie - delegate :files, :files=, :overwrite, :overwrite=, :test_help, :test_help=, to: "config.dotenv" + delegate :files, :files=, :overwrite, :overwrite=, :autorestore, :autorestore=, to: "config.dotenv" def initialize super() @@ -28,7 +28,7 @@ def initialize root.join(".env.#{env}"), root.join(".env") ].compact, - test_help: env.test? + autorestore: env.test? ) end @@ -88,8 +88,8 @@ def self.load app.deprecators[:dotenv] = deprecator if app.respond_to?(:deprecators) end - initializer "dotenv.test_help" do |app| - require "dotenv/test_help" if test_help + initializer "dotenv.autorestore" do |app| + require "dotenv/autorestore" if autorestore end config.before_configuration { load } diff --git a/spec/dotenv/rails_spec.rb b/spec/dotenv/rails_spec.rb index d2a4b806..8ba5875c 100644 --- a/spec/dotenv/rails_spec.rb +++ b/spec/dotenv/rails_spec.rb @@ -129,23 +129,23 @@ end end - describe "test_help" do + describe "autorestore" do it "is loaded if RAILS_ENV=test" do - expect(Dotenv::Rails.test_help).to eq(true) - expect(Dotenv::Rails.instance).to receive(:require).with("dotenv/test_help") + expect(Dotenv::Rails.autorestore).to eq(true) + expect(Dotenv::Rails.instance).to receive(:require).with("dotenv/autorestore") application.initialize! end it "is not loaded if RAILS_ENV=development" do Rails.env = "development" - expect(Dotenv::Rails.test_help).to eq(false) - expect(Dotenv::Rails.instance).not_to receive(:require).with("dotenv/test_help") + expect(Dotenv::Rails.autorestore).to eq(false) + expect(Dotenv::Rails.instance).not_to receive(:require).with("dotenv/autorestore") application.initialize! end - it "is not loaded if test_help set to false" do - Dotenv::Rails.test_help = false - expect(Dotenv::Rails.instance).not_to receive(:require).with("dotenv/test_help") + it "is not loaded if autorestore set to false" do + Dotenv::Rails.autorestore = false + expect(Dotenv::Rails.instance).not_to receive(:require).with("dotenv/autorestore") application.initialize! end end diff --git a/spec/spec_helper.rb b/spec/spec_helper.rb index ee138afc..a0df41cf 100644 --- a/spec/spec_helper.rb +++ b/spec/spec_helper.rb @@ -1,5 +1,5 @@ require "dotenv" -require "dotenv/test_help" +require "dotenv/autorestore" def fixture_path(*parts) Pathname.new(__dir__).join("./fixtures", *parts) diff --git a/test/test_help_test.rb b/test/autorestore_test.rb similarity index 70% rename from test/test_help_test.rb rename to test/autorestore_test.rb index 7c20e6a5..d3c660b8 100644 --- a/test/test_help_test.rb +++ b/test/autorestore_test.rb @@ -1,17 +1,11 @@ -begin - require "active_support/deprecator" -rescue LoadError - # Rails 7.1 fails if this is not loaded -end - require "active_support" # Rails 6.1 fails if this is not loaded require "active_support/test_case" require "minitest/autorun" require "dotenv" -require "dotenv/test_help" +require "dotenv/autorestore" -class TestHelpTest < ActiveSupport::TestCase +class AutorestoreTest < ActiveSupport::TestCase test "restores ENV between tests, part 1" do assert_nil ENV["DOTENV"], "ENV was not restored between tests" ENV["DOTENV"] = "1" From 98c9fc63ea71744e06249b307a761c31851a590e Mon Sep 17 00:00:00 2001 From: Brandon Keepers Date: Wed, 24 Jan 2024 08:10:36 -0500 Subject: [PATCH 2/4] Configure files for `rake test` --- Rakefile | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Rakefile b/Rakefile index 0069e362..055010b1 100644 --- a/Rakefile +++ b/Rakefile @@ -33,6 +33,8 @@ RSpec::Core::RakeTask.new(:spec) do |t| t.verbose = false end -Rake::TestTask.new +Rake::TestTask.new do |t| + t.test_files = Dir["test/**/*_test.rb"] +end task default: [:spec, :test, :standard] From 234e126d0fd16a523468465aca91f8d0fdc276a6 Mon Sep 17 00:00:00 2001 From: Brandon Keepers Date: Wed, 24 Jan 2024 11:51:24 -0500 Subject: [PATCH 3/4] Update README --- README.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/README.md b/README.md index 9d43faba..828d047b 100644 --- a/README.md +++ b/README.md @@ -52,6 +52,14 @@ require 'dotenv' Dotenv.load('file1.env', 'file2.env') ``` +## Autorestore in tests + +Since 3.0, dotenv in a Rails app will automatically restore `ENV` to its original state before each test. This means you can modify `ENV` in your tests without fear of leaking state to other tests. It works with both `ActiveSupport::TestCase` and `Rspec`. + +To disable this behavior, set `config.dotenv.autorestore = false` in `config/application.rb` or `config/environments/test.rb`. + +To use this behavior outside of a Rails app, just `require "dotenv/autorestore"` in your test suite. + ### Rake To ensure `.env` is loaded in rake, load the tasks: From 4df96c100c215e694c72afeb17fedca222c917ac Mon Sep 17 00:00:00 2001 From: Brandon Keepers Date: Wed, 24 Jan 2024 11:52:07 -0500 Subject: [PATCH 4/4] Use setup+teardown in AS::TestCase --- lib/dotenv/autorestore.rb | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/dotenv/autorestore.rb b/lib/dotenv/autorestore.rb index 81327790..c54851e1 100644 --- a/lib/dotenv/autorestore.rb +++ b/lib/dotenv/autorestore.rb @@ -12,12 +12,12 @@ if defined?(ActiveSupport) ActiveSupport.on_load(:active_support_test_case) do - # Save ENV when the test suite loads - Dotenv.save - ActiveSupport::TestCase.class_eval do + # Save ENV before each test + setup { Dotenv.save } + # Restore ENV after each test - setup { Dotenv.restore } + teardown { Dotenv.restore } end end end