mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-02 03:57:52 +00:00
* feat: add email for disabling automation rule * feat: disable automation rules and notify admin * feat: reset error count after update * feat: trigger invalid_condition_error if rule is invalid * feat: setup error trackable concern * refactor: use ErrorTrackable in Reauthorizable * fix: optional argument * feat: separate reauthorization_required_key * test: update case to use ERROR_TRACKABLE_COUNT * Revert "test: update case to use ERROR_TRACKABLE_COUNT" This reverts commit f439847147556a02759a7597a7fcf1d66091cafc. * Revert "feat: separate reauthorization_required_key" This reverts commit f4514fce217b0a2f2c2bf701a15de0a8b47acbc4. * Revert "fix: optional argument" This reverts commit 93b4194ec3f10f67e2402388c966c071c4d3b4fd. * Revert "refactor: use ErrorTrackable in Reauthorizable" This reverts commit 513c2a522bc782e73ea4b0f5ae34ce01e70e042c. * Revert "feat: setup error trackable concern" This reverts commit 278683060cf422f60af5d5c77100aa5272141141. * feat: use reauthorizable for automation rule * feat: remove redis key * test: fix method names * chore: refactor --------- Co-authored-by: Vishnu Narayanan <iamwishnu@gmail.com> Co-authored-by: Sojan <sojan@pepalo.com>
96 lines
2.9 KiB
Ruby
96 lines
2.9 KiB
Ruby
require 'rails_helper'
|
|
require Rails.root.join 'spec/models/concerns/reauthorizable_shared.rb'
|
|
|
|
RSpec.describe AutomationRule do
|
|
describe 'concerns' do
|
|
it_behaves_like 'reauthorizable'
|
|
end
|
|
|
|
describe 'associations' do
|
|
let(:account) { create(:account) }
|
|
let(:params) do
|
|
{
|
|
name: 'Notify Conversation Created and mark priority query',
|
|
description: 'Notify all administrator about conversation created and mark priority query',
|
|
event_name: 'conversation_created',
|
|
account_id: account.id,
|
|
conditions: [
|
|
{
|
|
attribute_key: 'browser_language',
|
|
filter_operator: 'equal_to',
|
|
values: ['en'],
|
|
query_operator: 'AND'
|
|
},
|
|
{
|
|
attribute_key: 'country_code',
|
|
filter_operator: 'equal_to',
|
|
values: %w[USA UK],
|
|
query_operator: nil
|
|
}
|
|
],
|
|
actions: [
|
|
{
|
|
action_name: :send_message,
|
|
action_params: ['Welcome to the chatwoot platform.']
|
|
},
|
|
{
|
|
action_name: :assign_team,
|
|
action_params: [1]
|
|
},
|
|
{
|
|
action_name: :add_label,
|
|
action_params: %w[support priority_customer]
|
|
},
|
|
{
|
|
action_name: :assign_agent,
|
|
action_params: [1]
|
|
}
|
|
]
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
it 'returns valid record' do
|
|
rule = FactoryBot.build(:automation_rule, params)
|
|
expect(rule.valid?).to be true
|
|
end
|
|
|
|
it 'returns invalid record' do
|
|
params[:conditions][0].delete('query_operator')
|
|
rule = FactoryBot.build(:automation_rule, params)
|
|
expect(rule.valid?).to be false
|
|
expect(rule.errors.messages[:conditions]).to eq(['Automation conditions should have query operator.'])
|
|
end
|
|
end
|
|
|
|
describe 'reauthorizable' do
|
|
context 'when prompt_reauthorization!' do
|
|
it 'marks the rule inactive' do
|
|
rule = create(:automation_rule)
|
|
expect(rule.active).to be true
|
|
rule.prompt_reauthorization!
|
|
expect(rule.active).to be false
|
|
end
|
|
end
|
|
|
|
context 'when reauthorization_required?' do
|
|
it 'unsets the error count if conditions are updated' do
|
|
rule = create(:automation_rule)
|
|
rule.prompt_reauthorization!
|
|
expect(rule.reauthorization_required?).to be true
|
|
|
|
rule.update!(conditions: [{ attribute_key: 'browser_language', filter_operator: 'equal_to', values: ['en'], query_operator: 'AND' }])
|
|
expect(rule.reauthorization_required?).to be false
|
|
end
|
|
|
|
it 'will not unset the error count if conditions are not updated' do
|
|
rule = create(:automation_rule)
|
|
rule.prompt_reauthorization!
|
|
expect(rule.reauthorization_required?).to be true
|
|
|
|
rule.update!(name: 'Updated name')
|
|
expect(rule.reauthorization_required?).to be true
|
|
end
|
|
end
|
|
end
|
|
end
|