import { render, screen } from '@testing-library/react'
import { describe, expect, it, vi } from 'vitest'
import CreateFromPipeline from './index'
// Mock child components to isolate testing
vi.mock('./header', () => ({
default: () =>
Header
,
}))
vi.mock('./list', () => ({
default: () => List
,
}))
vi.mock('./footer', () => ({
default: () => Footer
,
}))
vi.mock('../../base/effect', () => ({
default: ({ className }: { className?: string }) => (
Effect
),
}))
// ============================================================================
// CreateFromPipeline Component Tests
// ============================================================================
describe('CreateFromPipeline', () => {
// --------------------------------------------------------------------------
// Rendering Tests
// --------------------------------------------------------------------------
describe('Rendering', () => {
it('should render without crashing', () => {
render()
expect(screen.getByTestId('mock-header')).toBeInTheDocument()
})
it('should render Header component', () => {
render()
expect(screen.getByTestId('mock-header')).toBeInTheDocument()
})
it('should render List component', () => {
render()
expect(screen.getByTestId('mock-list')).toBeInTheDocument()
})
it('should render Footer component', () => {
render()
expect(screen.getByTestId('mock-footer')).toBeInTheDocument()
})
it('should render Effect component', () => {
render()
expect(screen.getByTestId('mock-effect')).toBeInTheDocument()
})
})
// --------------------------------------------------------------------------
// Layout Tests
// --------------------------------------------------------------------------
describe('Layout', () => {
it('should have proper container classes', () => {
const { container } = render()
const mainDiv = container.firstChild as HTMLElement
expect(mainDiv).toHaveClass('relative', 'flex', 'flex-col', 'overflow-hidden', 'rounded-t-2xl')
})
it('should have correct height calculation', () => {
const { container } = render()
const mainDiv = container.firstChild as HTMLElement
expect(mainDiv).toHaveClass('h-[calc(100vh-56px)]')
})
it('should have border and background styling', () => {
const { container } = render()
const mainDiv = container.firstChild as HTMLElement
expect(mainDiv).toHaveClass('border-t', 'border-effects-highlight', 'bg-background-default-subtle')
})
it('should position Effect component correctly', () => {
render()
const effect = screen.getByTestId('mock-effect')
expect(effect).toHaveClass('left-8', 'top-[-34px]', 'opacity-20')
})
})
// --------------------------------------------------------------------------
// Component Order Tests
// --------------------------------------------------------------------------
describe('Component Order', () => {
it('should render components in correct order', () => {
const { container } = render()
const children = Array.from(container.firstChild?.childNodes || [])
// Effect, Header, List, Footer
expect(children.length).toBe(4)
})
})
})