Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-12-2005, 16:07   #1
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
[CICLO 6] Test Driven Development task 6.1.4 (DanieleC88 vs 71104)

come da titolo

la build per ora potrebbe essere precaria, ma cercheremo di lasciarla sempre verde: chi scrive i test non committa, mentre committa solo chi li implementa

dunque, fatemi pensare una test list:
- verificare che Grid si accorga se una gemma sta alla sinistra di una del suo stesso tipo
- verificare bla bla bla destra bla bla bla
- verificare bla bla sopra
- verificare sotto
- verificare che Grid illumini la gemma se si accorge che sopra, sotto, a destra o a sinistra c'è una gemma dello stesso tipo

Ultima modifica di 71104 : 04-12-2005 alle 16:24.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 16:11   #2
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
bla bla bla destra bla bla bla? come sei esplicativo...
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 16:12   #3
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Dimenticavo: ovviamente vanno testate anche le condizioni in cui la gemma NON deve essere illuminata.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 16:21   #4
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
giusto, quindi la test list diventerebbe così:

- verificare che Grid si accorga se una gemma sta alla sinistra di un'altra dello stesso tipo
- verificare a destra
- verificare sopra
- verificare sotto
- verificare che Grid si accorga quando una gemma non sta a destra, sinistra, sopra o sotto una dello stesso tipo (sempre test separati: infatti mi sa che è meglio metterli in una classe apposta perché sono tanti)
- verificare che quando una gemma sta accanto ad almeno una dello stesso tipo si illumini
- verificare che questo non accada se una gemma non sta accanto a nessuna dello stesso tipo

ecco il primo test:
Codice:
    public void testSameAsLeft()
    {
        grid.insertGem(5, 3, gem1);
        grid.insertGem(5, 4, gem2);
        assertTrue(grid.sameAsLeft(gem2));
    }
si trova in TestGrid ma è meglio che lo sposto in una nuova classe TestGemBrightnessInGrid.

Ultima modifica di 71104 : 04-12-2005 alle 16:53.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 16:40   #5
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
primo commit, perfetto; Daniele ha risolto questo test col seguente codice (un po' modificato da me per far felice Ant e per correggere un erroretto minimo ^^):
Codice:
    public boolean gemIsSameAsLeft(Gem gem)
    {
        int column = gem.getCellColumn();
        int row = gem.getCellRow();
        
        if(column < 1)
        {
            return false;
        }
        
        if(getGemAt(row, column).getName().equals(getGemAt(row, column - 1).getName()))
        {
            return true;
        }
        
        return false;
    }
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 16:52   #6
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, allora, ho fatto una nuova classe TestGemBrightnessInGrid e spostato il mio test in quest'ultima:
Codice:
public class TestGemBrightnessInGrid extends TestCase
{
    private Grid grid;
    
    private Gem gem1;
    private Gem gem2;
    
    
    public void setUp()
    {
        grid = Grid.createForTesting();
        
        gem1 = new Gem("diamond");
        gem2 = new Gem("diamond");
        
    }
    
    
    public void testSameAsLeft()
    {
        grid.insertGem(5, 3, gem1);
        grid.insertGem(5, 4, gem2);
        assertTrue(grid.gemIsSameAsLeft(gem2));
    }
    
}
nel metodo setUp non ho usato Gem.createForTesting perché ho preferito esplicitare il tipo di gemma nella creazione; infatti tra poco quando faremo i test opposti dovremo anche creare una terza Gem nbella classe di test che dovrà essere di tipo diverso
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 16:56   #7
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Benissimo, ora non ci resta che testare anche gli altri lati, ci vorrà poco.
Codice:
    public void testSameAsRight()
    {
        grid.insertGem(5, 3, gem1);
        grid.insertGem(5, 4, gem2);
        assertTrue(grid.gemIsSameAsRight(gem1));
    }


    public void testSameAsTop()
    {
        grid.insertGem(5, 4, gem1);
        grid.insertGem(6, 4, gem2);
        assertTrue(grid.gemIsSameAsTop(gem2));
    }


    public void testSameAsBottom()
    {
        grid.insertGem(5, 4, gem1);
        grid.insertGem(6, 4, gem2);
        assertTrue(grid.gemIsSameAsBottom(gem1));
    }
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!

Ultima modifica di DanieleC88 : 05-12-2005 alle 13:41.
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 17:14   #8
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
et voilà:
Codice:
    public boolean gemIsSameAsRight(Gem gem)
    {
        int column = gem.getCellColumn();
        int row = gem.getCellRow();
        
        if(column >= grid[0].length)
        {
            return false;
        }
        
        if(getGemAt(row, column).getName().equals(getGemAt(row, column + 1).getName()))
        {
            return true;
        }
        
        return false;
    }

    public boolean gemIsSameAsDown(Gem gem)
    {
        int column = gem.getCellColumn();
        int row = gem.getCellRow();
        
        if(row > grid.length)
        {
            return false;
        }
        
        if(getGemAt(row, column).getName().equals(getGemAt(row + 1, column).getName()))
        {
            return true;
        }
        
        return false;
    }

    public boolean gemIsSameAsUp(Gem gem)
    {
        int column = gem.getCellColumn();
        int row = gem.getCellRow();
        
        if(row < 1)
        {
            return false;
        }
        
        if(getGemAt(row, column).getName().equals(getGemAt(row - 1, column).getName()))
        {
            return true;
        }
        
        return false;
    }
a questo punto uno pensa che stiamo già a metà del task e invece MANCOPENNIENTE!!!
carissimo Daniele, prima di continuare seguendo la test list ti sottopongo questo problema:
Codice:
    public void testAffinityCheckWithEmtpyCell()
    {
        grid.insertGem(5, 5, gem1);
        assertFalse(grid.gemIsSameAsLeft(gem1));
    }
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 17:15   #9
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
a proposito, sarebbe bene anche riflettere su qualche modo per eliminare quella mostruosa quadruplicazione di codice, ma si tratta di un refactoring e ci penseremo a fine task.

EDIT: anzi, è talmente semplice che ci ho già pensato
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 17:44   #10
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Per la quadruplicazione di codice non credo ci voglia molto... per il problema delle caselle vuote, be', cosa dire? Il problema è grande ma la soluzione è piccola. Un banalissimo 'if'.

Codice:
    public boolean gemIsSameAsLeft(Gem gem)
    {
        int column = gem.getCellColumn();
        int row = gem.getCellRow();

        if(column < 1)
        {
            return false;
        }

        if(getGemAt(row, column - 1) != null)
        {
            if(getGemAt(row, column).getName().equals(
                getGemAt(row, column - 1).getName()))
            {
                return true;
            }
        }
        return false;
    }
E così anche per gli altri.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!

Ultima modifica di DanieleC88 : 05-12-2005 alle 13:42.
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 18:00   #11
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
hmmm puoi ancora eliminare un return
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 18:02   #12
cover
Senior Member
 
L'Avatar di cover
 
Iscritto dal: May 2002
Città: Milan
Messaggi: 572
Raga, mettete i test sotto it.diamonds.tests.ignore, almeno non ci sono problemi con la build....e fek non si arrabbia
__________________
.:. NEONISI .:. a new island for online auctions. It's worldwide, safe, simple and free. Join Us!
cover è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 18:07   #13
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
allora, DanieleC88 si è dovuto disconnettere percui il task dovrò essere completato domani; ho eliminato la quadruplicazione sperando (come suggerito da VICIUS) in un miracoloso fix ma Spartacus mi ha detto sorry, oggi niente miracoli
ora provo ad aggiustare la build; nel frattempo ecco il codice dei 4 metodi riassunti in un unico metodo:
Codice:
    public boolean gemsAreSame(Gem gem, int xStep, int yStep)
    {
        int column = gem.getCellColumn();
        int row = gem.getCellRow();

        int otherColumn = column + xStep;
        int otherRow = row + yStep;

        if((otherColumn < 0) || (otherColumn >= grid[0].length))
        {
            return false;
        }

        if((otherRow < 1) || (otherRow >= grid.length))
        {
            return false;
        }

        if(getGemAt(otherRow, otherColumn) != null)
        {
            if(gem.getName().equals(getGemAt(otherRow, otherColumn).getName()))
            {
                return true;
            }
        }

        return false;
    }
ed ecco invece come è diventata la classe dei test:
Codice:
public class TestGemBrightnessInGrid extends TestCase
{
    private Grid grid;

    private Gem gem1;

    private Gem gem2;


    public void setUp()
    {
        grid = Grid.createForTesting();

        gem1 = new Gem("diamond");
        gem2 = new Gem("diamond");

    }


    public void testSameAsLeft()
    {
        grid.insertGem(5, 3, gem1);
        grid.insertGem(5, 4, gem2);
        assertTrue(grid.gemsAreSame(gem2, -1, 0));
    }


    public void testSameAsRight()
    {
        grid.insertGem(5, 3, gem1);
        grid.insertGem(5, 4, gem2);
        assertTrue(grid.gemsAreSame(gem1, 1, 0));
    }


    public void testSameAsUp()
    {
        grid.insertGem(5, 4, gem1);
        grid.insertGem(6, 4, gem2);
        assertTrue(grid.gemsAreSame(gem2, 0, -1));
    }


    public void testSameAsDown()
    {
        grid.insertGem(5, 4, gem1);
        grid.insertGem(6, 4, gem2);
        assertTrue(grid.gemsAreSame(gem1, 0, 1));
    }


    public void testAffinityCheckWithEmtpyCell()
    {
        grid.insertGem(5, 5, gem1);
        assertFalse(grid.gemsAreSame(gem1, 1, 0));
        assertFalse(grid.gemsAreSame(gem1, 0, 1));
    }

}
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 18:15   #14
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
magia, si è fixata da sola
tanto meglio

ci vediamo domani per la seconda puntata; byez
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 19:13   #15
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
In questo metodo:

Codice:
    public boolean gemsAroundOfSameType(Gem gem, int column, int row)
    {
        int otherColumn = gem.getCellColumn() + column;
        int otherRow = gem.getCellRow() + row;

        if((otherColumn < 0) || (otherColumn >= grid[0].length))
        {
            return false;
        }

        if((otherRow < 1) || (otherRow >= grid.length))
        {
            return false;
        }

        if(getGemAt(otherRow, otherColumn) != null)
        {
            if(gem.isSameType(getGemAt(otherRow, otherColumn)))
            {
                return true;
            }
        }

        return false;
    }
I primi due branch non sono testati da alcun test. Aggiungete i test relativi ragazzi. E, soprattutto, state scrivendo troppo codice fra un test e l'altro. Fate passi piu' piccoli.

(Ho fatto un po' di refactoring)
fek è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 19:19   #16
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
non è meglio unire le condizioni dei 2 if annidati con un &&?
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 19:42   #17
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
Quote:
Originariamente inviato da Ufo13
non è meglio unire le condizioni dei 2 if annidati con un &&?
In genere preferisco svolgere gli if per chiarezza:

Codice:
    public boolean gemsAroundOfSameType(Gem gem, int column, int row)
    {
        int otherColumn = gem.getCellColumn() + column;
        int otherRow = gem.getCellRow() + row;

        if((otherColumn < 0) || (otherColumn >= grid[0].length))
        {
            return false;
        }

        if((otherRow < 1) || (otherRow >= grid.length))
        {
            return false;
        }

        if(getGemAt(otherRow, otherColumn) == null)
        {
           return false;
        }
        
        if(gem.isSameType(getGemAt(otherRow, otherColumn)))
        {
            return true;
        }

        return false;
    }
fek è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2005, 20:32   #18
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da fek
I primi due branch non sono testati da alcun test. Aggiungete i test relativi ragazzi.
hai ragione, ci sarei arrivato alla fine ^^
dobbiamo aggiungere un test che verifichi che venga lanciata eccezione se vengono passati una riga e una colonna fuori dalla griglia; per ora ritorna false, ma è un comportamento "temporaneo".

Quote:
(Ho fatto un po' di refactoring)
ho visto e concordo
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2005, 13:40   #19
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da Ufo13
non è meglio unire le condizioni dei 2 if annidati con un &&?
Si, si potrebbe, ma in genere credo sia meglio spezzettare il codice per renderlo quanto più leggibile si può.

Colgo l'occasione per scusarmi del casino che ho fato ieri, ma purtroppo andavo di fretta, oggi spero di avere più tempo.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!

Ultima modifica di DanieleC88 : 05-12-2005 alle 13:44.
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2005, 17:51   #20
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da 71104
hai ragione, ci sarei arrivato alla fine ^^
dobbiamo aggiungere un test che verifichi che venga lanciata eccezione se vengono passati una riga e una colonna fuori dalla griglia; per ora ritorna false, ma è un comportamento "temporaneo".
ma cos'ero, fuso ieri??
non deve mica lanciare eccezione: se le coordinate vanno fuori significa semplicemente che la gemma che ho dato come parametro sta sui bordi
per testare gli if basta semplicemente creare dei test che testino il metodo con una gemma messa ai bordi
Daniele, tocca provvedere
71104 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
31,4 Tbps: Aisuru sfonda il suo stesso r...
Giocattoli AI, una falla espone oltre 50...
OPPO Reno15 in viaggio con Gaia Gozzi: i...
Elon Musk valuta il gioco delle tre cart...
Nuove revisioni per Abarth 600e: arrivan...
Intelligenza artificiale, re-training e ...
LG presenta a ISE 2026 la nuova serie di...
Alienware: disponibile in Italia il nuov...
Arrivano le bodycam sui treni di Ferrovi...
Nike taglia 775 posti negli USA: l'autom...
Crimson Desert si mostra in un nuovo gam...
Addio transistor? Questo dispositivo usa...
Jensen Huang: le fabbriche negli Stati U...
Sam Altman ammette l'errore: GPT-5.2 &eg...
Super test al gelo della Norvegia: quant...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 18:12.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v