mirror of
https://github.com/chatwoot/chatwoot.git
synced 2026-06-04 21:02:35 +08:00
## Description This is the first PR in a series of PRs for Introducing unread counts in the sidebar for inboxes and labels. In this PR: * Added the unread store, counter and builder modules * Added redis keys for unread count management * Added specs for all 3 modules, some specs are for testing enterprise only feature like specific roles and permissions which are added in the respective enterprise folder itself. **Note** None of this changes affect anything else and nothing is wired to existing modules. Issue: https://linear.app/chatwoot/issue/CW-6851/support-unread-conversation-counts ## Type of change Please delete options that are not relevant. - [ ] Bug fix (non-breaking change which fixes an issue) - [x] New feature (non-breaking change which adds functionality) - [ ] Breaking change (fix or feature that would cause existing functionality not to work as expected) - [ ] This change requires a documentation update ## How Has This Been Tested? Please describe the tests that you ran to verify your changes. Provide instructions so we can reproduce. Please also list any relevant details for your test configuration. ## Checklist: - [x] My code follows the style guidelines of this project - [x] I have performed a self-review of my code - [ ] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [x] My changes generate no new warnings - [x] I have added tests that prove my fix is effective or that my feature works - [x] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules --------- Co-authored-by: Sojan Jose <sojan@pepalo.com>
97 lines
3.7 KiB
Ruby
97 lines
3.7 KiB
Ruby
require 'spec_helper'
|
|
ENV['RAILS_ENV'] ||= 'test'
|
|
require File.expand_path('../config/environment', __dir__)
|
|
# Prevent database truncation if the environment is production
|
|
abort('The Rails environment is running in production mode!') if Rails.env.production?
|
|
require 'rspec/rails'
|
|
require 'pundit/rspec'
|
|
require 'sidekiq/testing'
|
|
|
|
# test-prof helpers for tests optimization
|
|
require 'test_prof/recipes/rspec/before_all'
|
|
require 'test_prof/recipes/rspec/let_it_be'
|
|
|
|
# Add additional requires below this line. Rails is not loaded until this point!
|
|
|
|
# Requires supporting ruby files with custom matchers and macros, etc, in
|
|
# spec/support/ and its subdirectories. Files matching `spec/**/*_spec.rb` are
|
|
# run as spec files by default. This means that files in spec/support that end
|
|
# in _spec.rb will both be required and run as specs, causing the specs to be
|
|
# run twice. It is recommended that you do not name files matching this glob to
|
|
# end with _spec.rb. You can configure this pattern with the --pattern
|
|
# option on the command line or in ~/.rspec, .rspec or `.rspec-local`.
|
|
#
|
|
# The following line is provided for convenience purposes. It has the downside
|
|
# of increasing the boot-up time by auto-requiring all files in the support
|
|
# directory. Alternatively, in the individual `*_spec.rb` files, manually
|
|
# require only the support files necessary.
|
|
#
|
|
# rubocop:disable Rails/FilePath
|
|
Dir[Rails.root.join('spec', 'support', '**', '*.rb')].each { |f| require f }
|
|
# rubocop:enable Rails/FilePath
|
|
|
|
# Checks for pending migrations and applies them before tests are run.
|
|
# If you are not using ActiveRecord, you can remove these lines.
|
|
begin
|
|
ActiveRecord::Migration.maintain_test_schema!
|
|
rescue ActiveRecord::PendingMigrationError => e
|
|
puts e.to_s.strip
|
|
exit 1
|
|
end
|
|
RSpec.configure do |config|
|
|
config.include FactoryBot::Syntax::Methods
|
|
# Remove this line if you're not using ActiveRecord or ActiveRecord fixtures
|
|
config.fixture_path = Rails.root.join('spec/fixtures')
|
|
|
|
# If you're not using ActiveRecord, or you'd prefer not to run each of your
|
|
# examples within a transaction, remove the following line or assign false
|
|
# instead of true.
|
|
config.use_transactional_fixtures = true
|
|
|
|
# RSpec Rails can automatically mix in different behaviours to your tests
|
|
# based on their file location, for example enabling you to call `get` and
|
|
# `post` in specs under `spec/controllers`.
|
|
#
|
|
# You can disable this behaviour by removing the line below, and instead
|
|
# explicitly tag your specs with their type, e.g.:
|
|
#
|
|
# RSpec.describe UsersController, :type => :controller do
|
|
# # ...
|
|
# end
|
|
#
|
|
# The different available types are documented in the features, such as in
|
|
# https://relishapp.com/rspec/rspec-rails/docs
|
|
config.infer_spec_type_from_file_location!
|
|
|
|
# Filter lines from Rails gems in backtraces.
|
|
config.filter_rails_from_backtrace!
|
|
# arbitrary gems may also be filtered via:
|
|
# config.filter_gems_from_backtrace("gem name")
|
|
config.include SlackStubs
|
|
config.include FileUploadHelpers
|
|
config.include CsvSpecHelpers
|
|
config.include InstagramSpecHelpers
|
|
config.include ConversationsUnreadCountsHelpers
|
|
config.include Devise::Test::IntegrationHelpers, type: :request
|
|
config.include ActiveSupport::Testing::TimeHelpers
|
|
config.include ActionCable::TestHelper
|
|
config.include ActiveJob::TestHelper
|
|
|
|
# OpenAPI response validation via Skooma
|
|
path_to_openapi = Rails.root.join('swagger/swagger.json')
|
|
config.include Skooma::RSpec[path_to_openapi], type: :request
|
|
end
|
|
|
|
Shoulda::Matchers.configure do |config|
|
|
config.integrate do |with|
|
|
with.test_framework :rspec
|
|
with.library :rails
|
|
end
|
|
end
|
|
|
|
# Required for fixture_file_upload
|
|
FactoryBot::SyntaxRunner.class_eval do
|
|
include ActionDispatch::TestProcess
|
|
include ActiveSupport::Testing::FileFixtures
|
|
end
|