|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
[TASK 8.1.2] Pair Programming: Cdimauro vs Bonfo
Task 8.1.2:
Evidenziare la gemma pivot di un GemsPair facendola pulsare. La pulsazione deve terminare una volta che la coppia si spezza, cioè quando una delle due gemme collide. E' la mia prima test list: siate buoni. ![]() ![]() 1) testare che GemsPair non deve pulsare se è costituita da 0 gemme 2) testare che GemsPair non deve pulsare se è costituita da 1 gemma pivot 3) testare che GemsPair non deve pulsare se è costituita da 1 gemma slave 4) testare che GemsPair sia costituita da 2 gemme, 1 pivot e 1 slave Nel caso 4: 5) testare che GemsPair non deve pulsare se la gemma pivot è ferma, ovvero non sta cadendo 6) testare che GemsPair non deve pulsare se la gemma slave è ferma, ovvero non sta cadendo 7) testare che se entrambe le gemme di GemsPair stiano cadendo possa pulsare |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Ed ecco che (finalmente) arriva il primo test:
Codice:
package it.diamonds.tests; public class TestGemsPairPulsation extends TestGemsPairBase { protected void setUp() { super.setUp(); } public void testNoPivotAndNoSlaveGems() { getPairFromController().setNoPivotGem(); getPairFromController().setNoSlaveGem(); assertFalse( "Pivot and slave gems are set-up", getPairFromController().isPulsing()); } }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#3 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Ed ecco il mio codice....prima volta
Codice:
public boolean isPulsing() { return false; } Ultima modifica di Bonfo : 16-01-2006 alle 20:59. |
![]() |
![]() |
![]() |
#4 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Ecco il codice del secondo test:
Codice:
public void testNoSlaveGem() { getPairFromController().setNoSlaveGem(); assertFalse( "Slave gem was set-up", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Qui Bonfo si è accorto che il test passa lo stesso senza cambiare il codice. Il che ci ha fatto insospettire sull'utilità di qualche test.
Più precisamente, è venuto fuori che sono sufficienti i test 2 e 3 per garantire che isPulsing faccia il suo lavoro soltanto se entrambe le gemme sono presenti in gemsPair. Quindi procedo a scrivere il test3: Codice:
public void testNoPivotGem() { getPairFromController().setNoPivotGem(); assertFalse( "Pivot gem was set-up", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Anche così il test passa senza alcuna modifica. Quindi è chiaro che la nostra test base va ripensata. Buttiamo tutto il codice e torniamo all'origine.
Il task dice che la gemma pivot di gemspair deve pulsare fino a quando la coppia non si spezza. Quindi testiamo per prima il caso che pulsi quando la coppia è unita: Codice:
public void testWithPivotAndSlaveGems() { assertTrue( "Pivot and slave gems aren't set-up", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#7 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Dualmente a prima, ecco il codice minimo:
Codice:
public boolean isPulsing() { return true; } Prossimo test |
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Riprendiamo il test2:
Codice:
public void testNoSlaveGem() { getPairFromController().setNoSlaveGem(); assertFalse( "Slave gem was set-up", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#9 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Modifica al metodo isPulsing()
Codice:
public boolean isPulsing() { if(getSlaveGem()==null) { return false; } return true; } Sotto il prossimo... |
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Riprendiamo anche il test3:
Codice:
public void testNoPivotGem() { getPairFromController().setNoPivotGem(); assertFalse( "Pivot gem was set-up", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#11 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Seconda modifica al metodo isPulsing()
Codice:
public boolean isPulsing() { if(getSlaveGem()==null || getPivotGem()==null) { return false; } return true; } |
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Dobbiamo testare che se la gemma pivot non sta cadendo, non deve nemmeno pulsare:
Codice:
public void testPivotIsNotFalling() { getGridController().setDelay(300); getGridFromController().insertGem(2, 4, Gem.diamond(3500)); getGridController().update(getTimer()); assertFalse( "Pivot gem was falling down", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#13 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Ulteriore modifica la metodo isPulsing() più un piccolo refactoring
Codice:
public boolean isPulsing() { return getPivotGem()!=null && getSlaveGem()!=null && getPivotGem().isFalling(); } E via col prossimo ![]() |
![]() |
![]() |
![]() |
#14 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Ecco il codice per testare che se anche la gemma slave non sta cadendo, quella pivot non deve pulsare:
Codice:
public void testSlaveIsNotFalling() { getGridController().setDelay(300); Gem gem = Gem.diamond(3500); getGridFromController().insertGem(1, 3, gem); getPairFromController().setPivotGem(gem); getGridFromController().insertGem(2, 3, Gem.diamond(3500)); getGridController().update(getTimer()); assertFalse( "Pivot gem was falling down", getPairFromController().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys Ultima modifica di cdimauro : 16-01-2006 alle 23:07. |
![]() |
![]() |
![]() |
#15 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Ennesima modifica a isPulsing()
Codice:
public boolean isPulsing() { return getPivotGem()!=null && getSlaveGem()!=null && getPivotGem().isFalling() && getSlaveGem().isFalling(); } |
![]() |
![]() |
![]() |
#16 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
L'ultimo test che rimane è inutile, perché i test precedenti ci garantiscono che gemsPair deve avere per forza pivot e slave, e che entrambi debbano cadere.
Non rimane che implementare il codice per far pulsare la gemma Pivot.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#17 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Bene...rieccoci qua.
Cdimauro non può testare perchè ha ant che non funziona. Sta seguendo passso passo con me. Stiamo modificando Gem perchè esponga i metodi per la pulsazione. Ecco i test: Codice:
private Gem createGem() { return Gem.diamond(3500); } public void testStartPulsing() { Gem gem=createGem(); gem.startPulsing(); assertTrue(gem.isPulsing()); } public void testStopPulsing() { Gem gem=createGem(); gem.startPulsing(); assertTrue(gem.isPulsing()); gem.stopPulsing(); assertFalse(gem.isPulsing()); } |
![]() |
![]() |
![]() |
#18 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Ed ecco il codice per passare i test
Codice:
public void startPulsing() { sprite.setSizeMultiplier(4); sprite.setSpeedDivisor(10); sprite.startPulsing(); } public void stopPulsing() { sprite.stopPulsing(); } public boolean isPulsing() { return sprite.isPulsing(); } |
![]() |
![]() |
![]() |
#19 |
Senior Member
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
|
Aggiungiamo anche un test per controllare che la gemma pivot pulsi se lo fa gemsPair:
Codice:
public void testPivotGemPulsingWhenGemsPairPulsing() { assertEquals( "Pivot and GemsPair aren't pulsing together", getPairFromController().isPulsing(), getPairFromController().getPivotGem().isPulsing()); }
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro @LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys |
![]() |
![]() |
![]() |
#20 |
Senior Member
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
|
Aggiunto il metodo privato updatePulsingState()
Codice:
private void updatePulsingState() { if(getPivotGem()==null) { return; } if(isPulsing()) { if(!getPivotGem().isPulsing()) { getPivotGem().startPulsing(); } } else { if(getPivotGem().isPulsing()) { getPivotGem().stopPulsing(); } } } - public void setPivotGem(Gem gem) - public void setNoPivotGem() - public void setNoSlaveGem() - public void update(TimerInterface timer) Green |
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:42.