redis_ui_rails 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (71) hide show
  1. checksums.yaml +7 -0
  2. data/.env.example +1 -0
  3. data/.envrc +3 -0
  4. data/.gitignore +10 -0
  5. data/.rspec.example +3 -0
  6. data/Gemfile +5 -0
  7. data/README.md +86 -0
  8. data/app/assets/config/manifest.js +1 -0
  9. data/app/assets/images/redis_ui_rails/.keep +0 -0
  10. data/app/assets/stylesheets/redis_ui_rails/application.css +26 -0
  11. data/app/controllers/redis_ui_rails/application_controller.rb +4 -0
  12. data/app/controllers/redis_ui_rails/configs_controller.rb +11 -0
  13. data/app/controllers/redis_ui_rails/dashboard_controller.rb +7 -0
  14. data/app/controllers/redis_ui_rails/instances_controller.rb +12 -0
  15. data/app/controllers/redis_ui_rails/keys_controller.rb +12 -0
  16. data/app/views/layouts/redis_ui_rails/application.html.erb +13 -0
  17. data/app/views/redis_ui_rails/configs/show.html.erb +18 -0
  18. data/app/views/redis_ui_rails/dashboard/index.html.erb +23 -0
  19. data/app/views/redis_ui_rails/instances/show.html.erb +35 -0
  20. data/app/views/redis_ui_rails/keys/show.html.erb +24 -0
  21. data/app/views/shared/_instance_hero.html.erb +13 -0
  22. data/config/routes.rb +8 -0
  23. data/lib/redis_ui_rails/config.rb +64 -0
  24. data/lib/redis_ui_rails/engine.rb +12 -0
  25. data/lib/redis_ui_rails/redis_instance.rb +54 -0
  26. data/lib/redis_ui_rails/version.rb +3 -0
  27. data/lib/redis_ui_rails.rb +24 -0
  28. data/redis_ui_rails.gemspec +30 -0
  29. data/spec/feature_spec_helper.rb +9 -0
  30. data/spec/integration/dashboard_spec.rb +12 -0
  31. data/spec/integration/instance_config_spec.rb +17 -0
  32. data/spec/integration/instance_keys_spec.rb +17 -0
  33. data/spec/redis_ui_rails/config_spec.rb +60 -0
  34. data/spec/redis_ui_rails/redis_instance_spec.rb +117 -0
  35. data/spec/redis_ui_rails_spec.rb +29 -0
  36. data/spec/spec_helper.rb +21 -0
  37. data/spec/support/dummy/app/assets/config/manifest.js +2 -0
  38. data/spec/support/dummy/app/assets/images/.keep +0 -0
  39. data/spec/support/dummy/app/assets/stylesheets/application.css +15 -0
  40. data/spec/support/dummy/app/controllers/application_controller.rb +2 -0
  41. data/spec/support/dummy/app/javascript/packs/application.js +14 -0
  42. data/spec/support/dummy/app/views/layouts/application.html.erb +15 -0
  43. data/spec/support/dummy/bin/rails +4 -0
  44. data/spec/support/dummy/bin/rake +4 -0
  45. data/spec/support/dummy/bin/setup +30 -0
  46. data/spec/support/dummy/config/application.rb +16 -0
  47. data/spec/support/dummy/config/boot.rb +5 -0
  48. data/spec/support/dummy/config/database.yml +11 -0
  49. data/spec/support/dummy/config/environment.rb +8 -0
  50. data/spec/support/dummy/config/environments/development.rb +76 -0
  51. data/spec/support/dummy/config/environments/production.rb +120 -0
  52. data/spec/support/dummy/config/environments/test.rb +59 -0
  53. data/spec/support/dummy/config/initializers/assets.rb +12 -0
  54. data/spec/support/dummy/config/initializers/backtrace_silencers.rb +8 -0
  55. data/spec/support/dummy/config/initializers/cookies_serializer.rb +5 -0
  56. data/spec/support/dummy/config/initializers/filter_parameter_logging.rb +6 -0
  57. data/spec/support/dummy/config/initializers/redis_ui_rails.rb +12 -0
  58. data/spec/support/dummy/config/initializers/wrap_parameters.rb +14 -0
  59. data/spec/support/dummy/config/locales/en.yml +33 -0
  60. data/spec/support/dummy/config/puma.rb +43 -0
  61. data/spec/support/dummy/config/routes.rb +3 -0
  62. data/spec/support/dummy/config.ru +6 -0
  63. data/spec/support/dummy/lib/assets/.keep +0 -0
  64. data/spec/support/dummy/log/.keep +0 -0
  65. data/spec/support/dummy/public/404.html +67 -0
  66. data/spec/support/dummy/public/422.html +67 -0
  67. data/spec/support/dummy/public/500.html +66 -0
  68. data/spec/support/dummy/public/apple-touch-icon-precomposed.png +0 -0
  69. data/spec/support/dummy/public/apple-touch-icon.png +0 -0
  70. data/spec/support/dummy/public/favicon.ico +0 -0
  71. metadata +279 -0
@@ -0,0 +1,60 @@
1
+ require "spec_helper"
2
+
3
+ RSpec.describe RedisUiRails::Config do
4
+ let(:config) { described_class.new }
5
+ let(:hash_instance) do
6
+ {
7
+ id: "test",
8
+ url: "test/url",
9
+ name: "test name",
10
+ enabled: true
11
+ }
12
+ end
13
+ let(:hash_instances) { [hash_instance] }
14
+
15
+ before(:each) do
16
+ config.redis_instances = hash_instances
17
+ end
18
+
19
+ describe "#ingest" do
20
+ it "slurps hash instances into instance objects" do
21
+ config.ingest
22
+
23
+ expect(config.redis_instances.map(&:class)).to contain_exactly(RedisUiRails::RedisInstance)
24
+ end
25
+ end
26
+
27
+ describe "validations" do
28
+ before(:each) { config.ingest }
29
+
30
+ context "given a valid instance hash" do
31
+ it "is valid" do
32
+ expect { config.validate! }.not_to raise_error
33
+ end
34
+ end
35
+
36
+ context "given an invalid instance hash" do
37
+ let(:hash_instance) { super().tap { |obj| obj.delete(:url) } }
38
+
39
+ it "is not valid" do
40
+ expect { config.validate! }.to raise_error(/url/)
41
+ end
42
+ end
43
+
44
+ context "given 0 instance hashes" do
45
+ let(:hash_instance) { nil }
46
+
47
+ it "is not valid" do
48
+ expect { config.validate! }.to raise_error(/at least one/i)
49
+ end
50
+ end
51
+
52
+ context "given duplicate ids" do
53
+ let(:hash_instances) { [hash_instance, hash_instance] }
54
+
55
+ it "is not valid" do
56
+ expect { config.validate! }.to raise_error(/duplicate/i)
57
+ end
58
+ end
59
+ end
60
+ end
@@ -0,0 +1,117 @@
1
+ require "spec_helper"
2
+
3
+ RSpec.describe RedisUiRails::RedisInstance do
4
+ let(:options) do
5
+ {
6
+ id: "test",
7
+ url: "//test/url",
8
+ name: "test name",
9
+ resource_links: [
10
+ {
11
+ label: "label",
12
+ url: "url"
13
+ }
14
+ ]
15
+ }
16
+ end
17
+ let(:instance) { described_class.new(options) }
18
+
19
+ it "provides accessors to input hash keys" do
20
+ expect(instance.id).to eq(options[:id])
21
+ expect(instance.url).to eq(options[:url])
22
+ expect(instance.name).to eq(options[:name])
23
+ end
24
+
25
+ describe "#url" do
26
+ context "given a localhost URL" do
27
+ let(:url) { "redis://localhost:6379/3" }
28
+
29
+ it "returns the full URL" do
30
+ instance.actual_url = url
31
+
32
+ expect(instance.url).to eq(url)
33
+ end
34
+ end
35
+
36
+ context "given non-localhost URLs" do
37
+ let(:sensitive_urls) do
38
+ {
39
+ "redis://fo-some-service.two01.ng.0001.use1.cache.amazonaws.com:6379" => "redis://fo-some-service.two**.ng.****.use*.cache.amazonaws.com:6379",
40
+ "redis://user:password@fo-some-service.two01.ng.0001.use1.cache.amazonaws.com:6379" => "redis://user:*@fo-some-service.two**.ng.****.use*.cache.amazonaws.com:6379"
41
+ }
42
+ end
43
+
44
+ it "obscures the URL" do
45
+ sensitive_urls.each do |url, redacted_url|
46
+ instance.actual_url = url
47
+
48
+ expect(instance.url).to eq(redacted_url)
49
+ end
50
+ end
51
+
52
+ it "can bypass URL obscuring" do
53
+ sensitive_urls.each do |url, _|
54
+ instance.actual_url = url
55
+
56
+ expect(instance.url(unredacted: true)).to eq(url)
57
+ end
58
+ end
59
+ end
60
+ end
61
+
62
+ describe "validations" do
63
+ context "given a valid set of options" do
64
+ it "is valid" do
65
+ expect { instance.validate! }.not_to raise_error
66
+ end
67
+ end
68
+
69
+ context "given a missing :url" do
70
+ let(:options) { super().tap { |obj| obj.delete(:url) } }
71
+
72
+ it "is not valid" do
73
+ expect { instance.validate! }.to raise_error(ActiveModel::ValidationError)
74
+ end
75
+ end
76
+
77
+ context "given a missing :name" do
78
+ let(:options) { super().tap { |obj| obj.delete(:name) } }
79
+
80
+ it "is not valid" do
81
+ expect { instance.validate! }.to raise_error(ActiveModel::ValidationError)
82
+ end
83
+ end
84
+
85
+ context "given a missing :id" do
86
+ let(:options) { super().tap { |obj| obj.delete(:id) } }
87
+
88
+ it "is not valid" do
89
+ expect { instance.validate! }.to raise_error(ActiveModel::ValidationError)
90
+ end
91
+ end
92
+
93
+ context "given a missing :resource_links" do
94
+ let(:options) { super().tap { |obj| obj.delete(:resource_links) } }
95
+
96
+ it "is valid" do
97
+ expect { instance.validate! }.not_to raise_error
98
+ end
99
+ end
100
+
101
+ context "given a missing resource_links: :url" do
102
+ let(:options) { super().tap { |obj| obj[:resource_links][0].delete(:url) } }
103
+
104
+ it "is not valid" do
105
+ expect { instance.validate! }.to raise_error(ActiveModel::ValidationError)
106
+ end
107
+ end
108
+
109
+ context "given a missing resource_links: :label" do
110
+ let(:options) { super().tap { |obj| obj[:resource_links][0].delete(:label) } }
111
+
112
+ it "is not valid" do
113
+ expect { instance.validate! }.to raise_error(ActiveModel::ValidationError)
114
+ end
115
+ end
116
+ end
117
+ end
@@ -0,0 +1,29 @@
1
+ require "spec_helper"
2
+
3
+ RSpec.describe RedisUiRails do
4
+ after(:each) do
5
+ described_class.remove_instance_variable(:@config)
6
+ end
7
+
8
+ it "is configurable" do
9
+ expect {
10
+ described_class.configure do |config|
11
+ config.redis_instances = [
12
+ {
13
+ id: "test",
14
+ url: "test/url",
15
+ name: "test name"
16
+ }
17
+ ]
18
+ end
19
+ }.not_to raise_error
20
+ end
21
+
22
+ it "raises an error if configured incorrectly" do
23
+ expect {
24
+ described_class.configure do |config|
25
+ config.redis_instances = []
26
+ end
27
+ }.to raise_error(ActiveModel::ValidationError)
28
+ end
29
+ end
@@ -0,0 +1,21 @@
1
+ # frozen_string_literal: true
2
+
3
+ ENV["RAILS_ENV"] ||= "test"
4
+
5
+ require_relative "../lib/redis_ui_rails"
6
+ require "pry"
7
+ require "mock_redis"
8
+
9
+ RSpec.configure do |config|
10
+ config.expect_with :rspec do |expectations|
11
+ expectations.include_chain_clauses_in_custom_matcher_descriptions = true
12
+ end
13
+ config.mock_with :rspec do |mocks|
14
+ mocks.verify_partial_doubles = true
15
+ end
16
+ config.disable_monkey_patching!
17
+ config.expose_dsl_globally = true
18
+ if config.files_to_run.one?
19
+ config.default_formatter = "doc"
20
+ end
21
+ end
@@ -0,0 +1,2 @@
1
+ //= link_tree ../images
2
+ //= link_directory ../stylesheets .css
File without changes
@@ -0,0 +1,15 @@
1
+ /*
2
+ * This is a manifest file that'll be compiled into application.css, which will include all the files
3
+ * listed below.
4
+ *
5
+ * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
6
+ * or any plugin's vendor/assets/stylesheets directory can be referenced here using a relative path.
7
+ *
8
+ * You're free to add application-wide styles to this file and they'll appear at the bottom of the
9
+ * compiled file so the styles you add here take precedence over styles defined in any other CSS/SCSS
10
+ * files in this directory. Styles in this file should be added after the last require_* statement.
11
+ * It is generally better to create a new file per style scope.
12
+ *
13
+ *= require_tree .
14
+ *= require_self
15
+ */
@@ -0,0 +1,2 @@
1
+ class ApplicationController < ActionController::Base
2
+ end
@@ -0,0 +1,14 @@
1
+ // This is a manifest file that'll be compiled into application.js, which will include all the files
2
+ // listed below.
3
+ //
4
+ // Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
5
+ // or any plugin's vendor/assets/javascripts directory can be referenced here using a relative path.
6
+ //
7
+ // It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
8
+ // compiled file. JavaScript code in this file should be added after the last require_* statement.
9
+ //
10
+ // Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details
11
+ // about supported directives.
12
+ //
13
+ //= require rails-ujs
14
+ //= require_tree .
@@ -0,0 +1,15 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Dummy</title>
5
+ <meta name="viewport" content="width=device-width,initial-scale=1">
6
+ <%= csrf_meta_tags %>
7
+ <%= csp_meta_tag %>
8
+
9
+ <%= stylesheet_link_tag 'application', media: 'all' %>
10
+ </head>
11
+
12
+ <body>
13
+ <%= yield %>
14
+ </body>
15
+ </html>
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+ APP_PATH = File.expand_path("../config/application", __dir__)
3
+ require_relative "../config/boot"
4
+ require "rails/commands"
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env ruby
2
+ require_relative "../config/boot"
3
+ require "rake"
4
+ Rake.application.run
@@ -0,0 +1,30 @@
1
+ #!/usr/bin/env ruby
2
+ require "fileutils"
3
+
4
+ # path to your application root.
5
+ APP_ROOT = File.expand_path("..", __dir__)
6
+
7
+ def system!(*args)
8
+ system(*args) || abort("\n== Command #{args} failed ==")
9
+ end
10
+
11
+ FileUtils.chdir APP_ROOT do
12
+ # This script is a way to set up or update your development environment automatically.
13
+ # This script is idempotent, so that you can run it at any time and get an expectable outcome.
14
+ # Add necessary setup steps to this file.
15
+
16
+ puts "== Installing dependencies =="
17
+ system! "gem install bundler --conservative"
18
+ system("bundle check") || system!("bundle install")
19
+
20
+ # puts "\n== Copying sample files =="
21
+ # unless File.exist?('config/database.yml')
22
+ # FileUtils.cp 'config/database.yml.sample', 'config/database.yml'
23
+ # end
24
+
25
+ puts "\n== Removing old logs and tempfiles =="
26
+ system! "bin/rails log:clear tmp:clear"
27
+
28
+ puts "\n== Restarting application server =="
29
+ system! "bin/rails restart"
30
+ end
@@ -0,0 +1,16 @@
1
+ require_relative "boot"
2
+
3
+ require "puma"
4
+ require "sqlite3"
5
+ require "net/smtp"
6
+ require "rails"
7
+ require "action_controller/railtie"
8
+ require "action_view/railtie"
9
+ require "sprockets/railtie"
10
+ require "redis_ui_rails"
11
+
12
+ module RedisUiRailsDummy
13
+ class Application < Rails::Application
14
+ config.load_defaults Rails::VERSION::STRING.to_f
15
+ end
16
+ end
@@ -0,0 +1,5 @@
1
+ # Set up gems listed in the Gemfile.
2
+ ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../../Gemfile", __dir__)
3
+
4
+ require "bundler/setup" if File.exist?(ENV["BUNDLE_GEMFILE"])
5
+ $LOAD_PATH.unshift File.expand_path("../../../lib", __dir__)
@@ -0,0 +1,11 @@
1
+ default: &default
2
+ adapter: sqlite3
3
+ pool: 5
4
+ timeout: 5000
5
+ database: ":memory:"
6
+
7
+ development:
8
+ <<: *default
9
+
10
+ test:
11
+ <<: *default
@@ -0,0 +1,8 @@
1
+ # Load the Rails application.
2
+ require_relative "application"
3
+
4
+ # Load the gem/engine under test
5
+ require "redis_ui_rails"
6
+
7
+ # Initialize the Rails application.
8
+ Rails.application.initialize!
@@ -0,0 +1,76 @@
1
+ require "active_support/core_ext/integer/time"
2
+
3
+ Rails.application.configure do
4
+ # Settings specified here will take precedence over those in config/application.rb.
5
+
6
+ # In the development environment your application's code is reloaded any time
7
+ # it changes. This slows down response time but is perfect for development
8
+ # since you don't have to restart the web server when you make code changes.
9
+ config.cache_classes = false
10
+
11
+ # Do not eager load code on boot.
12
+ config.eager_load = false
13
+
14
+ # Show full error reports.
15
+ config.consider_all_requests_local = true
16
+
17
+ # Enable/disable caching. By default caching is disabled.
18
+ # Run rails dev:cache to toggle caching.
19
+ if Rails.root.join("tmp", "caching-dev.txt").exist?
20
+ config.action_controller.perform_caching = true
21
+ config.action_controller.enable_fragment_cache_logging = true
22
+
23
+ config.cache_store = :memory_store
24
+ config.public_file_server.headers = {
25
+ "Cache-Control" => "public, max-age=#{2.days.to_i}"
26
+ }
27
+ else
28
+ config.action_controller.perform_caching = false
29
+
30
+ config.cache_store = :null_store
31
+ end
32
+
33
+ # Store uploaded files on the local file system (see config/storage.yml for options).
34
+ # config.active_storage.service = :local
35
+
36
+ # Don't care if the mailer can't send.
37
+ # config.action_mailer.raise_delivery_errors = false
38
+
39
+ # config.action_mailer.perform_caching = false
40
+
41
+ # Print deprecation notices to the Rails logger.
42
+ config.active_support.deprecation = :log
43
+
44
+ # Raise exceptions for disallowed deprecations.
45
+ config.active_support.disallowed_deprecation = :raise
46
+
47
+ # Tell Active Support which deprecation messages to disallow.
48
+ config.active_support.disallowed_deprecation_warnings = []
49
+
50
+ # Raise an error on page load if there are pending migrations.
51
+ # config.active_record.migration_error = :page_load
52
+
53
+ # Highlight code that triggered database queries in logs.
54
+ # config.active_record.verbose_query_logs = true
55
+
56
+ # Debug mode disables concatenation and preprocessing of assets.
57
+ # This option may cause significant delays in view rendering with a large
58
+ # number of complex assets.
59
+ # config.assets.debug = true
60
+
61
+ # Suppress logger output for asset requests.
62
+ # config.assets.quiet = true
63
+
64
+ # Raises error for missing translations.
65
+ # config.i18n.raise_on_missing_translations = true
66
+
67
+ # Annotate rendered view with file names.
68
+ # config.action_view.annotate_rendered_view_with_filenames = true
69
+
70
+ # Use an evented file watcher to asynchronously detect changes in source code,
71
+ # routes, locales, etc. This feature depends on the listen gem.
72
+ # config.file_watcher = ActiveSupport::EventedFileUpdateChecker
73
+
74
+ # Uncomment if you wish to allow Action Cable access from any origin.
75
+ # config.action_cable.disable_request_forgery_protection = true
76
+ end
@@ -0,0 +1,120 @@
1
+ require "active_support/core_ext/integer/time"
2
+
3
+ Rails.application.configure do
4
+ # Settings specified here will take precedence over those in config/application.rb.
5
+
6
+ # Code is not reloaded between requests.
7
+ config.cache_classes = true
8
+
9
+ # Eager load code on boot. This eager loads most of Rails and
10
+ # your application in memory, allowing both threaded web servers
11
+ # and those relying on copy on write to perform better.
12
+ # Rake tasks automatically ignore this option for performance.
13
+ config.eager_load = true
14
+
15
+ # Full error reports are disabled and caching is turned on.
16
+ config.consider_all_requests_local = false
17
+ config.action_controller.perform_caching = true
18
+
19
+ # Ensures that a master key has been made available in either ENV["RAILS_MASTER_KEY"]
20
+ # or in config/master.key. This key is used to decrypt credentials (and other encrypted files).
21
+ # config.require_master_key = true
22
+
23
+ # Disable serving static files from the `/public` folder by default since
24
+ # Apache or NGINX already handles this.
25
+ config.public_file_server.enabled = ENV["RAILS_SERVE_STATIC_FILES"].present?
26
+
27
+ # Compress CSS using a preprocessor.
28
+ # config.assets.css_compressor = :sass
29
+
30
+ # Do not fallback to assets pipeline if a precompiled asset is missed.
31
+ # config.assets.compile = false
32
+
33
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server.
34
+ # config.asset_host = 'http://assets.example.com'
35
+
36
+ # Specifies the header that your server uses for sending files.
37
+ # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
38
+ # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
39
+
40
+ # Store uploaded files on the local file system (see config/storage.yml for options).
41
+ # config.active_storage.service = :local
42
+
43
+ # Mount Action Cable outside main process or domain.
44
+ # config.action_cable.mount_path = nil
45
+ # config.action_cable.url = 'wss://example.com/cable'
46
+ # config.action_cable.allowed_request_origins = [ 'http://example.com', /http:\/\/example.*/ ]
47
+
48
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
49
+ # config.force_ssl = true
50
+
51
+ # Include generic and useful information about system operation, but avoid logging too much
52
+ # information to avoid inadvertent exposure of personally identifiable information (PII).
53
+ config.log_level = :info
54
+
55
+ # Prepend all log lines with the following tags.
56
+ config.log_tags = [:request_id]
57
+
58
+ # Use a different cache store in production.
59
+ # config.cache_store = :mem_cache_store
60
+
61
+ # Use a real queuing backend for Active Job (and separate queues per environment).
62
+ # config.active_job.queue_adapter = :resque
63
+ # config.active_job.queue_name_prefix = "dummy_production"
64
+
65
+ # config.action_mailer.perform_caching = false
66
+
67
+ # Ignore bad email addresses and do not raise email delivery errors.
68
+ # Set this to true and configure the email server for immediate delivery to raise delivery errors.
69
+ # config.action_mailer.raise_delivery_errors = false
70
+
71
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
72
+ # the I18n.default_locale when a translation cannot be found).
73
+ config.i18n.fallbacks = true
74
+
75
+ # Send deprecation notices to registered listeners.
76
+ config.active_support.deprecation = :notify
77
+
78
+ # Log disallowed deprecations.
79
+ config.active_support.disallowed_deprecation = :log
80
+
81
+ # Tell Active Support which deprecation messages to disallow.
82
+ config.active_support.disallowed_deprecation_warnings = []
83
+
84
+ # Use default logging formatter so that PID and timestamp are not suppressed.
85
+ config.log_formatter = ::Logger::Formatter.new
86
+
87
+ # Use a different logger for distributed setups.
88
+ # require "syslog/logger"
89
+ # config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new 'app-name')
90
+
91
+ if ENV["RAILS_LOG_TO_STDOUT"].present?
92
+ logger = ActiveSupport::Logger.new($stdout)
93
+ logger.formatter = config.log_formatter
94
+ config.logger = ActiveSupport::TaggedLogging.new(logger)
95
+ end
96
+
97
+ # Do not dump schema after migrations.
98
+ # config.active_record.dump_schema_after_migration = false
99
+
100
+ # Inserts middleware to perform automatic connection switching.
101
+ # The `database_selector` hash is used to pass options to the DatabaseSelector
102
+ # middleware. The `delay` is used to determine how long to wait after a write
103
+ # to send a subsequent read to the primary.
104
+ #
105
+ # The `database_resolver` class is used by the middleware to determine which
106
+ # database is appropriate to use based on the time delay.
107
+ #
108
+ # The `database_resolver_context` class is used by the middleware to set
109
+ # timestamps for the last write to the primary. The resolver uses the context
110
+ # class timestamps to determine how long to wait before reading from the
111
+ # replica.
112
+ #
113
+ # By default Rails will store a last write timestamp in the session. The
114
+ # DatabaseSelector middleware is designed as such you can define your own
115
+ # strategy for connection switching and pass that into the middleware through
116
+ # these configuration options.
117
+ # config.active_record.database_selector = { delay: 2.seconds }
118
+ # config.active_record.database_resolver = ActiveRecord::Middleware::DatabaseSelector::Resolver
119
+ # config.active_record.database_resolver_context = ActiveRecord::Middleware::DatabaseSelector::Resolver::Session
120
+ end
@@ -0,0 +1,59 @@
1
+ require "active_support/core_ext/integer/time"
2
+
3
+ # The test environment is used exclusively to run your application's
4
+ # test suite. You never need to work with it otherwise. Remember that
5
+ # your test database is "scratch space" for the test suite and is wiped
6
+ # and recreated between test runs. Don't rely on the data there!
7
+
8
+ Rails.application.configure do
9
+ # Settings specified here will take precedence over those in config/application.rb.
10
+
11
+ config.cache_classes = true
12
+
13
+ # Do not eager load code on boot. This avoids loading your whole application
14
+ # just for the purpose of running a single test. If you are using a tool that
15
+ # preloads Rails for running tests, you may have to set it to true.
16
+ config.eager_load = false
17
+
18
+ # Configure public file server for tests with Cache-Control for performance.
19
+ config.public_file_server.enabled = true
20
+ config.public_file_server.headers = {
21
+ "Cache-Control" => "public, max-age=#{1.hour.to_i}"
22
+ }
23
+
24
+ # Show full error reports and disable caching.
25
+ config.consider_all_requests_local = true
26
+ config.action_controller.perform_caching = false
27
+ config.cache_store = :null_store
28
+
29
+ # Raise exceptions instead of rendering exception templates.
30
+ config.action_dispatch.show_exceptions = false
31
+
32
+ # Disable request forgery protection in test environment.
33
+ config.action_controller.allow_forgery_protection = false
34
+
35
+ # Store uploaded files on the local file system in a temporary directory.
36
+ # config.active_storage.service = :test
37
+
38
+ # config.action_mailer.perform_caching = false
39
+
40
+ # Tell Action Mailer not to deliver emails to the real world.
41
+ # The :test delivery method accumulates sent emails in the
42
+ # ActionMailer::Base.deliveries array.
43
+ # config.action_mailer.delivery_method = :test
44
+
45
+ # Print deprecation notices to the stderr.
46
+ config.active_support.deprecation = :stderr
47
+
48
+ # Raise exceptions for disallowed deprecations.
49
+ config.active_support.disallowed_deprecation = :raise
50
+
51
+ # Tell Active Support which deprecation messages to disallow.
52
+ config.active_support.disallowed_deprecation_warnings = []
53
+
54
+ # Raises error for missing translations.
55
+ # config.i18n.raise_on_missing_translations = true
56
+
57
+ # Annotate rendered view with file names.
58
+ # config.action_view.annotate_rendered_view_with_filenames = true
59
+ end
@@ -0,0 +1,12 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Version of your assets, change this if you want to expire all your assets.
4
+ # Rails.application.config.assets.version = "1.0"
5
+
6
+ # Add additional assets to the asset load path.
7
+ # Rails.application.config.assets.paths << Emoji.images_path
8
+
9
+ # Precompile additional assets.
10
+ # application.js, application.css, and all non-JS/CSS in the app/assets
11
+ # folder are already added.
12
+ # Rails.application.config.assets.precompile += %w( admin.js admin.css )
@@ -0,0 +1,8 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4
+ # Rails.backtrace_cleaner.add_silencer { |line| /my_noisy_library/.match?(line) }
5
+
6
+ # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code
7
+ # by setting BACKTRACE=1 before calling your invocation, like "BACKTRACE=1 ./bin/rails runner 'MyClass.perform'".
8
+ Rails.backtrace_cleaner.remove_silencers! if ENV["BACKTRACE"]
@@ -0,0 +1,5 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Specify a serializer for the signed and encrypted cookie jars.
4
+ # Valid options are :json, :marshal, and :hybrid.
5
+ Rails.application.config.action_dispatch.cookies_serializer = :json
@@ -0,0 +1,6 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Configure sensitive parameters which will be filtered from the log file.
4
+ Rails.application.config.filter_parameters += [
5
+ :passw, :secret, :token, :_key, :crypt, :salt, :certificate, :otp, :ssn
6
+ ]