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 25-01-2006, 20:23   #1
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
[Task 9.1] 71104 Vs. TigerShark Pair Reloaded

Allora..
dopo tutte 'ste incomprensioni finalmente abbiamo deciso di iniziare stasera..
e io spero anche di finire dato che nei prox giorni non posso...
a tra poco a tutti i nostri internet-ascoltatori!
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 21:21   #2
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
TestList

Allora..
dopo un'accesa discussione abbiamo deciso di seguire il suggerimento di fek e di fare estendere inizialmente alla calsse Chest il tipo Gem.
Questo ha alcune conseguenze...
a quanto abbiamo capito i test per la creazione dei Chest e per tutti i metodi in comune con la classe Gem sono già testati, quindi la prima parte del nostro task consiste in un semplice refactoring.
Invece per la seconda parte dovremo testare che la probabilità di estrazione dei Chest sia quella voluta....
Per questo direi che ci sono essenzialmente due test fondamentali:
1)Che i Chest vengano generati in media alla frequenza voluta
2)Che due Chest consecutivi non possano uscire (è corretta quest'assunzione???Joc, Vic, Fek????)
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 21:24   #3
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
secondo me si, il secondo punto è esatto.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 21:30   #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
Quote:
Originariamente inviato da ^TiGeRShArK^
2)Che due Chest consecutivi non possano uscire (è corretta quest'assunzione???Joc, Vic, Fek????)
No, non devono uscire due chest dello stesso tipo consecutivi...guardate l'ltimo post di Jocchan nel thread delal storia 9...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 21:56   #5
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
ecco il codice del primo test:
Codice:
public void TestChestType()
    {
        assertTrue("EMERALD_CHEST is not correctly recognized as a Chest", GemType.EMERALD_CHEST.isChest());
        assertTrue("RUBY_CHEST is not correctly recognized as a Chest", GemType.RUBY_CHEST.isChest());
        assertTrue("SAPPHIRE_CHEST is not correctly recognized as a Chest", GemType.SAPPHIRE_CHEST.isChest());
        assertTrue("TOPAZ_CHEST is not correctly recognized as a Chest", GemType.TOPAZ_CHEST.isChest());
        assertTrue("DIAMOND_CHEST is not correctly recognized as a Chest", GemType.DIAMOND_CHEST.isChest());
        assertFalse("EMERALD is not correctly recognized as a Gem", GemType.EMERALD.isChest());
        assertFalse("RUBY is not correctly recognized as a Gem", GemType.RUBY.isChest());
        assertFalse("SAPPHIRE is not correctly recognized as a Gem", GemType.SAPPHIRE.isChest());
        assertFalse("TOPAZ is not correctly recognized as a Gem", GemType.TOPAZ.isChest());
        assertFalse("DIAMOND is not correctly recognized as a Gem", GemType.DIAMOND.isChest());
    }
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:05   #6
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ok, ed ecco come è diventata la classe GemType:
Codice:
public final class GemType
{
    public static final GemType EMERALD = new GemType("emerald", 40, false);
    public static final GemType RUBY = new GemType("ruby", 50, false);
    public static final GemType SAPPHIRE = new GemType("sapphire", 60, false);
    public static final GemType TOPAZ = new GemType("topaz", 80, false);
    public static final GemType DIAMOND = new GemType("diamond", 100, false);
    
    public static final GemType EMERALD_CHEST = new GemType("emerald", 40, true);
    public static final GemType RUBY_CHEST = new GemType("ruby", 50, true);
    public static final GemType SAPPHIRE_CHEST = new GemType("sapphire", 60, true);
    public static final GemType TOPAZ_CHEST = new GemType("topaz", 80, true);
    public static final GemType DIAMOND_CHEST = new GemType("diamond", 100, true);
    
    private final String name;
    private final int score;
    private final boolean isChest;
    
    
    GemType(String name, int score, boolean isChest)
    {
        this.name = name;
        this.score = score;
        this.isChest = isChest;
    }
    
    
    public String name()
    {
        return name;
    }
    
    
    public int score()
    {
        return score;
    }
    
    
    public boolean isChest()
    {
        return isChest;
    }
}
ora, spiegazione: siccome ci è stato richiesto di derivbare una classe Chest da Gem, io e TigerShark abbiamo deciso di implementare quel metodo per capire quand'è che il metodo statico Gem.create deve creare un oggetto Gem e quand'è che deve creare Chest, in base a cosa ritorna il metodo isChest dall'oggetto gemType passato come parametro a create.

ora ci sarebbe da testare se create in base a cosa viene ritornato da isChest capisce se creare un oggetto Gem o un oggetto Chest, e la cosa riesce un po' difficoltosa a causa del fatto che in Java che io sappia non è direttamente possibile ricavare RTTI sul tipo di un oggetto, quindi penso di aggiungere un metodo virtuale isChest anche in Gem e di sovrascriverlo in Chest; fek e vic, se pensate che non ne valga la pena fermateci e reverteremo.

intanto scrivo il test per questo metodo che TigerShark implementerà.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:23   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
prossimi test:
Codice:
    public void testGemIsNotChest()
    {
        Gem gem = Gem.createForTesting();
        assertFalse(gem.isChest());
    }
    
    public void testChestIsChest()
    {
        Gem gem = Chest.createForTesting();
        assertTrue(gem.isChest());
    }
questi due test servono a testare che isChest funzioni correttamente e che sia un metodo virtuale.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:34   #8
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
Quote:
Originariamente inviato da 71104
ora, spiegazione: siccome ci è stato richiesto di derivbare una classe Chest da Gem, io e TigerShark abbiamo deciso di implementare quel metodo per capire quand'è che il metodo statico Gem.create deve creare un oggetto Gem e quand'è che deve creare Chest, in base a cosa ritorna il metodo isChest dall'oggetto gemType passato come parametro a create.
Ti spezzo un braccio se ci provi. (Adoro le minacce fisiche )

Evitare metodi tipo isChest(), getType(), etc etc, sono l'esatto motivo per il quale esistono praticamente meta' dei Design Pattern. Trovate sicuramente un modo alternativo (un factory method in GemType?).
fek è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:35   #9
fek
Senior Member
 
L'Avatar di fek
 
Iscritto dal: Oct 2002
Città: San Jose, California
Messaggi: 11794
Quote:
Originariamente inviato da 71104
prossimi test:
Codice:
    public void testGemIsNotChest()
    {
        Gem gem = Gem.createForTesting();
        assertFalse(gem.isChest());
    }
    
    public void testChestIsChest()
    {
        Gem gem = Chest.createForTesting();
        assertTrue(gem.isChest());
    }
questi due test servono a testare che isChest funzioni correttamente e che sia un metodo virtuale.

REVEEEEEEEEEEEEEEEEEEEEERT!
fek è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:43   #10
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Fek...ma tu quindi la Reflection la usi??
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:54   #11
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
è stata colpa mia ke avrei dovuto pensarci avendolo usato un paio di volte questo pattern....
ma stasera sono proprio fuso

__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:55   #12
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
eh...? :|
non ho capito cos'è che non devo fare... O_o'
che tipo di metodi devo evitare?

mi sembrava una soluzione semplicissima quella che avevo inventato... o_O' e funzionava pure...

TigerShark dice di aver capito che dobbiamo cambiare e fare in modo che Gem e Chest derivino da una stessa classe di base, ma... non eri stato tu a imporci di derivare Chest da Gem??? :|

boh, a me sembrava che andasse tutto liscio... che dobbiamo fare di preciso?
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:57   #13
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
AAAAAAAAAAHHHHHHHHHHHHHHH FERMIHOCAPITOTUTTO!!!
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:57   #14
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Scusatemi... Dal momento in cui avete GemType.isChest() cosa ve ne fate della derivazione? Tenete la classe Gem ormai no?
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:58   #15
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
....mi sa ke io sono OUT.....
stasera nn capisco piu' niente e nei prox giorni sono a reggio....

ke si fa?
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 22:59   #16
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
TigerShark, ricominciamo daccapo, e stavolta andremo più veloci; allora, ho capito il democratico suggerimento di fek, dobbiamo cancellare isChest e mettere un public static Gem createByType, giusto?

scrivo il test...
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:00   #17
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da Ufo13
Scusatemi... Dal momento in cui avete GemType.isChest() cosa ve ne fate della derivazione? Tenete la classe Gem ormai no?
no, serviva anche la derivazione, altrimenti era tutto più complesso, ma adesso cambiamo tutto.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:03   #18
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
C'è un volontario x continuare con 71104 ke io nei prox giorni non ci sarò???
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:11   #19
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Io prima di sabato niente mi spiace
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2006, 23:11   #20
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
le cose si complicano: a TigerShark è caduta nuovamente la linea e a me per continuare serve di sapere la sintassi di instanceof, che serve in Java per ricavare RTTI; lo devo usare per forza nei test se non devo fare metodi virtuali, altrimenti il metodo statico Gem.create rimarrà non testato...
siccome s'è fatto tardi è meglio continuare domani, faccio un commit per essere sicuri che la codebase non contenga quei metodi virtuali che avevamo iniziato a scrivere.
71104 è 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:12.


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