Test für util und save control
git-svn-id: svn://sunsvr01.isp.uni-luebeck.de/swproj13/trunk@387 72836036-5685-4462-b002-a69064685172
This commit is contained in:
parent
3ff911ab93
commit
41fe3c93b3
2 changed files with 221 additions and 0 deletions
68
test/jrummikub/control/SaveControlTest.java
Normal file
68
test/jrummikub/control/SaveControlTest.java
Normal file
|
@ -0,0 +1,68 @@
|
|||
package jrummikub.control;
|
||||
|
||||
import static jrummikub.model.StoneColor.*;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
import java.awt.Color;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
|
||||
import jrummikub.model.GameSettings;
|
||||
import jrummikub.model.GameState;
|
||||
import jrummikub.model.IRoundState;
|
||||
import jrummikub.model.PlayerSettings;
|
||||
import jrummikub.model.Position;
|
||||
import jrummikub.model.RoundState;
|
||||
import jrummikub.model.Stone;
|
||||
import jrummikub.model.StoneSet;
|
||||
import jrummikub.util.IListener3;
|
||||
import jrummikub.view.MockView;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
public class SaveControlTest {
|
||||
@Test
|
||||
public void testSaveLoad() throws IOException {
|
||||
GameSettings settings = new GameSettings();
|
||||
settings.getPlayerList().add(new PlayerSettings("Matze", Color.GREEN));
|
||||
settings.getPlayerList().add(new PlayerSettings("Ida", Color.PINK));
|
||||
|
||||
GameState gameState = new GameState();
|
||||
RoundState roundState = new RoundState(settings);
|
||||
|
||||
Stone stone1 = new Stone(1, RED);
|
||||
Stone stone2 = new Stone(5, RED);
|
||||
Stone stone3 = new Stone(2, RED);
|
||||
|
||||
roundState.getTable().drop(new StoneSet(stone1), new Position(0, 0));
|
||||
roundState.getActivePlayer().getHand().drop(stone2, new Position(0, 0));
|
||||
roundState.getActivePlayer().getHand().drop(stone3, new Position(0, 0));
|
||||
|
||||
MockView view = new MockView();
|
||||
SaveControl saveControl = new SaveControl(view);
|
||||
saveControl.setGameSettings(settings);
|
||||
saveControl.setGameState(gameState);
|
||||
saveControl.setRoundState(roundState);
|
||||
|
||||
File file = File.createTempFile("testSave", ".rum");
|
||||
|
||||
view.saveEvent.emit(file);
|
||||
|
||||
saveControl.getLoadEvent().add(
|
||||
new IListener3<GameSettings, GameState, IRoundState>() {
|
||||
|
||||
@Override
|
||||
public void handle(GameSettings settings,
|
||||
GameState gameState, IRoundState roundState) {
|
||||
assertEquals(2, settings.getPlayerList().size());
|
||||
assertEquals(1, roundState.getTable().getSize());
|
||||
assertEquals(2, roundState.getActivePlayer().getHand()
|
||||
.getSize());
|
||||
}
|
||||
});
|
||||
|
||||
view.loadEvent.emit(file);
|
||||
file.delete();
|
||||
}
|
||||
|
||||
}
|
153
test/jrummikub/util/Event3Test.java
Normal file
153
test/jrummikub/util/Event3Test.java
Normal file
|
@ -0,0 +1,153 @@
|
|||
package jrummikub.util;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
/**
|
||||
* Test class for {@link Event2}
|
||||
*/
|
||||
public class Event3Test {
|
||||
|
||||
int fired, fired2, fired3, fired4, fired5, fired6;
|
||||
|
||||
/** */
|
||||
@Test
|
||||
public void singleListener() {
|
||||
fired = 0;
|
||||
fired2 = 0;
|
||||
fired3 = 0;
|
||||
Event3<Integer, Integer, Integer> testEvent = new Event3<Integer, Integer, Integer>();
|
||||
testEvent.add(new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fired += n;
|
||||
fired2 += m;
|
||||
fired3 += o;
|
||||
}
|
||||
});
|
||||
assertEquals(fired, 0);
|
||||
assertEquals(fired2, 0);
|
||||
assertEquals(fired3, 0);
|
||||
testEvent.emit(10, 5, 3);
|
||||
assertEquals(fired, 10);
|
||||
assertEquals(fired2, 5);
|
||||
assertEquals(fired3, 3);
|
||||
testEvent.emit(20, 45, 42);
|
||||
assertEquals(fired, 30);
|
||||
assertEquals(fired2, 50);
|
||||
assertEquals(fired3, 45);
|
||||
}
|
||||
|
||||
/** */
|
||||
@Test
|
||||
public void twoListeners() {
|
||||
fired = 0;
|
||||
fired2 = 0;
|
||||
fired3 = 0;
|
||||
fired4 = 0;
|
||||
fired5 = 0;
|
||||
fired6 = 0;
|
||||
Event3<Integer, Integer, Integer> testEvent = new Event3<Integer, Integer, Integer>();
|
||||
testEvent.add(new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fired += n;
|
||||
fired2 += m;
|
||||
fired3 += o;
|
||||
}
|
||||
});
|
||||
testEvent.add(new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fired4 -= n;
|
||||
fired5 -= m;
|
||||
fired6 -= o;
|
||||
}
|
||||
});
|
||||
assertEquals(fired, 0);
|
||||
assertEquals(fired2, 0);
|
||||
assertEquals(fired3, 0);
|
||||
assertEquals(fired4, 0);
|
||||
assertEquals(fired5, 0);
|
||||
assertEquals(fired6, 0);
|
||||
testEvent.emit(5, 10, 4);
|
||||
assertEquals(fired, 5);
|
||||
assertEquals(fired2, 10);
|
||||
assertEquals(fired3, 4);
|
||||
assertEquals(fired4, -5);
|
||||
assertEquals(fired5, -10);
|
||||
assertEquals(fired6, -4);
|
||||
}
|
||||
|
||||
/** */
|
||||
@Test
|
||||
public void removeListener() {
|
||||
fired = 0;
|
||||
fired2 = 0;
|
||||
fired3 = 0;
|
||||
Event3<Integer, Integer, Integer> testEvent = new Event3<Integer, Integer, Integer>();
|
||||
testEvent.add(new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fired += n;
|
||||
fired2 += m;
|
||||
fired3 += o;
|
||||
}
|
||||
});
|
||||
IListener3<Integer, Integer, Integer> rem = new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fail();
|
||||
}
|
||||
};
|
||||
assertEquals(fired, 0);
|
||||
assertEquals(fired2, 0);
|
||||
assertEquals(fired3, 0);
|
||||
testEvent.add(rem);
|
||||
testEvent.remove(rem);
|
||||
testEvent.emit(10, 20, 30);
|
||||
assertEquals(fired, 10);
|
||||
assertEquals(fired2, 20);
|
||||
assertEquals(fired3, 30);
|
||||
}
|
||||
|
||||
/** */
|
||||
@Test
|
||||
public void removeListenerByConnection() {
|
||||
fired = 0;
|
||||
fired2 = 0;
|
||||
fired3 = 0;
|
||||
Event3<Integer, Integer, Integer> testEvent = new Event3<Integer, Integer, Integer>();
|
||||
testEvent.add(new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fired += n;
|
||||
fired2 += m;
|
||||
fired3 += o;
|
||||
}
|
||||
});
|
||||
IListener3<Integer, Integer, Integer> rem = new IListener3<Integer, Integer, Integer>() {
|
||||
|
||||
@Override
|
||||
public void handle(Integer n, Integer m, Integer o) {
|
||||
fail();
|
||||
}
|
||||
};
|
||||
assertEquals(fired, 0);
|
||||
assertEquals(fired2, 0);
|
||||
assertEquals(fired3, 0);
|
||||
Connection connection = testEvent.add(rem);
|
||||
connection.remove();
|
||||
testEvent.emit(10, 20, 30);
|
||||
assertEquals(fired, 10);
|
||||
assertEquals(fired2, 20);
|
||||
assertEquals(fired3, 30);
|
||||
}
|
||||
}
|
Reference in a new issue