Test (informatique)

Une programmeuse écrivant du code Java avec JUnit.

En informatique, un test est une procédure de vérification partielle d'un système. Son objectif principal est d'identifier un nombre maximal de comportements problématiques du logiciel. Il permet ainsi, dès lors que les problèmes identifiés seront corrigés, d'en augmenter la qualité.

D'une manière plus générale, le test désigne toutes les activités qui consistent à rechercher des informations quant à la qualité du système afin de permettre la prise de décisions.

Un test ressemble à une expérience scientifique. Il examine une hypothèse exprimée en fonction de trois éléments : les données en entrée, l'objet à tester et les observations attendues. Cet examen est effectué sous conditions contrôlées pour pouvoir tirer des conclusions et, dans l'idéal, être reproduit[1].

Définition

La définition qui suit est issue de la norme IEEE 829-1998[2] revue à l'aide du glossaire de l'ISTQB[3].

Un test est un ensemble de cas à tester (état de l'objet à tester avant exécution du test, actions ou données en entrée, valeurs ou observations attendues, et état de l'objet après exécution), éventuellement accompagné d'une procédure d'exécution (séquence d'actions à exécuter). Il est lié à un objectif.

La réalisation d'un test amène donc à définir cet ensemble. Différents types de test permettent de détecter différents types de défaut. Des méthodes de spécification de test ont été élaborées pour permettre une plus grande rigueur dans cette activité de définition. La norme britannique BS 7925-2[4],[5] ou le Software Testing Techniques[6] de Boris Bezier en donnent des exemples.

Un test vise à mettre en évidence des défauts de l'objet testé. Cependant, il n'a pas pour finalité de les corriger.

La définition d'un cas à tester précise les exigences s'appliquant à une spécification. Un objet ne peut être testé que si on peut déterminer précisément le comportement attendu en fonction des conditions auxquelles il est soumis. Si la spécification ne permet pas cette détermination, la propriété du logiciel qu'elle définit ne peut être testée.

Soumettre la spécification à cette contrainte de « testabilité » permet d'en améliorer la précision puisqu'elle oblige à expliciter les caractéristiques de l'objet. Ceci permet, en retour, de trouver plus tôt les erreurs de spécification. Cette contrainte est renforcée par certaines méthodes de développement comme le Test-Driven Development[réf. souhaitée]. L'ISTQB souligne le rapport de cette contrainte à la « maintenabilité » de l'objet[réf. souhaitée].

L'activité de test d'un logiciel utilise différents types et techniques de tests pour vérifier que le logiciel est conforme à son cahier des charges ou ses spécifications (vérification du produit) et aux attentes du client (validation du produit). Elle est un des processus du développement de logiciels.

Défaut (Bug)

L'ISTQB définit un défaut comme une imperfection dans un composant ou un système qui peut en perturber le fonctionnement. Ce défaut est révélé par une défaillance (failure) si le système est exécuté, c'est-à-dire une déviation par rapport au comportement ou résultat attendu[3].

Cette définition indique que l'exécution du système n'est pas la seule façon de détecter des défauts. Elle laisse aussi entrevoir le fait qu'un code peut être syntaxiquement et sémantiquement correct et pourtant présenter un défaut qui ne se manifestera que lors d'un test de performance par exemple. Dans un tel cas, l'origine du défaut pourrait être une erreur d'architecture ou de configuration.

Le terme anomalie est aussi souvent utilisé. C'est un terme générique qui fait référence autant à un défaut qu'à une défaillance[réf. souhaitée].

La définition donnée dans la norme BS 7925-1[7] pour l'entrée fault (il n'y a pas d'entrée defect) fait de cette imperfection la matérialisation d'une erreur, c'est-à-dire d'une action humaine produisant un résultat incorrect (voir cette norme et la norme IEEE 610.12-1990[8]), une « faute » de frappe ou une erreur de raisonnement par exemple. L'ISTQB semble se démarquer de cette position car même s'il considère que les défauts sont le plus souvent provoqués par des erreurs humaines, ceux-ci peuvent aussi être la conséquence de phénomènes environnementaux (radiation, pollution, magnétisme…) modifiant le support hardware des logiciels testés.

Qualité et test

Les phases de test dans le cycle de développement d'un produit logiciel permettent d'assurer un niveau de qualité défini en accord avec le client. Une procédure de test peut donc être plus ou moins fine, et par conséquent l'effort de test plus ou moins important et coûteux selon le niveau de qualité requis. Aujourd'hui, les métiers du test se développent considérablement. C'est en grande partie grâce à une prise de conscience de la complexité ou de la criticité des produits. Il est alors important que ces différentes phases soient bien intégrées dans le cycle de développement sur la base de bonnes pratiques et de la rationalisation du processus[9].

Classification des tests

Il existe différentes façons de classer les tests informatiques. Nous proposons ici une classification selon trois perspectives : la nature de l'objet à tester (perspective étroitement liée au cycle de développement), l'accessibilité de la structure de l'objet et la propriété de l'objet (performance par exemple).

Ces trois perspectives ne permettent cependant pas de classer le test de non-régression (voir aussi l'article sur la non-régression). Le glossaire de l'ISTQB[3] le définit comme cherchant à mettre en évidence, dans la partie inchangée du logiciel, des défauts mis à jour ou introduits par un changement dans le logiciel (mise à niveau, correction, etc) ou son environnement d'exécution.

Le test de non-régression n'est donc pas restreint à une phase particulière du cycle de développement. Il n'est pas non plus restreint à un type de propriété à tester.

Classification selon la nature de l'objet

Le glossaire de l'ISTQB[3] définit un niveau de tests comme un groupe d'activités de tests qui sont organisées et gérées ensemble. Un niveau de tests est lié aux responsabilités dans un projet.

Le Comité français du test logiciel (CFTL) identifie quatre niveaux de test :

  1. Test unitaire (ou test de composants) ;
  2. Test d'intégration (anciennement test technique ou test d'intégration technique) ;
  3. Test système (anciennement test fonctionnel ou test d'intégration fonctionnel ou homologation) ;
  4. Test d'acceptation (anciennement test usine ou recette).

Par ailleurs, on parle aussi de niveau de test amont pour désigner les niveaux unitaire et intégration, et de niveau de test aval pour désigner les niveaux système et acceptation.

De même, en France, le terme « phase de test » est parfois utilisé à la place de « niveau de test », mais il ne respecte pas le vocabulaire du CFTL.

Classification selon l'accessibilité de la structure de l'objet

  • Technique de conception de test par boîte blanche (white box) : technique de conception de test, en général fonctionnel, fondée sur l'analyse de la structure interne du composant ou du système.
  • Technique de conception de test par boîte noire (black box) : technique de conception de test, fonctionnel ou non, qui n'est pas fondée sur l'analyse de la structure interne du composant ou du système mais sur la définition du composant ou du système.

Par extension, on appelle couramment les tests issus de ces types de techniques de conception, tests boîte blanche (ou tests structurels) et tests boîte noire.

Les tests boîte blanche vérifient la structure interne de l'objet, par exemple l'exécution des branches des instructions conditionnelles. Les tests unitaires et d'intégration sont souvent spécifiés à l'aide des techniques de conception de test par boîte blanche. Pour certains types de logiciel, des normes prescrivent les techniques de conception de tests par boîte blanche à utiliser (par exemple, la norme américaine RTCA/DO-178B pour les logiciels d'avionique).

Les tests boîte noire vérifient la définition de l'objet. Les tests système et d'acceptation sont souvent spécifiés à l'aide des techniques de conception de test par boîte noire, mais rien n'empêche d'utiliser ces techniques pour définir des tests unitaires ou d'intégration.

Classification selon la propriété de l'objet

On ne peut pas être exhaustif, on se contentera de quelques exemples :

Une liste de toutes les caractéristiques d'un logiciel a été établie par la norme ISO 9126.

En dehors du cas très particulier de systèmes extrêmement simples, il est impossible de tester exhaustivement un logiciel, car le nombre de configurations possibles croît de façon exponentielle selon le nombre de mises en situation différentes que le logiciel pourra être appelé à traiter ; le nombre de configurations accessibles, bien qu'inférieur, reste tout de même prohibitif. La réussite des tests ne permet donc pas de conclure au bon fonctionnement du logiciel. On essaye cependant, heuristiquement, de faire en sorte que si un bug est présent, le test le mette en évidence, notamment en exigeant une bonne couverture des tests :

  • couverture en points de programme : chaque point de programme doit avoir été testé au moins une fois ;
  • couverture en chemins de programme : chaque séquence de points de programme possible dans une exécution doit avoir été testée au moins une fois (impossible en général) ;
  • couverture fonctionnelle : chaque fonctionnalité métier de l'application doit être vérifiée par au moins un cas de test.

Si l'on veut des assurances plus fortes de bon fonctionnement, on peut utiliser des méthodes formelles.

Les bibliothèques de tests telles que JUnit pour le langage Java permettent de faciliter l'écriture de tests unitaires par l'apport des méthodes assert permettant de vérifier le comportement du programme.

Selon la complexité du logiciel, des séquences de vérification globale peuvent s'avérer nécessaires. Celles-ci mettent en jeu la maîtrise d'ouvrage et toutes les composantes du projet, au-delà du logiciel lui-même (processus, organisation, formation, accompagnement du changement) : réception, qualification, certification, homologation, simulation, VABF (vérification d'aptitude au bon fonctionnement)… Les termes varient selon les contextes.

Activités de test

Le test est souvent assimilé à son activité d'exécution. Cependant, cette activité d'exécution ne saurait se passer des étapes nécessaires qui la précèdent et la suivent. L'ISTQB définit ainsi un processus de test fondamental en cinq étapes. En pratique, ces étapes peuvent se chevaucher, en particulier au sein des projets développés de manière itérative.

  • Planification. Cette activité est celle qui est pratiquée au tout début de la phase de test. Elle permet de définir la stratégie qui sera mise en place tout au long de la phase de test.
  • Analyse et conception des tests. Cette activité consiste en la rédaction des scénarios de tests qui seront joués. Elle définit pour chaque test à exécuter quels seront les prérequis à posséder pour effectuer le test, les actions qu'il faudra mener et les résultats auxquels on s'attend.
  • Implémentation et exécution. Cette activité est le test à proprement parler du logiciel. Dans le cas où une défaillance survient lors de cette phase, celle-ci est alors le plus souvent décrite dans une fiche d'anomalie qui permet de conserver une trace du problème.
  • Evaluation des critères de sortie et communication. Cette étape permet d'évaluer si les activités de test sont conformes aux objectifs définis. Il s'agit également de communiquer les résultats des tests aux autres parties prenantes.
  • Clôture. Cette activité permet de synthétiser la phase de test quand elle est terminée. Elle décrit tous les éléments survenus lors du test et peut s'accompagner de recommandations pour l'utilisation ou l'évolution du logiciel testé[10].

Exemples de logiciels de test

Outre les librairies utilisées lors des tests unitaires et d'intégration, les activités de test nécessitent l'utilisation de logiciels de différentes natures.

Gestionnaires des tests

Ces outils permettent entre autres de constituer des référentiels de tests fonctionnels et d'exécuter des campagnes de test.

  • Testlink (en)
  • HP Quality Center (en)
  • Squash TM
  • Refertest

Gestionnaire des anomalies

Ces outils permettent entre autres de déclarer des anomalies et de les assigner pour correction.

Génération de référentiel de test

Outils d'automatisation des tests fonctionnels

Une liste détaillée peut être trouvée sur l'article en anglais Comparison of GUI testing tools.

Outils de tests non-fonctionnels

Tests de sécurité

  • ZAP (Zed Attack Proxy) (en)

Tests de performance et de charge

Qualité de code

Notes et références

  1. Claude Laporte et Alain April, Assurance qualité logicielle 2 : processus de support, Chapitre 1, Lavoisier, 2011, (ISBN 9782746232228), p. 372.
  2. (en)IEEE Standard for Software Test Documentation, 1998 (ISBN 0-7381-1444-8).
  3. a b c et d (en) Standard glossary of terms used in Software Testing, ISTQB, version 2.0, décembre 2007.
  4. (en) Software testing. Software component testing, 1998 (ISBN 0-580-29556-7).
  5. version préliminaire disponible ici
  6. (en) Software Testing Techniques, Boris Beizer, 1990 (ISBN 0-442-20672-0).
  7. (en) Glossary of terms used in software testing.
  8. (en) IEEE Standard Glossary of Software Engineering Terminology, 1990 (ISBN 0-7381-0391-8).
  9. (fr) Industrialiser le test fonctionnel : des exigences métier au référentiel de tests, 2009 (ISBN 978-2-100515-33-2).
  10. International Software Testing Qualifications Board, Comité Français des Tests Logiciels, Testeur Certifié - Syllabus Niveau Fondation, 82 p. (lire en ligne), p. 15-17

Voir aussi

Sur les autres projets Wikimedia :

Articles connexes

Liens externes

Read other articles:

本條目存在以下問題,請協助改善本條目或在討論頁針對議題發表看法。 此條目需要补充更多来源。 (2018年3月17日)请协助補充多方面可靠来源以改善这篇条目,无法查证的内容可能會因為异议提出而被移除。致使用者:请搜索一下条目的标题(来源搜索:羅生門 (電影) — 网页、新闻、书籍、学术、图像),以检查网络上是否存在该主题的更多可靠来源(判定指引)。 �...

 

This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: Concourse at Landmark Center – news · newspapers · books · scholar · JSTOR (April 2016) (Learn how and when to remove this template message) 33°54′58″N 84°21′18″W / 33.916°N 84.355°W / 33.916; -84.355 Commercial in Georgia, ...

 

Computer appliance company (1996–2000) Cobalt Networks, Inc.Founded1996; 28 years ago (1996)FounderVivek MehraDefunctDecember 7, 2000; 23 years ago (2000-12-07)FateAcquired by Sun MicrosystemsHeadquartersMountain View, CaliforniaRevenue $22 million (1999)Net income -$23 million (1999)Total assets $151 million (1999)Total equity $130 million (1999)Number of employees140 (1999)Footnotes / references[1] Cobalt RaQ 2 Cobalt Qube - a computer ...

Pour les articles homonymes, voir Brooks et John Brooks. Cet article est une ébauche concernant un homme politique américain et le Massachusetts. Vous pouvez partager vos connaissances en l’améliorant (comment ?) selon les recommandations des projets correspondants. John BrooksFonctionGouverneur du Massachusetts30 mai 1816 - 31 mai 1823Caleb StrongWilliam EustisBiographieNaissance 4 mai 1752MedfordDécès 1er mars 1825 (à 72 ans)MedfordSépulture Salem Street Burying Ground (...

 

Recopa Sudamericana 1998 Competizione Recopa Sudamericana Sport Calcio Edizione 10ª Organizzatore CONMEBOL Partecipanti 2 Risultati Vincitore  Cruzeiro(1º titolo) Secondo  River Plate Cronologia della competizione 1997 2003 Manuale La Recopa Sudamericana 1998 è stata la decima edizione della Recopa Sudamericana; in questa occasione a contendersi la coppa furono il vincitore della Coppa Libertadores 1997 e il vincitore della Supercoppa Sudamericana 1997. Indice 1 Tabellino 1.1 An...

 

Premio Nobel Alfred Nobel Pace vincitori Letteratura vincitori, candidati Medicina vincitori Fisica vincitori, candidati Chimica vincitori, candidati Economia vincitori Il premio Nobel per la fisica (Svedese: Nobelpriset i fysik), istituito dal testamento di Alfred Nobel del 1895, viene assegnato, con cadenza annuale, tendenzialmente nel quarto trimestre dell'anno, dall'Accademia reale svedese delle scienze.[1] Assegnato per la prima volta nel 1901, come gli altri premi istituiti da ...

Sef Vergoossen Personal informationDate of birth (1947-08-05) 5 August 1947 (age 76)Place of birth Echt, The NetherlandsManagerial careerYears Team1978–1989 VVV-Venlo1989–1998 MVV1998–2001 Roda JC2001–2004 Racing Genk2004–2005 Al-Jazeera Club2006–2007 Nagoya Grampus Eight2008 PSV Eindhoven Josephus Gerardus Dominicus Sef Vergoossen (Dutch pronunciation: [ˈsɛf ˈfɛrɣoːsə(n)],[1] born 5 August 1947 in Echt) is a former Dutch football manager. Biography Ve...

 

Universidad de California Fundación 1868Fundador Frederick LowLocalizaciónDirección Oakland, Estados UnidosCoordenadas 37°48′08″N 122°16′17″O / 37.802168, -122.271281Sitio web http://www.universityofcalifornia.edu/ y https://www.universityofcalifornia.edu/[editar datos en Wikidata] Mapa del sistema La Universidad de California es un sistema público de universidades en el Estado de California, en los Estados Unidos de América. Conforme al Plan Maestro p...

 

Міністерство оборони України (Міноборони) Емблема Міністерства оборони та Прапор Міністерства оборони Будівля Міністерства оборони у КиєвіЗагальна інформаціяКраїна  УкраїнаДата створення 24 серпня 1991Попередні відомства Міністерство оборони СРСР Народний комісарі...

1º Reggimento artiglieria terrestre (montagna)Stemma del 1º Reggimento artiglieria terrestre (montagna) Descrizione generaleAttiva1º novembre 1887 - oggi1915 - 19191941 - 19431992 - presente Nazione Italia Italia Servizio Regio esercito Esercito Italiano TipoArtiglieria RuoloTruppe da montagna Guarnigione/QGFossano (CN) EquipaggiamentoArmato di obici a traino meccanico MottoNulla via invia Decorazioni Parte di Brigata alpina Taurinense Reparti dipendenti Comando di reggimento, Batteri...

 

Hermes adalah spaceplane diusulkan dirancang oleh French Centre National d'Études Spatiales (CNES) pada tahun 1975, dan kemudian oleh European Space Agency. Itu terlihat serupa dengan US X-20. France mengusulkan pada bulan Januari 1985 melalui dengan pembangunan Hermes bawah naungan ESA. Hermes menjadi bagian dari program luar angkasa berawak penerbangan. Ini telah diluncurkan menggunakan Ariane 5. Proyek ini disetujui pada November 1987, dengan tahap pra-pengembangan awal 1988-1990, dengan...

 

SMA Negeri 1 GentengSmansa gentengInformasiDidirikan27 Juli 1971JenisNegeriAkreditasiA ( sangat baik)Nomor Pokok Sekolah Nasional20525854Kepala SekolahSuprijanto, S.Pd [1]Jumlah kelas12 kelas setiap tingkatJurusan atau peminatanMatematika dan lmu Pengetahuan Alam (MIPA) dan Ilmu Pengetahuan Sosial (IPS)Rentang kelasX, XI MIPA, XI IPS, XII MIPA, XII IPS, XII SCIKurikulumKurikulum 2013 , SKS , Kurikulum MerdekaStatusSekolah Standar NasionalAlamatLokasiJalan K.H. Wahid Hasyim n...

豪栄道 豪太郎 場所入りする豪栄道基礎情報四股名 澤井 豪太郎→豪栄道 豪太郎本名 澤井 豪太郎愛称 ゴウタロウ、豪ちゃん、GAD[1][2]生年月日 (1986-04-06) 1986年4月6日(38歳)出身 大阪府寝屋川市身長 183cm体重 160kgBMI 47.26所属部屋 境川部屋得意技 右四つ・出し投げ・切り返し・外掛け・首投げ・右下手投げ成績現在の番付 引退最高位 東大関生涯戦歴 696勝493敗...

 

زغاوةملف:اللغة الاساسية هي لغة زغاوةملف:اللغة الاساسية هي لغة زغاوةالعلمالتعداد الكليالتعداد 400,000مناطق الوجود المميزةالبلد تشاد[1]ليبيا[1]النيجرالسودان السودان وتشاد وليبيا السودان وتشاد وليبيااللغات لغة الزغاوة أساسية والعربية فرعيةالدين إسلام سنيتعديل - تعد�...

 

Рублёвая зона Члены рублёвой зоны в нумерации: АзербайджанАрменияБелоруссияГрузияКазахстанКиргизияЛатвияЛитваМолдавияРоссияТаджикистанТуркменистанУзбекистанУкраинаЭстония Членство бывших республик СССР Тип организации Валютный союз Основание Существование 1991...

Strong negative feeling towards a person with leprosy Part of a series onDiscrimination Forms Institutional Structural Statistical Taste-based Attributes Age Caste Class Dialect Disability Genetic Hair texture Height Language Looks Mental disorder Race / Ethnicity Skin color Scientific racism Rank Sex Sexual orientation Species Size Viewpoint Social Arophobia Acephobia Adultism Anti-albinism Anti-autism Anti-homelessness Anti-drug addicts Anti-intellectualism Anti-intersex Anti-left ...

 

UFC mixed martial arts event in 2009 UFC 105: Couture vs. VeraThe poster for UFC 105: Couture vs. VeraInformationPromotionUltimate Fighting ChampionshipDate14 November 2009VenueEvening News ArenaCityManchester, United KingdomAttendance16,693[1]Total gate$2,000,000[1]Event chronology UFC 104: Machida vs. Shogun UFC 105: Couture vs. Vera UFC 106: Ortiz vs. Griffin 2 UFC 105: Couture vs. Vera was a mixed martial arts event held by the Ultimate Fighting Championship (UFC) on 14 No...

 

صاحب السمو الملكي الأمير فواز بن سعود بن عبد العزيز آل سعود معلومات شخصية اسم الولادة فواز بن سعود بن عبد العزيز بن عبد الرحمن بن فيصل بن تركي بن عبد الله بن محمد بن سعود الميلاد سنة 1948   الرياض، السعودية الوفاة 2 يوليو 1980 (31–32 سنة)  الطائف، السعودية سبب الوفاة حادث سي�...

朱拉隆功จุฬาลงกรณ์暹罗国王暹罗国王統治1868年10月1日-1910年10月23日(42年22天)加冕1868年11月11日(1868歲—11—11)(15歲)前任蒙固(拉瑪四世)繼任瓦栖拉兀(拉瑪六世)摄政西·索里亚翁(1868–1873)绍瓦帕·蓬西(英语:Saovabha Phongsri)(1897)瓦棲拉兀王储(1907)副王威猜参(1868-1885)王储哇集鲁那希(1886-1895)瓦棲拉兀(1895-1910)出生(1853-09-20)1853年9月20日 暹羅曼...

 

Italian football club Football clubLatinaFull nameLatina Calcio 1932 S.r.l.Founded1932GroundStadio Domenico Francioni,Latina, ItalyCapacity9,398ChairmanAntonio TerraccianoManagerGaetano FontanaLeagueSerie C Group C2023–24Serie C Group C, 10th of 20WebsiteClub website Home colours Away colours Third colours Latina Calcio 1932, commonly referred to as Latina, is an Italian football club based in Latina, Lazio. They currently play in the Serie C Group C. History The club was founded in 1932 as...