Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2006, 11:46   #1
cionci
Senior Member
 
L'Avatar di cionci
 
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 16:39.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 11:54   #2
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
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
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 12:04   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Sì...è sicuramente meglio creare un mock...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 13:16   #4
cionci
Senior Member
 
L'Avatar di cionci
 
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...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 17:23   #5
cionci
Senior Member
 
L'Avatar di cionci
 
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);
    }
Per ora la stringa immessa è troppo lunga, ma eventualmente ce ne preoccupiamo dopo...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 18:24   #6
cionci
Senior Member
 
L'Avatar di cionci
 
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");
        }
    }
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 19:02   #7
nihil84
Junior Member
 
L'Avatar di nihil84
 
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));
    }
e scritto il secondo test:
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
nihil84 è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 19:13   #8
cionci
Senior Member
 
L'Avatar di cionci
 
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());       
    }
Il test è lo stesso di prima, ma modificato...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 20:10   #9
cionci
Senior Member
 
L'Avatar di cionci
 
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");
        }
    }
con le relative modifiche agli altri metodi...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 20:11   #10
cionci
Senior Member
 
L'Avatar di cionci
 
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 ??!?!!?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2006, 20:33   #11
cionci
Senior Member
 
L'Avatar di cionci
 
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();
    }
Questo mi ha permesso di rendere semplicissima tutta la procedura di log !!!

Fatto questo cia ggiorniamo a domani...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 00:25   #12
cionci
Senior Member
 
L'Avatar di cionci
 
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
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 01:10   #13
cionci
Senior Member
 
L'Avatar di cionci
 
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...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 01:25   #14
cionci
Senior Member
 
L'Avatar di cionci
 
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());       
    }
Ho risolto spostando l'aggiornamento del log all'interno dei due handler...ovviamente per far funzionare tutto il resto devo spostarlo anche per gli altri handler...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 01:30   #15
cionci
Senior Member
 
L'Avatar di cionci
 
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());       
    }
Ho risolto mettendo la chiamata a logEvent solo dove serve...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 10:20   #16
cionci
Senior Member
 
L'Avatar di cionci
 
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 10:30.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 10:59   #17
cionci
Senior Member
 
L'Avatar di cionci
 
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());
    }
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 13:54   #18
cionci
Senior Member
 
L'Avatar di cionci
 
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...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2006, 14:31   #19
nihil84
Junior Member
 
L'Avatar di nihil84
 
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
nihil84 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
È il momento migliore per comprar...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
Il cofondatore di Netflix ha lasciato l'...
ASUS porta in Italia il nuovo Zenbook Du...
Assassin's Creed: Black Flag Resynced, s...
Xbox Game Pass cambierà: tra le n...
I nuovi Surface Pro e Laptop sono vicini...
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: 15:35.


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