Files
smoothschedule/frontend/src/pages/help/__tests__/HelpStaff.test.tsx
poduck 47657e7076 Add staff permission controls for editing staff and customers
- Add can_edit_staff and can_edit_customers dangerous permissions
- Move Site Builder, Services, Locations, Time Blocks, Payments to Settings permissions
- Link Edit Others' Schedules and Edit Own Schedule permissions
- Add permission checks to StaffViewSet (partial_update, toggle_active, verify_email)
- Add permission checks to CustomerViewSet (update, partial_update, verify_email)
- Fix CustomerViewSet permission key mismatch (can_access_customers)
- Hide Edit/Verify buttons on Staff and Customers pages without permission
- Make dangerous permissions section more visually distinct (darker red)
- Fix StaffDashboard links to use correct paths (/dashboard/my-schedule)
- Disable settings sub-permissions when Access Settings is unchecked

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-29 17:38:48 -05:00

63 lines
2.1 KiB
TypeScript

import { describe, it, expect, vi } from 'vitest';
import { render, screen } from '@testing-library/react';
import React from 'react';
import { MemoryRouter } from 'react-router-dom';
import HelpStaff from '../HelpStaff';
vi.mock('react-i18next', () => ({
useTranslation: () => ({
t: (key: string, fallback?: string) => fallback || key,
}),
}));
const renderWithRouter = (component: React.ReactElement) => {
return render(
React.createElement(MemoryRouter, {}, component)
);
};
describe('HelpStaff', () => {
it('renders the page title', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Staff Guide')).toBeInTheDocument();
});
it('renders the page description', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Manage your team members, roles, and permissions')).toBeInTheDocument();
});
it('renders back button', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Back')).toBeInTheDocument();
});
it('renders overview section', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Overview')).toBeInTheDocument();
expect(screen.getByText(/manage team members who can access your business dashboard/i)).toBeInTheDocument();
});
it('renders understanding roles section', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Understanding Roles')).toBeInTheDocument();
});
it('renders user role types', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Owner')).toBeInTheDocument();
});
it('renders staff roles section', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Staff Roles: Permission Templates')).toBeInTheDocument();
expect(screen.getByText('Manager')).toBeInTheDocument();
});
it('renders need more help section', () => {
renderWithRouter(React.createElement(HelpStaff));
expect(screen.getByText('Need More Help?')).toBeInTheDocument();
expect(screen.getByRole('button', { name: /contact support/i })).toBeInTheDocument();
});
});