|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
[TASK 10.2.3] nihil84 Vs. cionci
Oggi pomeriggio facciamo questo task...
Intanto tiro giù una test list approssimativa... 1. quando viene eseguito un handler devo poter recuperare una stringa contenete il nome della classe che viene eseguita seguita da un newline 2. ogni handler che viene eseguito deve "appendere" il proprio nome ad una stringa 3. in caso di evento causato dalla pressione di un tasto deve essere "appesa" una ulteriore stringa con scritto " 1" seguita da newline 4. in caso di evento causato dal rilascio di un tasto deve essere "appesa" una ulteriore stringa con scritto " 0" seguita da newline 5. se premo destra e sinistra insieme non deve essera "appeso" niente alla stringa 6. se la gestione di un evento non produce effetti (rilascio di alcuni tasti) allora non deve essere scritto niente nel file 7. playField deve creare un file nella directory data (il file deve essere rimosso alla fine dell'esecuzione del test) 8. playField al momento dell'apertura del file deve scrivere nel log file la stringa "seed " seguita dal random seed del RandomGenerator 9. playField deve leggere da gridController una stringa contenente la nuova coppia di gemme inserita da gridController in gioco 10. dopo che viene eseguito gridController.reactToInput, playField deve scrivere il numero sul file di log le seguenti informazioni: <---riga vuota #XXXX <----inputServed pair XXXX YYYY<----coppia di gemme generate, se non ci sono linea vuota ZZZZEventHandler 0/1<----stringa recuperata da gridController.reactToInput <---riga vuota 11. se non ci sono coppie generate o eventi non deve essere scritto niente sul file Ultima modifica di cionci : 16-02-2006 alle 17:39. |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Oct 2001
Messaggi: 11471
|
La test list mi sembra buona. Anche se per i test scriverei in una zona di memoria o una stringa.
ciao |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Sì...è sicuramente meglio creare un mock...
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Allora facciamo così... Ci aggironiamo alle 17:30-18, spero di essere tornato a casa per quell'ora...
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ecco il primo test
Codice:
public void testLogStringOnEvent()
{
Config config = new Config("data/GameConfig");
MockTimer timer = new MockTimer();
Input input = Input.createForTesting(timer);
PlayField playField = new PlayField(config, input, new RandomGenerator(), timer,
new Point(0,0), new Point(0,0), new Point(0,0));
input.notifyKeyEvent(KEY_LEFT, KeyEvent.PRESSED);
String logString = new String();
playField.getGridController().reactToInput(timer, logString);
String className = new MoveLeftCommandHandler(playField.getGridController().getGemsPair())
.getClass().getCanonicalName() + "\n";
assertEquals("Logged string must cotain class name", className, logString);
}
|
|
|
|
|
|
#6 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Impemento il codice...
Faccio un refactoring di reactToInput (di GridController e di InputReactor) aggiungendo un parametro StringBuffer, inoltre aggiungo in InputReactor: Codice:
private void handleKeyEvent(KeyEvent event, StringBuffer logString)
{
if(eventHandlersMap.containsKey(event.key()))
{
eventHandlersMap.get(event.key()).handleEvent(this, event);
logString.append(eventHandlersMap.get(event.key()).getClass().getName() + "\n");
}
}
|
|
|
|
|
|
#7 |
|
Junior Member
Iscritto dal: Jan 2006
Città: Cecina (LI)
Messaggi: 10
|
creata la funzione sutUp per eliminare il codice ridondante...
Codice:
public void setUp()
{
config = new Config("data/GameConfig");
timer = new MockTimer();
input = Input.createForTesting(timer);
playField = new PlayField(config, input, new RandomGenerator(), timer,
new Point(0,0), new Point(0,0), new Point(0,0));
}
Codice:
public void testLogStringOnTwoEvents()
{
StringBuffer logString = new StringBuffer();
input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
input.notifyKeyEvent(KeyEvent.DOWN, KeyEvent.PRESSED);
playField.getGridController().reactToInput(timer, logString);
String eventList = new MoveLeftCommandHandler(playField.getGridController().getGemsPair())
.getClass().getName() + "\n";
eventList += new DropCommandHandler(playField.getGridController().getGrid())
.getClass().getName() + "\n";
assertEquals("Logged string must contain left and down events", eventList, logString.toString());
}
__________________
A Bright (http://www.the-brights.net) Linux is user-friendly... It is just selective about who its friends are |
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Il test passa già !!!
Passo al prossimo test, ora facciamo sul serio: Codice:
public void testLogStringOnTwoEvents()
{
input.notifyKeyEvent(KeyEvent.DOWN, KeyEvent.RELEASED);
playField.getGridController().reactToInput(timer, new StringBuffer());
StringBuffer logString = new StringBuffer();
input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
input.notifyKeyEvent(KeyEvent.DOWN, KeyEvent.RELEASED);
playField.getGridController().reactToInput(timer, logString);
String eventList = new MoveLeftCommandHandler(playField.getGridController().getGemsPair())
.getClass().getName() + " 1\n";
eventList += new DropCommandHandler(playField.getGridController().getGrid())
.getClass().getName() + " 0\n";
assertEquals("Logged string must contain left and down events", eventList, logString.toString());
}
|
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Riporto le modifiche fatte da nihil84:
Codice:
private void execute(InputReactor inputReactor, StringBuffer logString)
{
if(isKeyPressed())
{
executeWhenPressed(inputReactor);
logString.append(this.getClass().getName() + " 1\n");
}
else
{
executeWhenReleased(inputReactor);
logString.append(this.getClass().getName() + " 0\n");
}
}
|
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ora però mi nasce un refactoring !!!
Mmmmmhhh...mettere un bel metodo in inputReactor ??!?!!? |
|
|
|
|
|
#11 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Bene...ho tolto tutti quegli string buffer passati ed ho aggiunto due metodi a InputReactor:
Codice:
public void logEvent(AbstractKeyEventHandler handler)
{
Integer keyStatus = handler.isKeyPressed() ? 1 : 0;
logString.append(handler.getClass().getName() + " " + keyStatus.toString() + "\n");
}
public String getLogString()
{
return logString.toString();
}
Fatto questo cia ggiorniamo a domani... |
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Mi proto un po' avanti...altrimenti non finiamo più...
5. se premo destra e sinistra insieme non deve essera "appeso" niente alla stringa 6. se la gestione di un evento non produce effetti (rilascio di alcuni tasti) allora non deve essere scritto niente nel file |
|
|
|
|
|
#13 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ho deciso di eliminare il test 5 perchè questo evento può essere anche messo nel log... Non crea problemi nella riproduzione degli eventi... Se vogliamo evitare di scrivere una sequenza di questo tipo lo faremo dopo...ora complica eccessivamente il design, mentre non produce errori...
|
|
|
|
|
|
#14 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Mentre una situazione in cui non ci deve essere assolutamente log è quando viene premuto un LEFT che poi viene ripetuto nello stesso reactToInput in cui viene premuto RIGHT...
Codice:
public void testNoLogOnLeftRepeatedAndRightPressed()
{
input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
playField.getGridController().reactToInput(timer);
timer.advance(config.getInteger("NormalRepeatDelay") + 1);
input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.PRESSED);
playField.getGridController().reactToInput(timer);
assertEquals("no log on left and right pressed", "",
playField.getGridController().getEventLogString());
}
public void testNoLogOnRightRepeatedAndLeftPressed()
{
input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.PRESSED);
playField.getGridController().reactToInput(timer);
timer.advance(config.getInteger("NormalRepeatDelay") + 1);
input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
playField.getGridController().reactToInput(timer);
assertEquals("no log on left and right pressed", "",
playField.getGridController().getEventLogString());
}
|
|
|
|
|
|
#15 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Ora devo testare che non venga effettuato il log al rilascio di tutti i tasti meno down...
Codice:
public void testNoLogOnKeysReleased()
{
input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.PRESSED);
input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.PRESSED);
input.notifyKeyEvent(KeyEvent.BUTTON1, KeyEvent.PRESSED);
input.notifyKeyEvent(KeyEvent.BUTTON2, KeyEvent.PRESSED);
input.notifyKeyEvent(KeyEvent.BUTTON3, KeyEvent.PRESSED);
playField.getGridController().reactToInput(timer);
input.notifyKeyEvent(KeyEvent.RIGHT, KeyEvent.RELEASED);
input.notifyKeyEvent(KeyEvent.LEFT, KeyEvent.RELEASED);
input.notifyKeyEvent(KeyEvent.BUTTON1, KeyEvent.RELEASED);
input.notifyKeyEvent(KeyEvent.BUTTON2, KeyEvent.RELEASED);
input.notifyKeyEvent(KeyEvent.BUTTON3, KeyEvent.RELEASED);
playField.getGridController().reactToInput(timer);
assertEquals("no log on right, left, down, button 1, 2, 3 release", "",
playField.getGridController().getEventLogString());
}
|
|
|
|
|
|
#16 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Prossimo test:
Codice:
public void testLogFileCreated()
{
playField.createLogFile("data/playField.log");
LogFile log = playField.getLogFile();
assertTrue("log file was not correctly created", log.isCreated());
}
Ultima modifica di cionci : 17-02-2006 alle 11:30. |
|
|
|
|
|
#17 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Prossimo test:
Codice:
public void testLogFileWritingAndReading()
{
playField.createLogFile("data/playField.log");
LogFile log = playField.getLogFile();
log.write("xxxx");
log.write("yyyy");
log.openForReading();
StringBuffer string;
log.read(string);
assertTrue("log file was not correctly written", "xxxx", string.toString());
log.read(string);
assertTrue("log file was not correctly written", "yyyy", string.toString());
}
|
|
|
|
|
|
#18 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Help...ragazzi serve un pair programmer... Io devo andare via e mi sa che non posso lavorarci per il fine settimana... C'è qualcuno che può aiutare nihil84 per completare il task ?
La classe di log è già pronta...basta integrare le varie infomazioni (seed eventi e gemme) e produrre l'output... Ricordatevi che le gemme sono lì solo a titolo informativo, infatti il random seed è sufficiente a determinare la sequenza di gemme estratte... |
|
|
|
|
|
#19 |
|
Junior Member
Iscritto dal: Jan 2006
Città: Cecina (LI)
Messaggi: 10
|
Ragazzi ho bisogno d'aiuto!
Ci sono dei particolari della meccanica del gioco che non mi sono ancora perfettamente chiari. Il mio account emme esse enne dovebbe essere pubblico, altrimenti contattatemi in privato e decidiamo come comunicare. mi dispiace, ma ancora non sono in grado di proseguire da solo non manca molto, dai!
__________________
A Bright (http://www.the-brights.net) Linux is user-friendly... It is just selective about who its friends are |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 18:56.



















