import { configureStore } from '@reduxjs/toolkit';
import QuickFeedbackSlice, { clearCurrentQuickFeedback, fetchQuickFeedbacks, fetchTeamFeed, deleteQuickFeedback, fetchQuickFeedback } from '../QuickFeedbackSlice';

jest.mock('@/services/api/api', () => ({
  apiGet: jest.fn(),
  apiPost: jest.fn(),
  apiPut: jest.fn(),
  apiDelete: jest.fn(),
}));

jest.mock('antd', () => ({
  message: { success: jest.fn(), error: jest.fn(), warning: jest.fn() },
}));

jest.mock('@/utilities/Helpers', () => ({
  __esModule: true,
  default: { handleServerError: jest.fn((e) => e?.message || 'Error') },
}));

const createStore = () =>
  configureStore({ reducer: { qf: QuickFeedbackSlice.reducer } });

describe('QuickFeedbackSlice', () => {
  it('has correct initial state', () => {
    const store = createStore();
    const state = store.getState().qf;
    expect(state.quickFeedbacks).toEqual([]);
    expect(state.teamFeed).toEqual([]);
    expect(state.currentQuickFeedback).toBeNull();
    expect(state.loading).toBe(false);
    expect(state.error).toBeNull();
  });

  it('populates on fetchQuickFeedbacks.fulfilled', () => {
    const store = createStore();
    const payload = { data: [{ id: '1' }], meta: {}, links: {} };
    store.dispatch({ type: fetchQuickFeedbacks.fulfilled.type, payload });
    expect(store.getState().qf.quickFeedbacks).toEqual(payload.data);
  });

  it('populates teamFeed on fetchTeamFeed.fulfilled', () => {
    const store = createStore();
    const payload = { data: [{ id: '1' }], meta: {} };
    store.dispatch({ type: fetchTeamFeed.fulfilled.type, payload });
    expect(store.getState().qf.teamFeed).toEqual(payload.data);
  });

  it('removes on deleteQuickFeedback.fulfilled', () => {
    const store = createStore();
    store.dispatch({ type: fetchQuickFeedbacks.fulfilled.type, payload: { data: [{ id: '1' }], meta: {}, links: {} } });
    store.dispatch({ type: deleteQuickFeedback.fulfilled.type, payload: { id: '1', message: 'Deleted' } });
    expect(store.getState().qf.quickFeedbacks).toHaveLength(0);
  });

  it('clears via clearCurrentQuickFeedback', () => {
    const store = createStore();
    store.dispatch({ type: fetchQuickFeedback.fulfilled.type, payload: { id: '1' } });
    store.dispatch(clearCurrentQuickFeedback());
    expect(store.getState().qf.currentQuickFeedback).toBeNull();
  });
});
