ObsiViewer/docs/FOLDER_NAVIGATION_TEST_GUIDE.md
Bruno Charest 0dc346d6b7 feat: add folder filtering and improve list view performance
- Added server-side folder filtering to paginated metadata endpoint with support for regular folders and .trash
- Improved list view performance by optimizing kind filtering and non-markdown file handling
- Updated folder navigation to properly reset other filters (tags, quick links, search) when selecting a folder
- Added request ID tracking to prevent stale responses from affecting pagination state
- Enhanced list view to show loading
2025-11-02 08:38:05 -05:00

340 lines
8.9 KiB
Markdown

# 🧪 Guide de Test - Navigation Folders
## 🎯 Objectif
Valider que la correction de la navigation dans les dossiers fonctionne correctement dans tous les scénarios.
## 🚀 Préparation
### 1. Démarrer le serveur de développement
```bash
cd c:\dev\git\web\ObsiViewer
npm start
```
### 2. Ouvrir la console du navigateur
- **Chrome/Edge**: F12 → Onglet Console
- **Firefox**: F12 → Onglet Console
- Filtrer les logs: `[PaginatedNotesList]`
### 3. Préparer l'environnement de test
- Créer plusieurs dossiers avec différents nombres de notes:
- `test-empty` (0 notes)
- `test-small` (5 notes)
- `test-medium` (50 notes)
- `test-large` (200 notes)
- `test-deep/level1/level2` (sous-dossiers)
## 📋 Scénarios de Test
### ✅ Test 1: Navigation Simple
**Objectif**: Vérifier que la sélection d'un dossier affiche les bonnes notes
**Étapes**:
1. Ouvrir l'application
2. Cliquer sur le dossier `test-medium` (50 notes)
3. Observer la liste de notes
**Résultat attendu**:
- ✅ La liste affiche exactement 50 notes
- ✅ Le compteur indique "50" en bas à droite
- ✅ Console log: `[PaginatedNotesList] Folder filter changed: { from: null, to: 'test-medium' }`
- ✅ Requête HTTP: `GET /api/vault/metadata/paginated?folder=test-medium&limit=100`
**Résultat observé**: ___________
---
### ✅ Test 2: Navigation Rapide (Multiple Clics)
**Objectif**: Vérifier qu'il n'y a pas de "flicker" lors de changements rapides
**Étapes**:
1. Cliquer sur `test-small` (5 notes)
2. **Immédiatement** cliquer sur `test-medium` (50 notes)
3. **Immédiatement** cliquer sur `test-large` (200 notes)
**Résultat attendu**:
- ✅ Pas de "flash" des notes du dossier précédent
- ✅ La liste finale affiche 200 notes de `test-large`
- ✅ Pas d'erreur dans la console
- ✅ Chaque clic déclenche un nouveau `setFolderFilter()`
**Résultat observé**: ___________
---
### ✅ Test 3: Dossier Vide
**Objectif**: Vérifier le comportement avec un dossier sans contenu
**Étapes**:
1. Cliquer sur le dossier `test-empty` (0 notes)
**Résultat attendu**:
- ✅ Message "Aucune note trouvée"
- ✅ Compteur indique "0"
- ✅ Pas d'erreur dans la console
- ✅ Requête HTTP: `GET /api/vault/metadata/paginated?folder=test-empty&limit=100`
**Résultat observé**: ___________
---
### ✅ Test 4: Dossiers Profonds
**Objectif**: Vérifier la navigation dans des sous-dossiers
**Étapes**:
1. Développer (expand) le dossier `test-deep`
2. Développer le sous-dossier `level1`
3. Cliquer sur `level2`
**Résultat attendu**:
- ✅ Affiche uniquement les notes de `test-deep/level1/level2`
- ✅ N'affiche PAS les notes des dossiers parents
- ✅ Le chemin complet est envoyé au serveur: `folder=test-deep/level1/level2`
**Résultat observé**: ___________
---
### ✅ Test 5: Combinaison Dossier + Recherche
**Objectif**: Vérifier que la recherche fonctionne dans un dossier filtré
**Étapes**:
1. Cliquer sur `test-medium` (50 notes)
2. Saisir "test" dans la barre de recherche
3. Observer le résultat
4. Effacer la recherche
**Résultat attendu**:
- ✅ Après saisie: Affiche uniquement les notes contenant "test" dans `test-medium`
- ✅ Compteur mis à jour (ex: "12")
- ✅ Après effacement: Revient aux 50 notes
- ✅ Requête HTTP inclut: `?folder=test-medium&search=test`
**Résultat observé**: ___________
---
### ✅ Test 6: Combinaison Dossier + Tag
**Objectif**: Vérifier l'interaction entre filtres de dossier et de tag
**Étapes**:
1. Cliquer sur `test-medium` (50 notes)
2. Noter le nombre de notes affichées (ex: 50)
3. Cliquer sur un tag (ex: `#important`)
4. Observer le résultat
5. Cliquer sur un autre dossier
**Résultat attendu**:
- ✅ Après tag: Affiche les notes de `test-medium` ayant le tag `#important`
- ✅ Après changement dossier: Affiche les notes du nouveau dossier ayant le tag `#important`
- ✅ Requête HTTP: `?folder=...&tag=important`
**Résultat observé**: ___________
---
### ✅ Test 7: Retour à "Tout Afficher"
**Objectif**: Vérifier la réinitialisation du filtre
**Étapes**:
1. Cliquer sur un dossier (ex: `test-medium`)
2. Cliquer sur "✨ Tout" dans Quick Links
**Résultat attendu**:
- ✅ Affiche toutes les notes de tous les dossiers
- ✅ Compteur affiche le total (ex: "1,234")
- ✅ Console log: `[PaginatedNotesList] Folder filter changed: { from: 'test-medium', to: null }`
**Résultat observé**: ___________
---
### ✅ Test 8: Scroll Infini
**Objectif**: Vérifier la pagination avec un grand dossier
**Étapes**:
1. Cliquer sur `test-large` (200 notes)
2. Scroller vers le bas de la liste
3. Observer le chargement automatique
**Résultat attendu**:
- ✅ Les premières 100 notes se chargent immédiatement
- ✅ En scrollant, les 100 notes suivantes se chargent automatiquement
- ✅ Indicateur "Chargement..." visible pendant le chargement
- ✅ Requête HTTP avec cursor: `?folder=test-large&cursor=100`
**Résultat observé**: ___________
---
### ✅ Test 9: Rafraîchissement Page
**Objectif**: Vérifier la persistance de l'état après F5
**Étapes**:
1. Cliquer sur un dossier (ex: `test-medium`)
2. Observer l'URL (doit contenir `?folder=test-medium`)
3. Appuyer sur F5 (rafraîchir la page)
**Résultat attendu**:
- ✅ La page se recharge avec le même dossier sélectionné
- ✅ Les notes du dossier s'affichent immédiatement
- ✅ L'URL conserve `?folder=test-medium`
**Résultat observé**: ___________
---
### ✅ Test 10: Navigation Back/Forward
**Objectif**: Vérifier la compatibilité avec l'historique du navigateur
**Étapes**:
1. Cliquer sur `test-small`
2. Cliquer sur `test-medium`
3. Cliquer sur `test-large`
4. Cliquer sur le bouton "Retour" du navigateur (2 fois)
5. Cliquer sur le bouton "Avancer" du navigateur
**Résultat attendu**:
- ✅ Retour 1: Revient à `test-medium` avec ses notes
- ✅ Retour 2: Revient à `test-small` avec ses notes
- ✅ Avancer: Revient à `test-medium`
- ✅ L'URL change à chaque navigation
**Résultat observé**: ___________
---
## 🔍 Validation Console
### Logs Attendus (Exemple)
```javascript
// Navigation vers un dossier
[PaginatedNotesList] Folder filter changed: { from: null, to: 'folder-4' }
// Requête HTTP
GET /api/vault/metadata/paginated?folder=folder-4&limit=100 200 OK (45ms)
// Changement de dossier
[PaginatedNotesList] Folder filter changed: { from: 'folder-4', to: 'Allo-3' }
GET /api/vault/metadata/paginated?folder=Allo-3&limit=100 200 OK (38ms)
// Réinitialisation
[PaginatedNotesList] Folder filter changed: { from: 'Allo-3', to: null }
GET /api/vault/metadata/paginated?limit=100 200 OK (120ms)
```
### ⚠️ Logs d'Erreur à Surveiller
```javascript
// ❌ Ne devrait PAS apparaître
[PaginatedNotesList] Failed to set folder filter: ...
Error: Network error
Error: 404 Not Found
```
---
## 📊 Métriques de Performance
### Temps de Réponse Attendus
| Scénario | Temps Cible | Acceptable | Critique |
|----------|-------------|------------|----------|
| Dossier < 100 notes | < 100ms | < 200ms | > 500ms |
| Dossier > 100 notes | < 150ms | < 300ms | > 1s |
| Changement rapide | < 50ms | < 100ms | > 200ms |
| Scroll infini | < 100ms | < 200ms | > 500ms |
### Utilisation Mémoire
- **Initial**: ~50 MB
- **Après navigation 10 dossiers**: ~60-70 MB
- **Maximum acceptable**: < 150 MB
### Requêtes HTTP
- **Chaque sélection de dossier**: 1 requête
- **Pas de double requête** pour la même sélection
- **Annulation automatique** si navigation rapide
---
## ✅ Checklist Finale
### Fonctionnel
- [ ] Test 1: Navigation simple - OK
- [ ] Test 2: Navigation rapide - OK
- [ ] Test 3: Dossier vide - OK
- [ ] Test 4: Dossiers profonds - OK
- [ ] Test 5: Dossier + Recherche - OK
- [ ] Test 6: Dossier + Tag - OK
- [ ] Test 7: Retour "Tout" - OK
- [ ] Test 8: Scroll infini - OK
- [ ] Test 9: Rafraîchissement page - OK
- [ ] Test 10: Back/Forward - OK
### Performance
- [ ] Temps de réponse < 200ms - OK
- [ ] Pas de "flicker" visuel - OK
- [ ] Mémoire < 150 MB - OK
- [ ] Pas de double requête - OK
### Console
- [ ] Logs corrects `[PaginatedNotesList]` - OK
- [ ] Requêtes HTTP avec bons params - OK
- [ ] Pas d'erreur JavaScript - OK
- [ ] Pas de warning Angular - OK
---
## 🐛 Signaler un Bug
Si un test échoue:
1. **Noter les détails**:
- Numéro du test
- Résultat observé
- Logs console (screenshot ou copie)
- URL actuelle
2. **Reproduire** le bug:
- Essayer 3 fois
- Noter si c'est intermittent
3. **Créer un rapport**:
```markdown
## Bug: [Titre court]
**Test**: #X - [Nom du test]
**Observé**: [Description]
**Attendu**: [Description]
**Console**: [Logs]
**URL**: [URL complète]
**Reproductible**: Oui/Non
```
---
## 🎉 Validation Finale
**Tous les tests passent ?**
- **OUI** La correction est validée
- **NON** Voir la section "Signaler un Bug"
**Signature du testeur**: ___________
**Date**: ___________
**Environnement**: Windows/Mac/Linux + Chrome/Firefox/Edge
**Version**: Angular 20 + ObsiViewer v___________