Différences entre versions de « PHP »
imported>SylvainBeucler m (→Tests unitaires avec PHP : phpt) |
imported>SylvainBeucler |
||
Ligne 36 : | Ligne 36 : | ||
* [http://www.simpletest.org/ SimpleTest] | * [http://www.simpletest.org/ SimpleTest] | ||
* [http://phpunit.de/ PHPUnit] | * [http://phpunit.de/ PHPUnit] | ||
− | * | + | * phpt ([http://weierophinney.net/matthew/archives/65-phpt-Tutorial.html tutorial], [http://qa.php.net/write-test.php guide qa.php.net]), apparemment plus simple/rapide. Lancer avec <code>pear run-tests *.phpt</code>. |
Voir également WWW::Mechanize (''Mech'') pour tester le programme de manière externe par son interface web (en Perl). Pour une solution en PHP, voir éventuellement la bibliothèque curl, qui ne sait cependant pas analyser le HTML reçu. | Voir également WWW::Mechanize (''Mech'') pour tester le programme de manière externe par son interface web (en Perl). Pour une solution en PHP, voir éventuellement la bibliothèque curl, qui ne sait cependant pas analyser le HTML reçu. |
Version du 4 janvier 2007 à 17:22
Dernières versions de la documentation officielle de PHP, avant qu'elle ne devienne non-libre:
- Documentation for PHP3
- Documentation for PHP4 and PHP3 (snapshot 2002)
Dernière version libre de la documentation PHP
Précisons que l'Open Publication License (OPL) est une licence libre uniquement si aucune option n'est utilisée (notamment, l'interdiction des travaux dérivés sans consentement des détenteurs des droits).
La dernière version date de 2003.
Avec cvs2cl --utc
, j'obtiens le ChangeLog suivant:
2003-05-02 14:12 goba * en/bookinfo.xml: And now: upgrading to the new license
La dernière version libre est donc:
cvs -d :pserver:cvsread@cvs.php.net:/repository login # pass: phpfi cvs -d :pserver:cvsread@cvs.php.net:/repository checkout -D "2003-05-02 14:12:58Z" phpdocs
PEAR
Problèmes de license:
- Début
- Conclusion?
- Bug à inverser au niveau de la documentation
- Page de doc à corriger
Tests unitaires avec PHP
- SimpleTest
- PHPUnit
- phpt (tutorial, guide qa.php.net), apparemment plus simple/rapide. Lancer avec
pear run-tests *.phpt
.
Voir également WWW::Mechanize (Mech) pour tester le programme de manière externe par son interface web (en Perl). Pour une solution en PHP, voir éventuellement la bibliothèque curl, qui ne sait cependant pas analyser le HTML reçu.
Génération de formulaires
- HTML_QuickForm: one class that contains all form elements and associated info (validation), which can analyse input and render the form in HTML Critic HTML_QuickForm2
- patForms
- Solar_Form (à coupler avec un moteur de template pour l'affichage?)
Abstraction de la base de données
- MDB2: successeur de PEAR::DB, licence mBSD
- Creole: PHP5 seulement; licence LGPL
- AdoDB: utilisé par TikiWiki, Xaraya, eGroupWare; license mBSD
Simplification de l'accès à la base
Dépend d'une des abstraction ci-dessus. Mots-clefs à chercher: ORM (Object Relational Mapping)
- DB_Table: non-object, intégration avec QuickForm et validation des update/insert, description via une classe et des tableaux ($cols, $idx, $sql...); utilise PEAR::DB (licence PHP); LGPL
- Propel: description en XML (lourd?), relations inter-classes, relations N-M possibles mais pas encore propres; possibilité d'utiliser directement SQL si besoin; validation décrite en XML (lourd); utilise Creole
- DB_DataContainer: mapping objet simpliste, pas de relation inter-tables; description via la classe PHP; nécessite un champ 'id'.
- DB_DataObject: fichier de description .ini; liens entre classes; à essayer; licence PHP
- EZPDO: description inclue dans des tags @orm style javadoc; validation via des 'Events'/hooks, aucune validation par défaut a priori; mBSD
- CakePHP: framework style Ruby on Rails, inclut un ORM; la validation, à base de regexp, fait partie du framework et en est vraisemblablement indissociable.
- Doctrine: ça a l'air très propre; discussions en cours pour intégration dans PEAR
- MetaL Metastrorage: beaucoup de XML
- ADOdb Active Record: un ORM qui fait partie d'ADOdb, à voir
- d'autres listés sur Wikipedia.