mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-03 20:48:07 +00:00 
			
		
		
		
	If the feature is disabled (manually or due to plan changes), the customer cannot disable the existing campaigns. This PR would fix that. Fixes https://linear.app/chatwoot/issue/CW-3691/fix-disable-campaigns-on-plan-downgrade
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
require 'rails_helper'
 | 
						|
 | 
						|
RSpec.describe '/api/v1/widget/campaigns', type: :request do
 | 
						|
  let(:account) { create(:account) }
 | 
						|
  let(:web_widget) { create(:channel_widget, account: account) }
 | 
						|
  let!(:campaign_1) { create(:campaign, inbox: web_widget.inbox, enabled: true, account: account, trigger_rules: { url: 'https://test.com' }) }
 | 
						|
  let!(:campaign_2) { create(:campaign, inbox: web_widget.inbox, enabled: false, account: account, trigger_rules: { url: 'https://test.com' }) }
 | 
						|
 | 
						|
  describe 'GET /api/v1/widget/campaigns' do
 | 
						|
    let(:params) { { website_token: web_widget.website_token } }
 | 
						|
 | 
						|
    context 'when campaigns feature is enabled' do
 | 
						|
      before do
 | 
						|
        account.enable_features!('campaigns')
 | 
						|
      end
 | 
						|
 | 
						|
      it 'returns the list of enabled campaigns' do
 | 
						|
        get '/api/v1/widget/campaigns', params: params
 | 
						|
 | 
						|
        expect(response).to have_http_status(:success)
 | 
						|
        json_response = response.parsed_body
 | 
						|
        expect(json_response.length).to eq 1
 | 
						|
        expect(json_response.pluck('id')).to include(campaign_1.display_id)
 | 
						|
        expect(json_response.pluck('id')).not_to include(campaign_2.display_id)
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    context 'when campaigns feature is disabled' do
 | 
						|
      before do
 | 
						|
        account.disable_features!('campaigns')
 | 
						|
      end
 | 
						|
 | 
						|
      it 'returns empty array' do
 | 
						|
        get '/api/v1/widget/campaigns', params: params
 | 
						|
 | 
						|
        expect(response).to have_http_status(:success)
 | 
						|
        json_response = response.parsed_body
 | 
						|
        expect(json_response).to eq []
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    context 'with invalid website token' do
 | 
						|
      it 'returns not found status' do
 | 
						|
        get '/api/v1/widget/campaigns', params: { website_token: '' }
 | 
						|
        expect(response).to have_http_status(:not_found)
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |