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