Comment contribuer
Nous serions ravis d’accepter vos correctifs et contributions à ce projet.
Processus de contribution
Revues de code
Toutes les soumissions, y compris celles des membres du projet, nécessitent une revue. Nous utilisons les pull requests GitHub à cet effet.
Directives pour les Pull Requests
Pour nous aider à examiner et fusionner vos PR rapidement, veuillez suivre ces directives. Les PR qui ne respectent pas ces standards pourront être fermées.
1. Lier à une issue existante
Toutes les PR doivent être liées à une issue existante dans notre tracker. Cela garantit que chaque modification a été discutée et est alignée avec les objectifs du projet avant l’écriture de tout code.
- Pour les correctifs de bugs : La PR doit être liée à l’issue de rapport de bug.
- Pour les fonctionnalités : La PR doit être liée à l’issue de demande de fonctionnalité ou de proposition qui a été approuvée par un mainteneur.
Si aucune issue n’existe pour votre modification, veuillez en ouvrir une d’abord et attendre un retour avant de commencer à coder.
2. Restez concis et ciblé
Nous privilégions les PR petites et atomiques qui traitent d’un seul problème ou ajoutent une seule fonctionnalité autonome.
- À faire : Créez une PR qui corrige un bug spécifique ou ajoute une fonctionnalité spécifique.
- À éviter : Regroupez plusieurs modifications sans rapport (par ex., un correctif de bug, une nouvelle fonctionnalité et un refactoring) dans une seule PR.
Les modifications importantes doivent être découpées en une série de PR plus petites et logiques, pouvant être examinées et fusionnées indépendamment.
3. Utilisez les Draft PR pour les travaux en cours
Si vous souhaitez obtenir un retour rapide sur votre travail, veuillez utiliser la fonctionnalité Draft Pull Request de GitHub. Cela indique aux mainteneurs que la PR n’est pas encore prête pour une revue formelle, mais qu’elle est ouverte à la discussion et aux premiers retours.
4. Assurez-vous que toutes les vérifications passent
Avant de soumettre votre PR, assurez-vous que toutes les vérifications automatisées passent en exécutant npm run preflight. Cette commande lance tous les tests, le linting et d’autres vérifications de style.
5. Mettez à jour la documentation
Si votre PR introduit un changement visible par l’utilisateur (par ex., une nouvelle commande, un flag modifié ou un changement de comportement), vous devez également mettre à jour la documentation correspondante dans le répertoire /docs.
6. Rédigez des messages de commit clairs et une bonne description de PR
Votre PR doit avoir un titre clair et descriptif, ainsi qu’une description détaillée des modifications. Respectez le standard Conventional Commits pour vos messages de commit.
- Bon titre de PR :
feat(cli): Add --json flag to 'config get' command - Mauvais titre de PR :
Made some changes
Dans la description de la PR, expliquez le “pourquoi” de vos modifications et liez l’issue correspondante (par ex., Fixes #123).
Configuration et flux de travail de développement
Cette section guide les contributeurs sur la façon de construire, modifier et comprendre la configuration de développement de ce projet.
Configuration de l’environnement de développement
Prérequis :
- Node.js :
- Développement : Veuillez utiliser Node.js
~20.19.0. Cette version spécifique est requise en raison d’un problème de dépendance de développement en amont. Vous pouvez utiliser un outil comme nvm pour gérer les versions de Node.js. - Production : Pour exécuter la CLI dans un environnement de production, toute version de Node.js
>=20est acceptable.
- Développement : Veuillez utiliser Node.js
- Git
Processus de build
Pour cloner le dépôt :
git clone https://github.com/QwenLM/qwen-code.git # Or your fork's URL
cd qwen-codePour installer les dépendances définies dans package.json ainsi que les dépendances racines :
npm installPour construire l’ensemble du projet (tous les packages) :
npm run buildCette commande compile généralement le TypeScript en JavaScript, bundle les assets et prépare les packages pour l’exécution. Consultez scripts/build.js et les scripts de package.json pour plus de détails sur le déroulement du build.
Activation du sandboxing
Le sandboxing est fortement recommandé et nécessite, au minimum, de définir QWEN_SANDBOX=true dans votre ~/.env et de vous assurer qu’un fournisseur de sandboxing (par ex. macOS Seatbelt, docker ou podman) est disponible. Consultez Sandboxing pour plus de détails.
Pour construire à la fois l’utilitaire CLI qwen-code et le conteneur sandbox, exécutez build:all depuis le répertoire racine :
npm run build:allPour ignorer la construction du conteneur sandbox, vous pouvez utiliser npm run build à la place.
Exécution
Pour démarrer l’application Qwen Code à partir du code source (après le build), exécutez la commande suivante depuis le répertoire racine :
npm startSi vous souhaitez exécuter le build source en dehors du dossier qwen-code, vous pouvez utiliser npm link path/to/qwen-code/packages/cli (voir : docs ) pour l’exécuter avec qwen-code.
Exécution des tests
Ce projet contient deux types de tests : les tests unitaires et les tests d’intégration.
Tests unitaires
Pour exécuter la suite de tests unitaires du projet :
npm run testCela exécutera les tests situés dans les répertoires packages/core et packages/cli. Assurez-vous que les tests passent avant de soumettre des modifications. Pour une vérification plus complète, il est recommandé d’exécuter npm run preflight.
Tests d’intégration
Les tests d’intégration sont conçus pour valider le fonctionnement de bout en bout de Qwen Code. Ils ne sont pas exécutés dans le cadre de la commande par défaut npm run test.
Pour exécuter les tests d’intégration, utilisez la commande suivante :
npm run test:e2ePour plus d’informations détaillées sur le framework de tests d’intégration, veuillez consulter la documentation des tests d’intégration.
Linting et vérifications preflight
Pour garantir la qualité du code et la cohérence du formatage, exécutez la vérification preflight :
npm run preflightCette commande exécutera ESLint, Prettier, tous les tests et d’autres vérifications telles que définies dans le package.json du projet.
Astuce
après le clonage, créez un fichier de hook git precommit pour vous assurer que vos commits sont toujours propres.
echo "
# Run npm build and check for errors
if ! npm run preflight; then
echo "npm build failed. Commit aborted."
exit 1
fi
" > .git/hooks/pre-commit && chmod +x .git/hooks/pre-commitFormatage
Pour formater séparément le code de ce projet, exécutez la commande suivante depuis le répertoire racine :
npm run formatCette commande utilise Prettier pour formater le code selon les directives de style du projet.
Linting
Pour exécuter le linting séparément sur le code de ce projet, exécutez la commande suivante depuis le répertoire racine :
npm run lintConventions de codage
- Veuillez respecter le style de codage, les patterns et les conventions utilisés dans l’ensemble du codebase existant.
- Imports : Portez une attention particulière aux chemins d’import. Le projet utilise ESLint pour appliquer des restrictions sur les imports relatifs entre les packages.
Structure du projet
packages/: Contient les sous-packages individuels du projet.cli/: L’interface en ligne de commande.core/: La logique backend principale pour Qwen Code.
docs/: Contient toute la documentation du projet.scripts/: Scripts utilitaires pour les tâches de build, de test et de développement.
Pour une architecture plus détaillée, consultez docs/architecture.md.
Développement de la documentation
Cette section décrit comment développer et prévisualiser la documentation localement.
Prérequis
- Assurez-vous d’avoir Node.js (version 18+) installé
- Avoir npm ou yarn disponible
Configuration locale du site de documentation
Pour travailler sur la documentation et prévisualiser les modifications localement :
-
Accédez au répertoire
docs-site:cd docs-site -
Installez les dépendances :
npm install -
Liez le contenu de la documentation depuis le répertoire principal
docs:npm run linkCela crée un lien symbolique de
../docsverscontentdans le projet docs-site, permettant au contenu de la documentation d’être servi par le site Next.js. -
Démarrez le serveur de développement :
npm run dev -
Ouvrez http://localhost:3000 dans votre navigateur pour voir le site de documentation avec des mises à jour en direct au fur et à mesure de vos modifications.
Toute modification apportée aux fichiers de documentation dans le répertoire principal docs sera immédiatement reflétée sur le site de documentation.
Débogage
VS Code :
- Exécutez la CLI pour déboguer de manière interactive dans VS Code avec
F5 - Démarrez la CLI en mode debug depuis le répertoire racine :
Cette commande exécute
npm run debugnode --inspect-brk dist/index.jsdans le répertoirepackages/cli, mettant l’exécution en pause jusqu’à ce qu’un débogueur s’y attache. Vous pouvez ensuite ouvrirchrome://inspectdans votre navigateur Chrome pour vous connecter au débogueur. - Dans VS Code, utilisez la configuration de lancement “Attach” (trouvée dans
.vscode/launch.json).
Vous pouvez également utiliser la configuration “Launch Program” dans VS Code si vous préférez lancer directement le fichier actuellement ouvert, mais ‘F5’ est généralement recommandé.
Pour atteindre un point d’arrêt à l’intérieur du conteneur sandbox, exécutez :
DEBUG=1 qwen-codeRemarque : Si vous avez DEBUG=true dans le fichier .env d’un projet, cela n’affectera pas qwen-code en raison de l’exclusion automatique. Utilisez les fichiers .qwen-code/.env pour les paramètres de debug spécifiques à qwen-code.
React DevTools
Pour déboguer l’interface utilisateur basée sur React de la CLI, vous pouvez utiliser React DevTools. Ink, la bibliothèque utilisée pour l’interface de la CLI, est compatible avec React DevTools version 4.x.
-
Démarrez l’application Qwen Code en mode développement :
DEV=true npm start -
Installez et exécutez React DevTools version 4.28.5 (ou la dernière version 4.x compatible) :
Vous pouvez soit l’installer globalement :
npm install -g react-devtools@4.28.5 react-devtoolsOu l’exécuter directement avec npx :
npx react-devtools@4.28.5Votre application CLI en cours d’exécution devrait alors se connecter à React DevTools.
Sandboxing
À venir
Publication manuelle
Nous publions un artifact pour chaque commit dans notre registre interne. Mais si vous devez créer manuellement un build local, exécutez les commandes suivantes :
npm run clean
npm install
npm run auth
npm run prerelease:dev
npm publish --workspaces