Compare commits

..

13 Commits
main ... ueb09

Author SHA1 Message Date
8910cac7a5
add .gitignore 2025-01-11 15:38:31 +01:00
0nlineSam
56fe48642c Updated pdf 2025-01-11 13:17:22 +01:00
0nlineSam
ce6251dca3 Task 2 test all combinations 2025-01-11 13:03:41 +01:00
0nlineSam
b936a11ac4 Modified OrMatcherTest 2025-01-11 12:34:46 +01:00
0nlineSam
a7b8b7a3f7 Refactoring: Moved test packages 2025-01-11 12:32:07 +01:00
0nlineSam
754f52346f Added .iml file 2025-01-11 12:32:07 +01:00
0nlineSam
04cd6a297a Task 1 changed tests to parameterized tests 2025-01-11 12:32:07 +01:00
0nlineSam
800b5ef5d2 Added pdf 2025-01-11 12:32:07 +01:00
0nlineSam
746ece4a42 Task 2 interface testing jabref 2025-01-11 12:32:07 +01:00
0nlineSam
5da1a41b2b Task 1 b) 2 more test cases 2025-01-11 12:32:07 +01:00
0nlineSam
8f3ea48583 Task 1 a) error test cases 2025-01-11 12:32:07 +01:00
0nlineSam
f358310e66 Modification for compatibility with jdk17 2025-01-11 12:32:06 +01:00
0nlineSam
0947cda3da Added maven and dependencies 2025-01-11 12:32:06 +01:00
16 changed files with 350 additions and 11 deletions

BIN
Homework 09.pdf Normal file

Binary file not shown.

5
dicegame/.gitignore vendored
View File

@ -1,4 +1 @@
.gradle/
.idea/
src/build/
target/
/target

8
dicegame/dicegame.iml Normal file
View File

@ -0,0 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="JAVA_MODULE" version="4">
<component name="AdditionalModuleElements">
<content url="file://$MODULE_DIR$" dumb="true">
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
</content>
</component>
</module>

29
dicegame/pom.xml Normal file
View File

@ -0,0 +1,29 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.sq2024.homework08</groupId>
<artifactId>dicegame</artifactId>
<version>1.0</version>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>org.mockito</groupId>
<artifactId>mockito-core</artifactId>
<version>5.11.0</version>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter</artifactId>
<version>5.7.0</version>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,118 @@
package dicegame.logic;
import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.CsvSource;
import org.mockito.Mockito;
import java.util.Random;
import static org.junit.jupiter.api.Assertions.*;
class LogicTest {
Logic logic;
/**
* K1 Passed index:
* - index: 0-5
* - error: out of bounds
*
* K2 The number of the dice passed:
* - value: 1 | 5
* - error: !(1 | 5)
*
* K3 Existing fixation of the passed dice:
* - fixable: true | false
* - error: dice was fixed previously
*
* K4 Number of other dice of the same number fixed in the current roll:
* - bonus triggered: (2 | 5) of the same number fixed
* - no bonus triggered: (1 | 3 | 4) of the same number fixed
* - first fix of the game: 0 of the same number fixed
*
* K5 Number of fixed dice of the same number in previous rolls:
* - bonus triggered: (2 | 5) of the same number fixed
* - no bonus triggered: (1 | 3 | 4) of the same number fixed
* - first fix of the game: 0 of the same number fixed
*/
@AfterEach
void tearDown() {
logic = null;
}
// K2 (c)
// Valid index: 0-5
// The value for this index is not 1 or 5
@Test
void changeDiceStateWithValidDiceNot1Or5() {
startGameAndRollDiceWithValue(2);
Exception e = assertThrows(SelectionException.class, () -> logic.changeDiceState(0));
String expectedMessage = "Es können nur 1'en und 5'en fixiert werden!";
String actualMessage = e.getMessage();
assertEquals(expectedMessage, actualMessage);
}
// K3 (a)
@ParameterizedTest
@CsvSource({"1","5"})
void changeDiceStateWithValidDice1Or5(int diceValue) {
startGameAndRollDiceWithValue(diceValue);
// Fixing dice in round 1
assertDoesNotThrow(() -> logic.changeDiceState(0));
// Starting next round
logic.rollDice();
// Trying to fix dice again in round 2
Exception e = assertThrows(SelectionException.class, () -> logic.changeDiceState(0));
String expectedMessage = "Der Würfel wurde bereits in einer vorherigen Runde fixiert!";
String actualMessage = e.getMessage();
assertEquals(expectedMessage, actualMessage);
}
// K3 (b)
// Valid index: 0-5
// Value: 0 | 5
// Index refers to dice which has been fixed in current round
@ParameterizedTest
@CsvSource({"1","5"})
void changeDiceStateWhenFixedInThisRoll(int diceValue) {
startGameAndRollDiceWithValue(diceValue);
assertFalse(logic.isDieFixed(0));
// Fixing dice
assertDoesNotThrow(() -> logic.changeDiceState(0));
assertTrue(logic.isDieFixed(0));
//Unfixing dice
assertDoesNotThrow(() -> logic.changeDiceState(0));
assertFalse(logic.isDieFixed(0));
}
// K3 (c)
// Valid index: 0-5
// Value: 0 | 5
// Index refers to dice which is not fixed
@ParameterizedTest
@CsvSource({"1","5"})
void changeDiceStateWhenNotFixed(int diceValue) {
startGameAndRollDiceWithValue(diceValue);
assertFalse(logic.isDieFixed(0));
// Fixing dice
assertDoesNotThrow(() -> logic.changeDiceState(0));
assertTrue(logic.isDieFixed(0));
}
private void startGameAndRollDiceWithValue(int value) {
Random mockedRandom = Mockito.mock(Random.class);
Mockito.when(mockedRandom.nextInt(6)).thenReturn(value - 1);
logic = new Logic(mockedRandom);
logic.startGame();
logic.rollDice();
}
}

View File

@ -0,0 +1,32 @@
package org.jabref.model.search.matchers;
import org.jabref.model.search.SearchMatcher;
import org.jabref.model.search.rules.MockSearchMatcher;
import java.util.ArrayList;
import java.util.List;
public class AndMatcherTest extends SearchMatcherTest {
@Override
protected List<SearchMatcher> makeTrueMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildMatcher(true, true));
return matchers;
}
@Override
protected List<SearchMatcher> makeFalseMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildMatcher(true, false));
matchers.add(buildMatcher(false, true));
matchers.add(buildMatcher(false, false));
return matchers;
}
private SearchMatcher buildMatcher(boolean first, boolean second) {
MatcherSet matcherSet = MatcherSets.build(MatcherSets.MatcherType.AND);
matcherSet.addRule(new MockSearchMatcher(first));
matcherSet.addRule(new MockSearchMatcher(second));
return matcherSet;
}
}

View File

@ -0,0 +1,32 @@
package org.jabref.model.search.matchers;
import org.jabref.model.search.SearchMatcher;
import org.jabref.model.search.rules.MockSearchMatcher;
import java.util.ArrayList;
import java.util.List;
public class NotAndMatcherTest extends SearchMatcherTest {
@Override
protected List<SearchMatcher> makeTrueMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildNotMatcher(true, false));
matchers.add(buildNotMatcher(false, true));
matchers.add(buildNotMatcher(false, false));
return matchers;
}
@Override
protected List<SearchMatcher> makeFalseMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildNotMatcher(true, true));
return matchers;
}
private SearchMatcher buildNotMatcher(boolean first, boolean second) {
MatcherSet matcherSet = MatcherSets.build(MatcherSets.MatcherType.AND);
matcherSet.addRule(new MockSearchMatcher(first));
matcherSet.addRule(new MockSearchMatcher(second));
return new NotMatcher(matcherSet);
}
}

View File

@ -0,0 +1,26 @@
package org.jabref.model.search.matchers;
import org.jabref.model.search.SearchMatcher;
import org.jabref.model.search.rules.MockSearchMatcher;
import java.util.ArrayList;
import java.util.List;
public class NotMatcherTest extends SearchMatcherTest {
@Override
protected List<SearchMatcher> makeTrueMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(new NotMatcher(new MockSearchMatcher(false)));
matchers.add(new NotMatcher(new NotMatcher(new MockSearchMatcher(true))));
return matchers;
}
@Override
protected List<SearchMatcher> makeFalseMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(new NotMatcher(new MockSearchMatcher(true)));
matchers.add(new NotMatcher(new NotMatcher(new MockSearchMatcher(false))));
return matchers;
}
}

View File

@ -0,0 +1,32 @@
package org.jabref.model.search.matchers;
import org.jabref.model.search.SearchMatcher;
import org.jabref.model.search.rules.MockSearchMatcher;
import java.util.ArrayList;
import java.util.List;
public class NotOrMatcherTest extends SearchMatcherTest {
@Override
protected List<SearchMatcher> makeTrueMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildNotMatcher(false, false));
return matchers;
}
@Override
protected List<SearchMatcher> makeFalseMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildNotMatcher(true, true));
matchers.add(buildNotMatcher(true, false));
matchers.add(buildNotMatcher(false, true));
return matchers;
}
private SearchMatcher buildNotMatcher(boolean first, boolean second) {
MatcherSet matcherSet = MatcherSets.build(MatcherSets.MatcherType.OR);
matcherSet.addRule(new MockSearchMatcher(first));
matcherSet.addRule(new MockSearchMatcher(second));
return new NotMatcher(matcherSet);
}
}

View File

@ -0,0 +1,32 @@
package org.jabref.model.search.matchers;
import org.jabref.model.search.SearchMatcher;
import org.jabref.model.search.rules.MockSearchMatcher;
import java.util.ArrayList;
import java.util.List;
public class OrMatcherTest extends SearchMatcherTest {
@Override
protected List<SearchMatcher> makeTrueMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildMatcher(true, true));
matchers.add(buildMatcher(true, false));
matchers.add(buildMatcher(false, true));
return matchers;
}
@Override
protected List<SearchMatcher> makeFalseMatchers() {
List<SearchMatcher> matchers = new ArrayList<>();
matchers.add(buildMatcher(false, false));
return matchers;
}
private SearchMatcher buildMatcher(boolean first, boolean second) {
MatcherSet matcherSet = MatcherSets.build(MatcherSets.MatcherType.OR);
matcherSet.addRule(new MockSearchMatcher(first));
matcherSet.addRule(new MockSearchMatcher(second));
return matcherSet;
}
}

View File

@ -0,0 +1,40 @@
package org.jabref.model.search.matchers;
import org.jabref.model.entry.BibEntry;
import org.jabref.model.search.SearchMatcher;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.ArgumentsSource;
import java.util.List;
import static org.junit.jupiter.api.Assertions.*;
public abstract class SearchMatcherTest {
private List<SearchMatcher> trueMatchers;
private List<SearchMatcher> falseMatchers;
protected abstract List<SearchMatcher> makeTrueMatchers();
protected abstract List<SearchMatcher> makeFalseMatchers();
@BeforeEach
public void setUp() {
trueMatchers = makeTrueMatchers();
falseMatchers = makeFalseMatchers();
}
@Test
public void testIsMatch() {
for (SearchMatcher matcher : trueMatchers) {
assertTrue(matcher.isMatch(new BibEntry()));
}
}
@Test
public void testIsNotMatch() {
for (SearchMatcher matcher : falseMatchers) {
assertFalse(matcher.isMatch(new BibEntry()));
}
}
}

View File

@ -1,7 +0,0 @@
/.idea/
# Ignore Gradle project-specific cache directory
/.gradle
# Ignore Gradle build output directory
/app/build/