Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Proposta prima bozza capitolo testing #145

Merged
merged 36 commits into from
Dec 23, 2023
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
444377e
feat: proposta prima bozza capitolo testing
Cadienvan Oct 6, 2023
7d8af9c
feat: proposta seconda bozza capitolo testing
Cadienvan Oct 6, 2023
a3a49c5
chore: linting
Cadienvan Oct 6, 2023
e6e0b96
chore: aggiunta test coverage + un paio di modifiche provenienti da r…
Cadienvan Oct 7, 2023
ef33611
chore: linting
Cadienvan Oct 7, 2023
62a22e2
Merge branch 'main' into issue-96-Proposta_argomento_Testing
Cadienvan Oct 7, 2023
62e272d
Update docs/testing/README.md
Cadienvan Oct 31, 2023
2149e51
Update docs/testing/README.md
Cadienvan Nov 2, 2023
77434f6
PR a Proposta prima bozza capitolo testing (#164)
frnmjn Nov 9, 2023
eed19d9
Issue 96 proposta argomento testing ejf (#171)
frnmjn Nov 11, 2023
2414f72
Aggiunta linee guida in CONTRIBUTING.md (#148)
Cadienvan Oct 12, 2023
e67847a
Creazione FUNDING.yml (#154)
Cadienvan Oct 26, 2023
2945a55
Aggiunge il capitolo Introduzione all'indice del libro (#149)
nicolaerario Oct 31, 2023
0c4d2d7
Rimuove il titolo del libro da Introduzione (#161)
nicolaerario Oct 31, 2023
d2ad3ae
Aggiunge capitolo Cosa significa essere dev (#111)
guizzo Nov 2, 2023
cc1b988
Aggiunge all'indice il capitolo Cosa significa essere dev (#163)
guizzo Nov 2, 2023
24b3cb2
Aggiunta del titolo al capitolo "cosa significa essere dev" (#165)
Cadienvan Nov 3, 2023
5fc4e66
Adattamento nomine Ambassador (#166)
Cadienvan Nov 4, 2023
76f3961
Aggiunta approvazione contenuti ambassador (#167)
Cadienvan Nov 4, 2023
62c3df0
Aggiunta licenza del progetto (#160)
guizzo Nov 4, 2023
dceb9b7
chore: rinominato file testing
Cadienvan Nov 11, 2023
c93ffb5
chore: linting
Cadienvan Nov 11, 2023
83dc4d4
Merge branch 'main' into issue-96-Proposta_argomento_Testing
Cadienvan Nov 11, 2023
37206ec
feat: piccole correzioni per rispettare le guidelines (#96)
sensorario Nov 19, 2023
698e47a
chore: aggiunta nota sul ping pong tdd nel punto corretto
Cadienvan Nov 29, 2023
192e12f
chore: lint
Cadienvan Nov 29, 2023
6c12604
Merge branch 'main' into issue-96-Proposta_argomento_Testing
Cadienvan Nov 29, 2023
ec9018d
chore: corretto typo
Cadienvan Dec 1, 2023
828df74
chore: review
Cadienvan Dec 5, 2023
bf05572
chore: aggiunti riferimenti a golden e contract testing
Cadienvan Dec 5, 2023
7b1fecc
chore: rivista la forma di alcune parti + continuous integration + ov…
Cadienvan Dec 16, 2023
35f8d67
chore: linting
Cadienvan Dec 16, 2023
fce9323
chore: inseriti suggerimenti di sistella
Cadienvan Dec 19, 2023
2bf1e4e
chore: suggerimento TDD
Cadienvan Dec 19, 2023
66bffdc
chore: applicata revisione
Cadienvan Dec 23, 2023
a46ce73
fix: utilizzo di .gitattribute per utilizzare sempre newline unix lik…
Livio74 Dec 11, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
121 changes: 121 additions & 0 deletions docs/testing/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
# Testing
frnmjn marked this conversation as resolved.
Show resolved Hide resolved

Cadienvan marked this conversation as resolved.
Show resolved Hide resolved
Il testing è una parte fondamentale di ogni progetto software. In questo capitolo vedremo come testare il nostro codice in modo efficace.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved

## Piramide del testing

Esistono diversi tipi di test, ognuno con un suo scopo ben preciso.

Si fa spesso riferimento alla piramide del testing, che rappresenta la proporzione tra i diversi tipi di test:
<img src="./piramide.png" alt="Piramide del testing"/>

Di seguito vedremo nel dettaglio i diversi tipi di test.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved

### Unit test

Il test unitario è un processo di sviluppo software in cui le parti testabili più piccole di un'applicazione, denominate unità, vengono esaminate individualmente per verificarne il corretto funzionamento. Chi sviluppa e talvolta il personale del controllo qualità completano i test unitari durante il processo di sviluppo. Per unità solitamente si intende una funzione o una piccola serie di funzioni i cui comportamenti sono strettamente legati.

Il punto principale è la presenza di un contesto isolato con un obiettivo.

Non dovrebbe avere dipendenze, se presenti queste dovrebbero essere messe sotto mock quando possibile.

Coverage: Solitamente gli unit test permettono di raggiungere alti livelli di code coverage proprio per via della loro granularità.

Solitamente i problemi nati negli unit test sono più facili da correggere perché riguardano piccole porzioni di codice e molti test sono riutilizzabili anche in altri progetti se si usa codice condiviso.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved

D'altro canto, se i test sono scritti male o non hanno una buona coverage, danno falsa sicurezza e non prevengono i bug, inoltre impiegano tanto tempo ad essere scritti.

### Integration test

Il test di integrazione è una tecnica di test del software che si concentra sul test delle interazioni e dell'integrazione tra più componenti o moduli di un sistema software. Ha lo scopo di verificare che i diversi componenti, quando combinati, funzionino correttamente e producano i risultati attesi.

Concetti principali:

- **Scope**: Anche qui parliamo di contesto e obiettivi specifici.
- **Stubs**: Sostituti di moduli e dipendenze necessari al funzionamento dei test.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved
- **Spettro più ampio**: A differenza dello unit test che verifica un modulo / una funzione / un contesto specifico e ridotto, l’integration testing integra più moduli e ne testa le interdipendenze e la comunicazione.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved

Tipologie di test:

- **Big-bang**: Si creano decine, centinaia, migliaia di test in base alla dimensione della codebase. Si testa tutto, tutto assieme. Solitamente il tutto viene fatto in un singolo integration test, o in pochissimi. Funziona per codebase ridotte.
frnmjn marked this conversation as resolved.
Show resolved Hide resolved
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved
- **Top-down testing**: Approccio incrementale, si parte dai moduli ad altissimo livello (Controller nel caso di un MVC) e si scende al livello più basso (Se si utilizzano i fat model si arriva anche fino a lì). Funziona per codebase grosse, iniziare è più tosta ma ha più impatto, pian piano diventa sempre più facile perché le parti "sopra" sono già state testate.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved
- **Bottom-up testing**: Approccio incrementale al contrario. Si parte da sotto e si va in alto. Anche qui parliamo di grosse codebase, iniziare è più facile ma ha meno impatto, proseguendo anche qui diventa sempre più facile perché l’impalcatura sotto funziona.
- **Sandwich** o **Hybrid Testing**: Combinazione dei due approcci sopra basati su un planning di priorità.

Quando si lavora in team più o meno grandi non sempre ci si può assicurare che quanto sviluppato da una parte del team comunichi correttamente con quanto sviluppato da un’altra parte del team, questi test sono fondamentali in questi contesti, inoltre è facile individuare e correggere il comportamento di una specifica funzione (Tramite unit test o tramite semplice attenzione quando si sviluppa), più difficile è notare eventuali differenze nel modo in cui i componenti di un’applicazione interagiscono tra di loro. I test di integrazione sono OTTIMI per garantire questa sicurezza.
Infine, l’integrazione tra componenti non è solo da intendersi come "corretta comunicazione e scambio di informazioni tra le parti" ma anche "corretta gestione degli errori". In definitiva, se so che quei due componenti funzionano assieme e ho scritto correttamente i test dormo sonni tranquilli.

D'altro canto è complesso realizzare dei test di integrazione e mantenerli nel tempo per via dell’evoluzione naturale del software su cui si lavora.

Rispetto agli unit test, infatti, è più complicato trovare gli errori essendo più ad ampio spettro.

Molto complesso individuare tutte le integrazioni che ha senso testare. La coverage al 100% è infatti inverosimile in progetti grossi.
Spesso realizzare questi test è più complesso perché bisogna prima avere idea della codebase sottostante, a prescindere che si lavori in TDD o meno.

### End-to-end test

Il test end-to-end (E2E) è una metodologia di test del software che si concentra sul test dell'intero sistema software dall'inizio alla fine, simulando scenari del mondo reale e interazioni dell'utente. Ha lo scopo di garantire che il sistema funzioni correttamente nel suo insieme e soddisfi i requisiti aziendali desiderati.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved

E qui sta il punto. I requisiti sono essenzialmente aziendali e non tecnici.

Nei test E2E, l'intera applicazione o sistema viene testato in un modo che imita il modo in cui verrebbe utilizzato dagli utenti finali. Implica la simulazione delle interazioni dell'utente, l'inserimento dei dati e la convalida degli output previsti su più componenti, moduli e livelli del sistema.

Anche qui parliamo di contesto e obiettivi, ma chiaramente non sono più “specifici” di per se, perché testate “specificatamente” un flusso di pagamento coinvolge centinaia di parti. Inoltre, vista la complessità di realizzare questi test, solitamente si usano strumenti che perlomeno automatizzino alcune parti del processo, come un live recording via estensione del browser.

A differenza degli altri tipi di test, qui possiamo verificare se l’esigenza non funzionale, e quindi di business, sia rispecchiata nel comportamento della piattaforma.

Infine, a differenza degli altri tipi di test trattati, qui vediamo all’atto pratico come i dati agiscono a 360 gradi.

Ricreando scenari realistici, abbiamo modo di avere una sicurezza “definitiva” (tra molte virgolette) del comportamento della piattaforma.

D'altro canto, è difficile prevedere e analizzare quante farne e cosa testare. Inoltre il test è più lungo da scrivere perché mentre per un integration test basta cambiare un flag, un e2e deve probabilmente essere riscritto perché ha flussi differenti per giungere alla stessa conclusione.

## Tipologie di test

Esistono diverse tipologie di test, ognuna con un suo scopo ben preciso. Vediamole brevemente:

- **Functional testing**: Il test funzionale è un tipo di test in cui il target sono le specifiche funzionali. Il sistema viene infatti testato rispetto ai requisiti funzionali, garantendo che questi siano adeguatamente soddisfatti dall'applicazione.
- **Performance testing**: Il test di performance è un tipo di test in cui il target è la performance del sistema. Il sistema viene infatti testato rispetto ai requisiti di performance, garantendo che questi siano adeguatamente soddisfatti dall'applicazione.
- **Usability testing**: Il test di usabilità è un tipo di test in cui il target è l'usabilità del sistema. Il sistema viene infatti testato rispetto ai requisiti di usabilità, garantendo che questi siano adeguatamente soddisfatti dall'applicazione.
- **Security testing**: Il test di sicurezza è un tipo di test in cui il target è la sicurezza del sistema. Il sistema viene infatti testato rispetto ai requisiti di sicurezza, garantendo che questi siano adeguatamente soddisfatti dall'applicazione.
- **Regression testing**: Il test di regressione è un tipo di test in cui il target è la regressione del sistema. Il sistema viene infatti testato rispetto ai requisiti di regressione, garantendo che questi siano adeguatamente soddisfatti dall'applicazione.

Esistono molte altre tipologie di test, come _compatibility testing_, _acceptance testing_, _exploratory testing_, ma queste sono le più comuni.

## Tecniche di test

Esistono tre tecniche di test, ognuna con un suo scopo ben preciso. Vediamole brevemente:

- **Black-box testing**: Il test _black-box_ è una tecnica di test in cui il tester non ha conoscenza dell'implementazione del sistema.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved
- **White-box testing**: Il test _white-box_ è una tecnica di test in cui il tester ha conoscenza dell'implementazione del sistema.
- **Grey-box testing**: Il test _grey-box_ è una tecnica di test in cui il tester ha conoscenza parziale dell'implementazione del sistema.

Di solito queste tre tecniche vengono utilizzate per individuare eventuali falle nel sistema. Solitamente il _Black-box testing_ è la tecnica più utilizzata, in quanto permette di individuare falle che non sono state individuate durante lo sviluppo e non richiede una conoscenza pregressa del sistema.

## Metodologie di testing

### Manual testing

Il manual testing è una metodologia di testing in cui i test vengono eseguiti manualmente dalla figura del tester. Questo approccio ha diversi svantaggi e solitamente viene utilizzato solo per testare le funzionalità più critiche del sistema quando non è possibile automatizzare i test. Questa metodologia viene chiamata anche _explorative testing_, tramite la quale si prova a rompere l'applicazione creando scenari difficilmente automatizzabili e scrivendo di conseguenza i test.

### Automated testing

L'automated testing è una metodologia di testing in cui i test vengono eseguiti automaticamente da un software. Questo approccio ha diversi vantaggi: **Ripetibilità**, **Riduzione dei costi**, **Riduzione dei tempi di sviluppo**.

### Continuous testing
frnmjn marked this conversation as resolved.
Show resolved Hide resolved

Il continuous testing è una metodologia di testing in cui i test vengono eseguiti automaticamente ad ogni commit o ad ogni modifica del codice sorgente.

### Test-driven development

Il test-driven development (TDD) è una metodologia di sviluppo software che prevede di scrivere i test prima di scrivere il codice.
Cadienvan marked this conversation as resolved.
Show resolved Hide resolved

### Behavior-driven development

Il behavior-driven development (BDD) è una metodologia di sviluppo software che prevede di scrivere i test prima di scrivere il codice, ma con un approccio più orientato al comportamento dell'applicazione.
frnmjn marked this conversation as resolved.
Show resolved Hide resolved

## Test Coverage

La test coverage è una metrica che indica la percentuale di codice sorgente che viene eseguita (_coperta_) durante l'esecuzione dei test. Questa metrica è molto importante, in quanto permette di capire quanto il codice sorgente è stato testato. Solitamente si cerca di raggiungere una test coverage del 100%, ma questo non è sempre possibile. Inoltre, una test coverage del 100% non garantisce che il codice sorgente sia privo di bug, esattamente come una coverage del 50% non garantisce che il codice sorgente sia pieno di bug. Come in moltissimi altri aspetti della programmazione, la parola _dipende_ assume un significato molto importante.

**La test coverage ci dice quanto del nostro codice si comporta come ci aspettiamo, ma non è detto che ciò che ci aspettiamo sia corretto.**
Binary file added docs/testing/piramide.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.