Keep/keep-notes/tests/recent-notes-section.spec.ts

162 lines
5.7 KiB
TypeScript

import { test, expect } from '@playwright/test'
test.describe('Recent Notes Section', () => {
test.beforeEach(async ({ page }) => {
// Navigate to home page
await page.goto('/')
// Wait for page to load
await page.waitForLoadState('networkidle')
})
test('should display recent notes section when notes exist', async ({ page }) => {
// Check if recent notes section exists
const recentSection = page.locator('[data-testid="recent-notes-section"]')
// The section should be visible when there are recent notes
// Note: This test assumes there are notes created/modified in the last 7 days
await expect(recentSection).toBeVisible()
})
test('should show section header with clock icon and title', async ({ page }) => {
const recentSection = page.locator('[data-testid="recent-notes-section"]')
// Check for header elements
await expect(recentSection.locator('text=Recent Notes')).toBeVisible()
await expect(recentSection.locator('text=(last 7 days)')).toBeVisible()
})
test('should be collapsible', async ({ page }) => {
const recentSection = page.locator('[data-testid="recent-notes-section"]')
const collapseButton = recentSection.locator('button[aria-expanded]')
// Check that collapse button exists
await expect(collapseButton).toBeVisible()
// Click to collapse
await collapseButton.click()
await expect(collapseButton).toHaveAttribute('aria-expanded', 'false')
// Click to expand
await collapseButton.click()
await expect(collapseButton).toHaveAttribute('aria-expanded', 'true')
})
test('should display notes in grid layout', async ({ page }) => {
const recentSection = page.locator('[data-testid="recent-notes-section"]')
const collapseButton = recentSection.locator('button[aria-expanded]')
// Ensure section is expanded
if (await collapseButton.getAttribute('aria-expanded') === 'false') {
await collapseButton.click()
}
// Check for grid layout
const grid = recentSection.locator('.grid')
await expect(grid).toBeVisible()
// Check that grid has correct classes
await expect(grid).toHaveClass(/grid-cols-1/)
})
test('should not show pinned notes in recent section', async ({ page }) => {
const recentSection = page.locator('[data-testid="recent-notes-section"]')
// Recent notes should filter out pinned notes
// Get all note cards in recent section
const recentNoteCards = recentSection.locator('[data-testid^="note-card-"]')
// If there are recent notes, none should be pinned
const count = await recentNoteCards.count()
if (count > 0) {
// Check that none of the notes in recent section have pin indicator
// This is an indirect check - pinned notes are shown in FavoritesSection
// The implementation should filter them out
const favoriteSection = page.locator('[data-testid="favorites-section"]')
await expect(favoriteSection).toBeVisible()
}
})
test('should handle empty state (no recent notes)', async ({ page }) => {
// This test would need to manipulate the database to ensure no recent notes
// For now, we can check that the section doesn't break when empty
// Reload page to check stability
await page.reload()
await page.waitForLoadState('networkidle')
// Page should load without errors
await expect(page).toHaveTitle(/Keep/)
})
})
test.describe('Recent Notes - Integration', () => {
test('new note should appear in recent section', async ({ page }) => {
// Create a new note
await page.goto('/')
await page.waitForLoadState('networkidle')
const noteContent = `Test note for recent section - ${Date.now()}`
// Type in note input
const noteInput = page.locator('[data-testid="note-input-textarea"]')
await noteInput.fill(noteContent)
// Submit note
const submitButton = page.locator('button[type="submit"]')
await submitButton.click()
// Wait for note to be created
await page.waitForTimeout(1000)
// Reload page to refresh recent notes
await page.reload()
await page.waitForLoadState('networkidle')
// Check if recent notes section is visible
const recentSection = page.locator('[data-testid="recent-notes-section"]')
// The section should now be visible with the new note
await expect(recentSection).toBeVisible()
})
test('editing note should update its position in recent section', async ({ page }) => {
// This test verifies that edited notes move to top
// It requires at least one note to exist
await page.goto('/')
await page.waitForLoadState('networkidle')
const recentSection = page.locator('[data-testid="recent-notes-section"]')
// If recent notes exist
if (await recentSection.isVisible()) {
// Get first note card
const firstNote = recentSection.locator('[data-testid^="note-card-"]').first()
// Click to edit
await firstNote.click()
// Wait for editor to open
const editor = page.locator('[data-testid="note-editor"]')
await expect(editor).toBeVisible()
// Make a small edit
const contentArea = editor.locator('textarea').first()
await contentArea.press('End')
await contentArea.type(' - edited')
// Save changes
const saveButton = editor.locator('button:has-text("Save")').first()
await saveButton.click()
// Wait for save and reload
await page.waitForTimeout(1000)
await page.reload()
await page.waitForLoadState('networkidle')
// The edited note should still be in recent section
await expect(recentSection).toBeVisible()
}
})
})