* * * *

Privacy Policy

Blog italiano

Clicca qui se vuoi andare al blog italiano su Lazarus e il pascal.

Forum ufficiale

Se non siete riusciti a reperire l'informazione che cercavate nei nostri articoli o sul nostro forum vi consiglio di visitare il
Forum ufficiale di Lazarus in lingua inglese.

Lazarus 1.0

Trascinare un file nel programma
DB concetti fondamentali e ZeosLib
Recuperare codice HTML da pagina web
Mandare mail con Lazarus
Stabilire il sistema operativo
Esempio lista in pascal
File INI
Codice di attivazione
Realizzare programmi multilingua
Lavorare con le directory
Utilizzare Unità esterne
TTreeView
TTreeview e Menu
Generare controlli RUN-TIME
LazReport, PDF ed immagini
Intercettare tasti premuti
Ampliare Lazarus
Lazarus e la crittografia
System Tray con Lazarus
UIB: Unified Interbase
Il file: questo sconosciuto
Conferma di chiusura di un applicazione
Liste e puntatori
Overload di funzioni
Funzioni a parametri variabili
Proprietà
Conversione numerica
TImage su Form e Panel
Indy gestiore server FTP lato Client
PopUpMenu sotto Pulsante (TSpeedButton)
Direttiva $macro
Toolbar
Evidenziare voci TreeView
Visualizzare un file Html esterno
StatusBar - aggirare l'errore variabile duplicata
Da DataSource a Excel
Le permutazioni
Brute force
Indy 10 - Invio email con allegati
La gestione degli errori in Lazarus
Pascal Script
Linux + Zeos + Firebird
Dataset virtuale
Overload di operatori
Lavorare con file in formato JSON con Lazarus
Zeos ... dietro le quinte (prima parte)
Disporre le finestre in un blocco unico (come Delphi)
Aspetto retrò (Cmd Line)
Lazarus 1.0
Come interfacciare periferica twain
Ubuntu - aggiornare free pascal e lazarus
fpcup: installazioni parallele di lazarus e fpc
Free Pascal e Lazarus sul Raspberry Pi
Cifratura: breve guida all'uso dell'algoritmo BlowFish con lazarus e free pascal.
Creare un server multithread
guida all'installazione di fpc trunk da subversion in linux gentoo
Indice
DB concetti fondamentali e connessioni standard
Advanced Record Syntax
DB concetti fondamentali e DBGrid
DB concetti fondamentali e TDBEdit, TDBMemo e TDBText
Advanced Record Syntax: un esempio pratico
Superclasse form base per programmi gestionali (e non)
Superclasse form base per programmi gestionali (e non) #2 - log, exception call stack, application toolbox
Superclasse form base per programmi gestionali (e non) #3 - traduzione delle form
Superclasse form base per programmi gestionali (e non) #4 - wait animation
Un dialog per la connessione al database:TfmSimpleDbConnectionDialog
Installare lazarus su mac osx sierra
immagine docker per lavorare con lazarus e free pascal
TDD o Test-Driven Development
Benvenuto! Effettua l'accesso oppure registrati.
Dicembre 10, 2024, 09:22:42 am

Inserisci il nome utente, la password e la durata della sessione.

106 Visitatori, 1 Utente
 
Il test-driven development (abbreviato in TDD e tradotto con sviluppo guidato dai test) è un modello di sviluppo del software che prevede che la stesura dei test automatici avvenga prima di quella del software che deve essere sottoposto a test, e che lo sviluppo del software applicativo sia orientato esclusivamente all'obiettivo di passare i test automatici precedentemente predisposti.

Più in dettaglio, il TDD prevede la ripetizione di un breve ciclo di sviluppo in tre fasi, detto "ciclo TDD". Nella prima fase (detta "fase rossa"), il programmatore scrive un test automatico per la nuova funzione da sviluppare, che deve fallire in quanto la funzione non è stata ancora realizzata. Nella seconda fase (detta "fase verde"), il programmatore sviluppa la quantità minima di codice necessaria per passare il test. Nella terza fase (detta "fase grigia" o di refactoring), il programmatore esegue il refactoring del codice per adeguarlo a determinati standard di qualità.

Il TDD è una delle 12 regole base dell'XP, ma viene anche usato indipendentemente da questa metodologia; la sua applicazione è anche parte fondamentale dello sviluppo agile del software.

Lazarus ci mette a disposizione dei semplici strumenti per poter adottare il TDD. Per prima cosa dobbiamo installare il package che trovate nella cartella d'installazione di lazarus nella sottodirectory components/fpunit/ide/ di nome fpcunitide.lpk

Premessa: questa metodologia è utile per sviluppare le logiche dei software e non l'interfaccia grafica.

Ora procediamo con un progetto d'esempio per capire come funziona, ipotizziamo di voler reinventare la ruota e di scrivere una libreria matematica che deve fornirmi le funzionalità di somma, differenza, moltiplicazione e divisione di due numeri. Partiamo con la creazione di un nuovo progetto

File -> nuovo ... -> Progetto -> Applicazione di test FPCUnit

Inserisci nome del test di default: TTestCase_Math

Checchiamo su "Crea metodo di setup" e su "Crea metodo TearDown"

Procediamo, si aprirà una finestra con del codice

Codice: [Seleziona]

unit TestCase1;

{$mode objfpc}{$H+}

interface

uses
  Classes, SysUtils, fpcunit, testutils, testregistry;

type

  { TTestCase_Math }

  TTestCase_Math= class(TTestCase)
  protected
    procedure SetUp; override;
    procedure TearDown; override;
  published
    procedure TestHookUp;
  end;

implementation

procedure TTestCase_Math.TestHookUp;
begin
  Fail('Scrivi il tuo test');
end;

procedure TTestCase_Math.SetUp;
begin

end;

procedure TTestCase_Math.TearDown;
begin

end;

initialization

  RegisterTest(TTestCase_Math);
end.



Ora procediamo con la fase rossa, aggiungendo del codice a questa unit trasformandola in

Codice: [Seleziona]

unit TestCase1;

{$mode objfpc}{$H+}

interface

uses
  Classes, SysUtils, fpcunit, testutils, testregistry;

type

  { TTestCase_Math }

  TTestCase_Math= class(TTestCase)
  protected
    procedure SetUp; override;
    procedure TearDown; override;
  published
    procedure TestHookUp;
    procedure TestSum();
    procedure TestDifference();
    procedure TestMultiply();
    procedure TestDivide();
  end;

implementation

procedure TTestCase_Math.TestHookUp;
begin
  Fail('Scrivi il tuo test');
end;

procedure TTestCase_Math.TestSum();
begin
     CheckEquals(5, 6,'Sum incorrect');
end;

procedure TTestCase_Math.TestDifference();
begin
     CheckEquals(3, 4,'Difference incorrect');
end;

procedure TTestCase_Math.TestMultiply();
begin
     CheckEquals(8, 6,'Multiply incorrect');
end;

procedure TTestCase_Math.TestDivide();
begin
     CheckEquals(2, 3,'Difference incorrect');
end;

procedure TTestCase_Math.SetUp;
begin

end;

procedure TTestCase_Math.TearDown;
begin

end;

initialization

  RegisterTest(TTestCase_Math);
end.



Ora se compilate il software dovrebbe comparire una schermata con la lista dei test da eseguire (ovvero tutte le procedure presenti nel ramo published della classe) e due pulsanti in alto a sinistra con cui potete eseguire tutti i test o quello selezionato. Se premete sul pulsante che esegue tutti i test vedrete il risultato del vostro lavoro fino ad adesso. Bene, una volta definiti i test da superare passiamo alla unit (di nome uMath) che è il cuore del nostro ragionamento, che sarà scritta come segue

Codice: [Seleziona]

unit uMath;

{$mode objfpc}{$H+}

interface

uses
  Classes, SysUtils;

type

    { TMath }

    TMath = class

    private

    public

          constructor Create;
          destructor Free;
          function Sum(a : integer; b : integer) : integer;
          function Difference(a : integer; b : integer) : integer;
          function Multiply(a : integer; b : integer) : integer;
          function Divide(a : integer; b : integer) : single;
    end;

implementation

{ TMath }

constructor TMath.Create;
begin

end;

destructor TMath.Free;
begin

end;

function TMath.Sum(a: integer; b: integer): integer;
begin
     result := a + b;
end;

function TMath.Difference(a: integer; b: integer): integer;
begin
     result := a - b;
end;

function TMath.Multiply(a: integer; b: integer): integer;
begin
     result := a * b;
end;

function TMath.Divide(a: integer; b: integer): single;
begin
     result := a / b;
end;

end.


Come si può dedurre questa unit è di per se molto semplice e non necessiterà della fase grigia, ma raramente ciò accade nella realtà.
Procediamo quindi con la fase verde del nostro progetto, andando a modifica la unit TestCase1 come segue

Codice: [Seleziona]

unit TestCase1;

{$mode objfpc}{$H+}

interface

uses
  Classes, SysUtils, fpcunit, testutils, testregistry, uMath;

type

  { TTestCase_Math }

  TTestCase_Math= class(TTestCase)
  protected
    procedure SetUp; override;
    procedure TearDown; override;
  published
    procedure TestHookUp;
    procedure TestSum();
    procedure TestDifference();
    procedure TestMultiply();
    procedure TestDivide();
  end;

implementation

procedure TTestCase_Math.TestHookUp;
begin
  Fail('Scrivi il tuo test');
end;

procedure TTestCase_Math.TestSum();
var
   app : TMath;
begin
     app := TMath.Create;

     CheckEquals(5, app.Sum(4, 1),'Sum incorrect');

     app.Free;
     app := nil;
end;

procedure TTestCase_Math.TestDifference();
var
   app : TMath;
begin
     app := TMath.Create;

     CheckEquals(3, app.Difference(4, 1),'Difference incorrect');

     app.Free;
     app := nil;
end;

procedure TTestCase_Math.TestMultiply();
var
   app : TMath;
begin
     app := TMath.Create;

     CheckEquals(8, app.Multiply(4, 2),'Multiply incorrect');

     app.Free;
     app := nil;
end;

procedure TTestCase_Math.TestDivide();
var
   app : TMath;
begin
     app := TMath.Create;

     CheckEquals(2, app.Divide(4, 2),'Divide incorrect');

     app.Free;
     app := nil;
end;

procedure TTestCase_Math.SetUp;
begin

end;

procedure TTestCase_Math.TearDown;
begin

end;

initialization

  RegisterTest(TTestCase_Math);
end.


Se ora eseguite tutti i test noterete che tutte le procedure ad eccezione di TestHookUp superano il test.


Per maggiori info fare riferimento al seguente link: https://wiki.freepascal.org/fpcunit

Share on Twitter! Digg this story! Del.icio.us Share on Facebook! Technorati Reddit StumbleUpon

Articles in « Lazarus 1.0 »

Comments *

Commenting option has been turned off for this article.

Recenti

How To

Utenti
  • Utenti in totale: 802
  • Latest: maXim.FI
Stats
  • Post in totale: 19252
  • Topic in totale: 2297
  • Online Today: 112
  • Online Ever: 900
  • (Gennaio 21, 2020, 08:17:49 pm)
Utenti Online
Users: 1
Guests: 106
Total: 107

Disclaimer:

Questo blog non rappresenta una testata giornalistica poiché viene aggiornato senza alcuna periodicità. Non può pertanto considerarsi un prodotto editoriale ai sensi della legge n. 62/2001.