Compare commits
2 Commits
master
...
vollständi
Author | SHA1 | Date |
---|---|---|
|
9928ee5ed7 | 2 years ago |
|
527cec763e | 3 years ago |
49 changed files with 2304 additions and 7 deletions
@ -0,0 +1,3 @@ |
|||
# Default ignored files |
|||
/shelf/ |
|||
/workspace.xml |
@ -0,0 +1,17 @@ |
|||
<component name="libraryTable"> |
|||
<library name="junit.jupiter" type="repository"> |
|||
<properties maven-id="org.junit.jupiter:junit-jupiter:5.8.0" /> |
|||
<CLASSES> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter/5.8.0/junit-jupiter-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-api/5.8.0/junit-jupiter-api-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/opentest4j/opentest4j/1.2.0/opentest4j-1.2.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/platform/junit-platform-commons/1.8.0/junit-platform-commons-1.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/apiguardian/apiguardian-api/1.1.2/apiguardian-api-1.1.2.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-params/5.8.0/junit-jupiter-params-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-engine/5.8.0/junit-jupiter-engine-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/platform/junit-platform-engine/1.8.0/junit-platform-engine-1.8.0.jar!/" /> |
|||
</CLASSES> |
|||
<JAVADOC /> |
|||
<SOURCES /> |
|||
</library> |
|||
</component> |
@ -0,0 +1,9 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="MarkdownSettings"> |
|||
<enabledExtensions> |
|||
<entry key="MermaidLanguageExtension" value="false" /> |
|||
<entry key="PlantUMLLanguageExtension" value="false" /> |
|||
</enabledExtensions> |
|||
</component> |
|||
</project> |
@ -0,0 +1,4 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="ProjectRootManager" version="2" project-jdk-name="11" project-jdk-type="JavaSDK" /> |
|||
</project> |
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="ProjectModuleManager"> |
|||
<modules> |
|||
<module fileurl="file://$PROJECT_DIR$/.idea/oop_crashkurs.iml" filepath="$PROJECT_DIR$/.idea/oop_crashkurs.iml" /> |
|||
</modules> |
|||
</component> |
|||
</project> |
@ -0,0 +1,13 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<module type="JAVA_MODULE" version="4"> |
|||
<component name="NewModuleRootManager" inherit-compiler-output="true"> |
|||
<exclude-output /> |
|||
<content url="file://$MODULE_DIR$"> |
|||
<sourceFolder url="file://$MODULE_DIR$/SimpleArrayMap" isTestSource="false" /> |
|||
<sourceFolder url="file://$MODULE_DIR$/SimpleLinkedList" isTestSource="false" /> |
|||
</content> |
|||
<orderEntry type="inheritedJdk" /> |
|||
<orderEntry type="sourceFolder" forTests="false" /> |
|||
<orderEntry type="library" name="junit.jupiter" level="project" /> |
|||
</component> |
|||
</module> |
@ -0,0 +1,6 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="VcsDirectoryMappings"> |
|||
<mapping directory="" vcs="Git" /> |
|||
</component> |
|||
</project> |
@ -0,0 +1,17 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<projectDescription> |
|||
<name>2021-WS-Testat-G1-TagAnalyzer-LV</name> |
|||
<comment></comment> |
|||
<projects> |
|||
</projects> |
|||
<buildSpec> |
|||
<buildCommand> |
|||
<name>org.eclipse.jdt.core.javabuilder</name> |
|||
<arguments> |
|||
</arguments> |
|||
</buildCommand> |
|||
</buildSpec> |
|||
<natures> |
|||
<nature>org.eclipse.jdt.core.javanature</nature> |
|||
</natures> |
|||
</projectDescription> |
Binary file not shown.
@ -0,0 +1,58 @@ |
|||
package G1; |
|||
|
|||
import twitter.TweetObject; |
|||
|
|||
import java.util.*; |
|||
import java.util.function.Consumer; |
|||
import java.util.function.Predicate; |
|||
|
|||
public abstract class ATweetTagAnalyser { |
|||
|
|||
// ----------------------------------------------------
|
|||
// API
|
|||
// ----------------------------------------------------
|
|||
|
|||
public int prepareTweetObject(TweetObject tweet) { |
|||
return prepareTweetObject(tweet, t -> true); |
|||
} |
|||
|
|||
// Extrahiert die Tags aus dem Text des Tweet-Objektes in eine Liste und fügt diese dem
|
|||
// Tweet-Objekt hinzu, falls dass Tweet-Objekt den filter erfüllt (Methode filter.test(...))
|
|||
// muss true liefern. Achtung: Das "#"-Zeichen muss entfernt werden
|
|||
// Rückgabe: 0 falls tweet == null oder filter.test(tweet)==False
|
|||
// Sonst: Anzahl an gefundenen Tags
|
|||
// Beachten Sie die Hinweise
|
|||
public abstract int prepareTweetObject(TweetObject tweet, Predicate<TweetObject> filter); |
|||
|
|||
// Fügt die Tags eines tweet-Objektes zum Analyzer hinzu. Das Tweet-Objekt muss die Tags als
|
|||
// Liste enthalten (im Attribut tagList).
|
|||
// Rückgabe: Anzahl an Tags, die noch nicht im Analyzer enthalten waren
|
|||
// 0 falls tweet==null
|
|||
public abstract int addTags(TweetObject tweet); |
|||
|
|||
// Liefert die Anzahl, wie oft der Tag tag zum Analyzer hinzugefügt wurde
|
|||
// 0 falls der Tag nicht enthalten ist
|
|||
public abstract int getTagCount(String tag); |
|||
|
|||
// Ist der Tag im Analyzer enthalten?
|
|||
public abstract boolean contains(String tag); |
|||
|
|||
// Löscht einen Tag und gibt die Anzahl zurück,wie oft er addiert wurde
|
|||
public abstract int remove(String tag); |
|||
|
|||
|
|||
// Undo-Operation für addTags(TweetObject tweet).
|
|||
public abstract int removeTags(TweetObject tweet); |
|||
|
|||
//public abstract int forEach(Consumer<Integer> action);
|
|||
public abstract Set<String> getTags(); |
|||
|
|||
|
|||
// ----------------------------------------------------
|
|||
// Delegate methods
|
|||
// ----------------------------------------------------
|
|||
|
|||
|
|||
|
|||
|
|||
} |
@ -0,0 +1,252 @@ |
|||
package G1; |
|||
|
|||
import org.junit.jupiter.api.BeforeAll; |
|||
import org.junit.jupiter.api.BeforeEach; |
|||
import org.junit.jupiter.api.Test; |
|||
import twitter.TweetObject; |
|||
|
|||
import java.util.Arrays; |
|||
import java.util.HashSet; |
|||
import java.util.List; |
|||
import java.util.Set; |
|||
import java.util.concurrent.atomic.AtomicInteger; |
|||
import java.util.function.Consumer; |
|||
import java.util.function.Predicate; |
|||
|
|||
import static org.junit.jupiter.api.Assertions.*; |
|||
|
|||
public abstract class ATweetTagAnalyserTest { |
|||
|
|||
private ATweetTagAnalyser analyser; |
|||
|
|||
private Set<String> interestingTags = new HashSet<>(); |
|||
private ATweetTagAnalyser preparation; |
|||
protected Predicate<TweetObject> filter = t -> { |
|||
if(t.getId().equals("123459876543211")) {return false;} |
|||
else {return true;} |
|||
}; |
|||
|
|||
static TweetObject tw1, tw1c, tw2, tw2c, tw3, tw4, tw5; |
|||
|
|||
@BeforeAll |
|||
static void setUpBeforeAll() { |
|||
tw1c = new TweetObject("123459876543211", null, "Mein #PCR Test ist positiv, #Corona " + |
|||
"#Covid19"); |
|||
tw1c.setTags(Arrays.asList("corona", "pcr", "covid19")); |
|||
tw2c = new TweetObject("123459876543212", null, "Geht zur #Corona #Impfung " + |
|||
"#COVID19"); |
|||
tw2c.setTags(Arrays.asList("corona", "impfung", "covid19")); |
|||
} |
|||
|
|||
protected abstract ATweetTagAnalyser getInstance(); |
|||
|
|||
@BeforeEach |
|||
void setUp() { |
|||
analyser = getInstance(); |
|||
tw1 = new TweetObject("123459876543211", null, "Mein #PCR Test ist positiv, #Corona " + |
|||
"#Covid19"); |
|||
tw2 = new TweetObject("123459876543212", null, "Geht zur #Corona #Impfung " + |
|||
"#COVID19"); |
|||
tw3 = new TweetObject("123459876543212", null, "Hallo Welt"); |
|||
tw4 = new TweetObject("123459876543212", null, "#CORONA ist #Mist"); |
|||
tw4.setTags(Arrays.asList("corona", "mist")); |
|||
tw5 = new TweetObject("123459876543211", null, "Am BVerfG gelten für alle " + |
|||
"Prozessbeteiligten strengste " + |
|||
"Zugangsbeschränkungen: 2G plus " + |
|||
"PCR Test. Erste Bundesländer vom " + |
|||
"Grundsatz ab, die Justiz bei " + |
|||
"Corona-Beschränkungen auszusparen " + |
|||
"#covid #corona #Grundgesetz"); |
|||
|
|||
} |
|||
|
|||
@Test |
|||
void prepareTweetObject1() { |
|||
var actual = analyser.prepareTweetObject(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void prepareTweetObject2() { |
|||
var actual = analyser.prepareTweetObject(tw1); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@Test |
|||
void prepareTweetObject3() { |
|||
var actual = analyser.prepareTweetObject(tw5, this.filter); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void prepareTweetObject4() { |
|||
analyser.prepareTweetObject(tw1); |
|||
var actual = tw1.getTags().size(); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@Test |
|||
void prepareTweetObject5() { |
|||
analyser.prepareTweetObject(tw1); |
|||
List<String> tagList = tw1.getTags(); |
|||
var actual = tagList.contains("corona"); |
|||
assertEquals(true, actual); |
|||
actual = tagList.contains("covid19"); |
|||
assertEquals(true, actual); |
|||
actual = tagList.contains("pcr"); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTags1() { |
|||
var actual = analyser.addTags(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTags2() { |
|||
var actual = analyser.addTags(tw1c); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTags3() { |
|||
analyser.addTags(tw1c); |
|||
var actual = analyser.addTags(tw1c); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTags4() { |
|||
analyser.addTags(tw1c); |
|||
var actual = analyser.addTags(tw2c); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
|
|||
@Test |
|||
void getTagCount1() { |
|||
var actual = analyser.getTagCount("corona"); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void getTagCount2a() { |
|||
analyser.addTags(tw1c); |
|||
var actual = analyser.getTagCount("corona"); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@Test |
|||
void getTagCount2b() { |
|||
analyser.addTags(tw1c); |
|||
var actual = analyser.getTagCount("CORONa"); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@Test |
|||
void getTagCount3() { |
|||
analyser.addTags(tw1c); |
|||
analyser.addTags(tw2c); |
|||
var actual = analyser.getTagCount("corona"); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
|
|||
@Test |
|||
void remove1a() { |
|||
var actual = analyser.remove(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void remove1b() { |
|||
var actual = analyser.remove("corona"); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void remove2a() { |
|||
analyser.addTags(tw1c); |
|||
var actual = analyser.remove("corona"); |
|||
assertEquals(1, actual); |
|||
actual = analyser.getTagCount("corona"); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void remove2b() { |
|||
analyser.addTags(tw1c); |
|||
var actual = analyser.remove("Corona"); |
|||
assertEquals(1, actual); |
|||
actual = analyser.getTagCount("corona"); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void remove3() { |
|||
analyser.addTags(tw1c); |
|||
analyser.addTags(tw2c); |
|||
var actual = analyser.remove("corona"); |
|||
assertEquals(2, actual); |
|||
actual = analyser.getTagCount("corona"); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void remove4() { |
|||
analyser.addTags(tw1c); |
|||
analyser.addTags(tw2c); |
|||
analyser.remove("corona"); |
|||
var actual = analyser.getTagCount("pcr"); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@Test |
|||
void removeTweet1a() { |
|||
var actual = analyser.removeTags(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void removeTweet1b() { |
|||
var actual = analyser.removeTags(tw1c); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void removeTweet2a() { |
|||
analyser.addTags(tw1c); |
|||
analyser.addTags(tw2c); |
|||
analyser.addTags(tw4); |
|||
var actual = analyser.removeTags(tw1c); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@Test |
|||
void removeTweet2b() { |
|||
analyser.addTags(tw1c); |
|||
analyser.addTags(tw2c); |
|||
analyser.addTags(tw4); |
|||
analyser.removeTags(tw1c); |
|||
var actual = analyser.getTagCount("Corona"); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
// @Test
|
|||
// void forEach1() {
|
|||
// var actual = analyser.forEach(null);
|
|||
// assertEquals(0, actual);
|
|||
// }
|
|||
//
|
|||
// @Test
|
|||
// void forEach2() {
|
|||
// AtomicInteger counter = new AtomicInteger();
|
|||
// Consumer<Integer> action = s -> counter.getAndAdd(s);
|
|||
// analyser.addTags(tw1);
|
|||
// analyser.addTags(tw2);
|
|||
// var actual = analyser.forEach(action);
|
|||
// assertEquals(4, actual);
|
|||
// assertEquals(6, counter.intValue());
|
|||
// }
|
|||
} |
@ -0,0 +1,100 @@ |
|||
package G1_solution; |
|||
|
|||
import G1.ATweetTagAnalyser; |
|||
import twitter.TweetObject; |
|||
|
|||
import java.util.*; |
|||
import java.util.function.Consumer; |
|||
import java.util.function.Predicate; |
|||
|
|||
public class TweetTagAnalyzer extends ATweetTagAnalyser { |
|||
|
|||
private Map<String, Integer> tagCounter; |
|||
private Set<String> interestingTags; |
|||
|
|||
public TweetTagAnalyzer(Set<String> interestingTags) { |
|||
this.interestingTags = interestingTags; |
|||
} |
|||
|
|||
public TweetTagAnalyzer() { |
|||
this.interestingTags = null; |
|||
this.tagCounter = new HashMap<>(); |
|||
} |
|||
|
|||
@Override |
|||
public int prepareTweetObject(TweetObject tweet, Predicate<TweetObject> filter) { |
|||
if(tweet == null) {return 0;} |
|||
if(!filter.test(tweet)) {return 0;} |
|||
List<String> tagList = new LinkedList<>(); |
|||
String[] parts = tweet.getText().toLowerCase().split(" "); |
|||
for(int i = 0; i < parts.length; i++) { |
|||
if(parts[i].contains("#")) { |
|||
String tag = parts[i].replace("#", ""); |
|||
tagList.add(tag); |
|||
} |
|||
} |
|||
tweet.setTags(tagList); |
|||
return tagList.size(); |
|||
} |
|||
|
|||
@Override |
|||
public int addTags(TweetObject tweet) { |
|||
if(tweet == null) {return 0;} |
|||
int counter = 0; |
|||
for(String tag : tweet.getTags()) { |
|||
Integer tagCount = tagCounter.get(tag); |
|||
if(tagCount == null) { |
|||
counter++; |
|||
tagCount = 0; |
|||
} |
|||
tagCounter.put(tag, tagCount + 1); |
|||
} |
|||
return counter; |
|||
} |
|||
|
|||
|
|||
@Override |
|||
public int getTagCount(String tag) { |
|||
Integer counter = this.tagCounter.get(tag.toLowerCase(Locale.ROOT)); |
|||
if(counter == null) {return 0;} |
|||
return counter; |
|||
} |
|||
|
|||
@Override |
|||
public boolean contains(String tag) { |
|||
return this.tagCounter.values().contains(tag); |
|||
} |
|||
|
|||
@Override |
|||
public int remove(String tag) { |
|||
if(tag == null) {return 0;} |
|||
Integer counter = this.tagCounter.remove(tag.toLowerCase(Locale.ROOT)); |
|||
if(counter != null) {return counter;} |
|||
return 0; |
|||
} |
|||
|
|||
@Override |
|||
public int removeTags(TweetObject tweet) { |
|||
if(tweet == null) {return 0;} |
|||
int counter = 0; |
|||
for(String tag : tweet.getTags()) { |
|||
int tagCount = getTagCount(tag.toLowerCase()); |
|||
if(tagCount > 0) { |
|||
this.tagCounter.put(tag.toLowerCase(Locale.ROOT), --tagCount); |
|||
counter++; |
|||
} |
|||
} |
|||
return counter; |
|||
} |
|||
|
|||
// @Override
|
|||
// public int forEach(Consumer<Integer> action) {
|
|||
// this.tagCounter.values().forEach(v -> action.accept(v));
|
|||
// return this.tagCounter.size();
|
|||
// }
|
|||
|
|||
@Override |
|||
public Set<String> getTags() { |
|||
return null; |
|||
} |
|||
} |
@ -0,0 +1,11 @@ |
|||
package G1_solution; |
|||
|
|||
import G1.ATweetTagAnalyser; |
|||
import G1.ATweetTagAnalyserTest; |
|||
|
|||
public class TweetTagAnalyzerTest extends ATweetTagAnalyserTest { |
|||
@Override |
|||
protected ATweetTagAnalyser getInstance() { |
|||
return new TweetTagAnalyzer(); |
|||
} |
|||
} |
@ -0,0 +1,15 @@ |
|||
package twitter; |
|||
|
|||
import org.junit.jupiter.api.BeforeEach; |
|||
|
|||
public abstract class AbstractTestClass<T> { |
|||
protected T testObject; |
|||
|
|||
protected abstract T getInstance(); |
|||
|
|||
@BeforeEach |
|||
void setUp() { |
|||
testObject = getInstance(); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,86 @@ |
|||
package twitter; |
|||
|
|||
import java.util.Date; |
|||
import java.util.LinkedList; |
|||
import java.util.List; |
|||
|
|||
public class TweetObject { |
|||
private String id; |
|||
private String created_at; |
|||
private String text; |
|||
private String user; |
|||
private int wordCount; |
|||
private List<String> tags; |
|||
|
|||
public TweetObject() {} |
|||
|
|||
public TweetObject(String id, String created_at, String text) { |
|||
this.id = id; |
|||
this.created_at = created_at; |
|||
this.text = text; |
|||
this.tags = new LinkedList<>(); |
|||
} |
|||
|
|||
public String getId() { |
|||
return id; |
|||
} |
|||
|
|||
public void setId(String id) { |
|||
this.id = id; |
|||
} |
|||
|
|||
public String getCreated_at() { |
|||
return created_at; |
|||
} |
|||
|
|||
public void setCreated_at(String created_at) { |
|||
this.created_at = created_at; |
|||
} |
|||
|
|||
public String getText() { |
|||
return text; |
|||
} |
|||
|
|||
public void setText(String text) { |
|||
this.text = text; |
|||
} |
|||
|
|||
public String getUser() { |
|||
return user; |
|||
} |
|||
|
|||
public void setUser(String user) { |
|||
this.user = user; |
|||
} |
|||
|
|||
public int getWordCount() {return wordCount;} |
|||
|
|||
public void setWordCount(int wordCount) {this.wordCount = wordCount;} |
|||
|
|||
public List<String> getTags() { |
|||
return tags; |
|||
} |
|||
|
|||
public void setTags(List<String> tags) { |
|||
this.tags.addAll(tags); |
|||
} |
|||
|
|||
public void addTag(String tag) {this.tags.add(tag);} |
|||
|
|||
@Override |
|||
public boolean equals(Object obj) { |
|||
if(obj == null) {return false;} |
|||
if(obj instanceof TweetObject) { |
|||
TweetObject that = (TweetObject) obj; |
|||
return this.id.equals(that.id); |
|||
} |
|||
return false; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return id + ';' + created_at + ';' + text + ';' + user; |
|||
} |
|||
} |
|||
|
|||
|
@ -0,0 +1,17 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<projectDescription> |
|||
<name>2021-WS-Testat-G2-TweetGen-LV</name> |
|||
<comment></comment> |
|||
<projects> |
|||
</projects> |
|||
<buildSpec> |
|||
<buildCommand> |
|||
<name>org.eclipse.jdt.core.javabuilder</name> |
|||
<arguments> |
|||
</arguments> |
|||
</buildCommand> |
|||
</buildSpec> |
|||
<natures> |
|||
<nature>org.eclipse.jdt.core.javanature</nature> |
|||
</natures> |
|||
</projectDescription> |
Binary file not shown.
@ -0,0 +1,86 @@ |
|||
package G2; |
|||
|
|||
import twitter.TweetObject; |
|||
|
|||
import java.util.*; |
|||
|
|||
public abstract class ATweetGenerator { |
|||
|
|||
private ITwitterConnector connector; |
|||
|
|||
public interface ITwitterConnector { |
|||
public boolean testConnection(); |
|||
|
|||
public boolean postTweets(Collection<TweetObject> tweetObjects); |
|||
} |
|||
|
|||
public ATweetGenerator() { |
|||
|
|||
} |
|||
|
|||
// ----------------------------------------------------
|
|||
// API
|
|||
// ----------------------------------------------------
|
|||
|
|||
|
|||
// Umwandlung der Zeichenkette csvTweet in ein TweetObject
|
|||
// Die Tags können mit extractTags(String text) extrahiert werden (s.u.)
|
|||
// Rückgabe: TweetObjekt, null falls csvString == null oder syntaktisch nicht korrekt ist
|
|||
// Format csvString: id;created_at;text;user
|
|||
// Hinweis: text enthält kein ";"
|
|||
public abstract TweetObject addTweetCSV(String csvTweed); |
|||
|
|||
// Fügt das tweetObjekt hinzu sofern es nicht null oder bereits enthalten ist
|
|||
// Falls das TweetObjekt hinzugefügt wird, wird die Anzahl an Wörtern im Text zu der bereits
|
|||
// gespeicherten Anzahl der Wörter des Users tweet.getUser() hinzugefügt
|
|||
// Falls Tweet keine Wörter enthält, nicht aufnehmen
|
|||
// Rückgabe: Anzahl der neu aufgenommenen Wörter (0 falls tweet bereits enthalten ist)
|
|||
public abstract int addTweet(TweetObject tweet); |
|||
|
|||
// Gesamte Anzahl an Wörtern
|
|||
public abstract int getNrOfWords(); |
|||
|
|||
// Gesamte Anzahl an Wörtern von User user
|
|||
public abstract int getNrOfWords(String user); |
|||
|
|||
// Tweet enthalten
|
|||
public abstract boolean contains(TweetObject tweet); |
|||
|
|||
// Löscht den Tweet und entfernt die entsprechende Anzahl an Wörtern bei User tweet.getUser()
|
|||
// Rückgabe: Die Anzahl an verbleibenden Wörter des User
|
|||
// Ist tweet == null oder der Tweet nicht enthalten, wird 0 zurückgegeben
|
|||
public abstract int remove(TweetObject tweet); |
|||
|
|||
// Postet alle gesammelten Tweets, sofern testConnection() true ergibt
|
|||
// Rückgabe true, falls postTweet() true liefert
|
|||
// danach ist der CLient leer
|
|||
public abstract int postTweets(ITwitterConnector connector); |
|||
|
|||
|
|||
// Support
|
|||
public int addTweetsCSV(Collection<String> csvTweedCollection) { |
|||
Set<TweetObject> collectedTweeds = new HashSet<>(); |
|||
csvTweedCollection.forEach(csvTweet -> collectedTweeds.add(this.addTweetCSV(csvTweet))); |
|||
return addTweets(collectedTweeds); |
|||
} |
|||
|
|||
public int addTweets(Collection<TweetObject> tweetObjects) { |
|||
int counter = 0; |
|||
for(TweetObject t : tweetObjects) { |
|||
counter += this.addTweet(t); |
|||
} |
|||
return counter; |
|||
} |
|||
|
|||
protected static List<String> extractTags(String text) { |
|||
List<String> tagList = new LinkedList<>(); |
|||
String[] parts = text.split(" "); |
|||
for(int i = 0; i < parts.length; i++) { |
|||
if(parts[i].contains("#")) { |
|||
String[] tagParts = parts[i].split("#"); |
|||
tagList.add(tagParts[1]); |
|||
} |
|||
} |
|||
return tagList; |
|||
} |
|||
} |
@ -0,0 +1,296 @@ |
|||
package G2; |
|||
|
|||
import org.junit.jupiter.api.BeforeAll; |
|||
import org.junit.jupiter.api.BeforeEach; |
|||
import org.junit.jupiter.api.Test; |
|||
import twitter.TweetObject; |
|||
|
|||
import java.util.Collection; |
|||
|
|||
import static org.junit.jupiter.api.Assertions.assertEquals; |
|||
|
|||
public abstract class ATweetGeneratorTest { |
|||
private ATweetGenerator client; |
|||
private ATweetGenerator.ITwitterConnector defaultConnector = new ATweetGenerator.ITwitterConnector() { |
|||
@Override |
|||
public boolean testConnection() { |
|||
return false; |
|||
} |
|||
|
|||
@Override |
|||
public boolean postTweets(Collection<TweetObject> tweetObjects) { |
|||
return false; |
|||
} |
|||
}; |
|||
private ATweetGenerator.ITwitterConnector connector = new ATweetGenerator.ITwitterConnector() { |
|||
@Override |
|||
public boolean testConnection() { |
|||
return true; |
|||
} |
|||
|
|||
@Override |
|||
public boolean postTweets(Collection<TweetObject> tweetObjects) { |
|||
return true; |
|||
} |
|||
}; |
|||
static TweetObject tw1, tw2, tw3; |
|||
static String csv1; |
|||
static String csv2 = "123456789;2020-12-22T13:28:30.000Z;OOPP-Testat trotz #corona #Covid19;1234"; |
|||
static String csv3 = "123456719;2020-12-22T13:28:30.000Z;OOPP-Testat im #Corona-Semester " + |
|||
"#Covid19;" + |
|||
"271895613"; |
|||
; |
|||
|
|||
@BeforeAll |
|||
static void setUpBeforeAll() { } |
|||
|
|||
protected abstract ATweetGenerator getInstance(); |
|||
|
|||
@BeforeEach |
|||
void setUp() { |
|||
client = getInstance(); |
|||
tw1 = new TweetObject("1341375150298697728", null, "Mein #PCR-Test ist positiv, #Corona " + |
|||
"#Covid19"); |
|||
tw1.setUser("271895613"); |
|||
csv1 = tw1.toString(); |
|||
tw2 = new TweetObject("1341375111920758786", null, ""); |
|||
tw2.setUser("151949069"); |
|||
|
|||
tw3 = new TweetObject("2221375150298697728", null, "Mein #PCR Test ist negativ, #Corona " + |
|||
"#Covid19"); |
|||
tw3.setUser("271895613"); |
|||
} |
|||
|
|||
@Test |
|||
void addTweetCSV1a() { |
|||
var actual = client.addTweetCSV(null); |
|||
assertEquals(null, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTweetCSV1b() { |
|||
var actual = client.addTweetCSV(""); |
|||
assertEquals(null,actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTweetCSV2() { |
|||
var actual = client.addTweetCSV(csv1); |
|||
assertEquals(tw1, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTweetCSV3() { |
|||
var actual = client.addTweetCSV(csv2); |
|||
assertEquals("OOPP-Testat trotz #corona #Covid19", actual.getText()); |
|||
assertEquals(2, actual.getTags().size()); |
|||
assertEquals("1234", actual.getUser()); |
|||
} |
|||
|
|||
@Test |
|||
void addTweet1() { |
|||
var actual = client.addTweet(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTweet2() { |
|||
var actual = client.addTweet(tw1); |
|||
assertEquals(6, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTweet3() { |
|||
client.addTweet(tw1); |
|||
var actual = client.addTweet(tw2); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void addTweet4() { |
|||
client.addTweet(tw1); |
|||
var actual = client.addTweet(tw1); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWords1() { |
|||
var actual = client.getNrOfWords(); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWords2() { |
|||
client.addTweet(tw1); |
|||
var actual = client.getNrOfWords(); |
|||
assertEquals(6, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWords3() { |
|||
client.addTweet(tw1); |
|||
client.addTweet(tw1); |
|||
var actual = client.getNrOfWords(); |
|||
assertEquals(6, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWordsUser1a() { |
|||
var actual = client.getNrOfWords(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWordsUser1b() { |
|||
var actual = client.getNrOfWords(""); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWordsUser2a() { |
|||
client.addTweet(tw1); |
|||
var actual = client.getNrOfWords("271895613"); |
|||
assertEquals(6, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWordsUser2b() { |
|||
client.addTweet(tw1); |
|||
var actual = client.getNrOfWords("2718956000"); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWordsUser3() { |
|||
client.addTweet(tw1); |
|||
var actual = client.getNrOfWords("271895613"); |
|||
assertEquals(6, actual); |
|||
} |
|||
|
|||
@Test |
|||
void nrOfWordsUser4() { |
|||
client.addTweet(tw1); |
|||
client.addTweet(tw3); |
|||
var actual = client.getNrOfWords("271895613"); |
|||
assertEquals(13, actual); |
|||
} |
|||
|
|||
@Test |
|||
void testContains1a() { |
|||
var actual = client.contains(null); |
|||
assertEquals(false, actual); |
|||
} |
|||
@Test |
|||
void testContains1b() { |
|||
var actual = client.contains(tw1); |
|||
assertEquals(false, actual); |
|||
} |
|||
@Test |
|||
void testContains2() { |
|||
client.addTweet(tw1); |
|||
client.addTweet(tw2); |
|||
var actual = client.contains(tw1); |
|||
assertEquals(true, actual); |
|||
} |
|||
@Test |
|||
void testContains3() { |
|||
client.addTweet(tw1); |
|||
var actual = client.contains(tw2); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@Test |
|||
void testRemove1a() { |
|||
var actual = client.remove(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
@Test |
|||
void testRemove1b() { |
|||
var actual = client.remove(tw1); |
|||
assertEquals(0, actual); |
|||
} |
|||
@Test |
|||
void testRemove2a() { |
|||
client.addTweet(tw1); |
|||
var actual = client.remove(tw1); |
|||
assertEquals(0, actual); |
|||
} |
|||
@Test |
|||
void testRemove2b() { |
|||
client.addTweet(tw1); |
|||
client.addTweet(tw3); |
|||
var actual = client.remove(tw1); |
|||
assertEquals(7, actual); |
|||
} |
|||
@Test |
|||
void testRemove3() { |
|||
client.addTweet(tw1); |
|||
client.addTweet(tw3); |
|||
client.remove(tw1); |
|||
var actual = client.contains(tw1); |
|||
assertEquals(false, actual); |
|||
} |
|||
@Test |
|||
void testRemove4() { |
|||
client.addTweet(tw1); |
|||
client.addTweet(tw3); |
|||
client.remove(tw1); |
|||
var actual = client.getNrOfWords("271895613"); |
|||
assertEquals(7, actual); |
|||
} |
|||
|
|||
@Test |
|||
void testPostTweets1a() { |
|||
var actual = client.postTweets(null); |
|||
assertEquals(0,actual); |
|||
} |
|||
@Test |
|||
void testPostTweets1b() { |
|||
var actual = client.postTweets(this.defaultConnector); |
|||
assertEquals(0,actual); |
|||
} |
|||
|
|||
@Test |
|||
void testPostTweets2a() { |
|||
client.addTweet(tw1); |
|||
var actual = client.postTweets(this.defaultConnector); |
|||
assertEquals(0,actual); |
|||
} |
|||
@Test |
|||
void testPostTweets2b() { |
|||
client.addTweet(tw1); |
|||
client.postTweets(this.defaultConnector); |
|||
var actual = client.getNrOfWords(); |
|||
assertEquals(6,actual); |
|||
} |
|||
@Test |
|||
void testPostTweets3a() { |
|||
client.addTweet(tw1); |
|||
var actual = client.postTweets(this.connector); |
|||
assertEquals(6,actual); |
|||
} |
|||
@Test |
|||
void testPostTweets3b() { |
|||
client.addTweet(tw1); |
|||
client.postTweets(this.connector); |
|||
var actual = client.getNrOfWords("271895613"); |
|||
assertEquals(0,actual); |
|||
} |
|||
@Test |
|||
void testPostTweets3c() { |
|||
client.addTweet(tw1); |
|||
client.postTweets(this.connector); |
|||
var actual = client.contains(tw1); |
|||
assertEquals(false,actual); |
|||
} |
|||
@Test |
|||
void testPostTweets3d() { |
|||
client.addTweet(tw1); |
|||
client.postTweets(this.connector); |
|||
var actual = client.getNrOfWords(tw1.getUser()); |
|||
assertEquals(0,actual); |
|||
} |
|||
@Test |
|||
void size() { |
|||
} |
|||
} |
@ -0,0 +1,88 @@ |
|||
package G2_solution; |
|||
|
|||
import G2.ATweetGenerator; |
|||
import twitter.TweetObject; |
|||
|
|||
import java.util.*; |
|||
import java.util.stream.Collectors; |
|||
|
|||
public class TweetGenerator extends ATweetGenerator { |
|||
|
|||
private Set<TweetObject> tweetObjects; |
|||
private Map<String, Integer> wordMap; |
|||
|
|||
public TweetGenerator() { |
|||
tweetObjects = new HashSet<>(); |
|||
wordMap = new HashMap<>(); |
|||
} |
|||
|
|||
@Override |
|||
public TweetObject addTweetCSV(String csvTweed) { |
|||
if(csvTweed == null) {return null;} |
|||
String[] parts = csvTweed.split(";"); |
|||
if(parts.length != 4) {return null;} |
|||
TweetObject tweetObject = new TweetObject(parts[0], parts[1], parts[2]); |
|||
tweetObject.setUser(parts[3]); |
|||
tweetObject.setTags(super.extractTags(parts[2])); |
|||
return tweetObject; |
|||
} |
|||
|
|||
|
|||
@Override |
|||
public int addTweet(TweetObject tweet) { |
|||
if(tweet == null) {return 0;} |
|||
if(tweet.getText().length() == 0) {return 0;} |
|||
if(this.tweetObjects.add(tweet)) { |
|||
String[] parts = tweet.getText().split(" "); |
|||
Integer wordCount = this.wordMap.get(tweet.getUser()); |
|||
if(wordCount == null) {wordCount = 0;} |
|||
this.wordMap.put(tweet.getUser(), wordCount + parts.length); |
|||
tweet.setWordCount(parts.length); |
|||
return parts.length; |
|||
} |
|||
else {return 0;} |
|||
} |
|||
|
|||
@Override |
|||
public int getNrOfWords() { |
|||
return this.wordMap.values().stream().collect(Collectors.summingInt(value -> value)); |
|||
} |
|||
|
|||
@Override |
|||
public int getNrOfWords(String user) { |
|||
Integer wordCount = this.wordMap.get(user); |
|||
if(wordCount == null) {wordCount = 0;} |
|||
return wordCount; |
|||
} |
|||
|
|||
@Override |
|||
public boolean contains(TweetObject tweet) { |
|||
return this.tweetObjects.contains(tweet); |
|||
} |
|||
|
|||
@Override |
|||
public int remove(TweetObject tweet) { |
|||
Integer wordCount = 0; |
|||
if(this.tweetObjects.remove(tweet)) { |
|||
String user = tweet.getUser(); |
|||
wordCount = this.wordMap.get(user) - tweet.getWordCount(); |
|||
this.wordMap.put(user,wordCount); |
|||
|
|||
} |
|||
return wordCount; |
|||
} |
|||
|
|||
@Override |
|||
public int postTweets(ITwitterConnector connector) { |
|||
if(connector==null) return 0; |
|||
if(connector.testConnection()){ |
|||
if(connector.postTweets(this.tweetObjects)){ |
|||
int nrOfWords = getNrOfWords(); |
|||
this.tweetObjects.clear(); |
|||
this.wordMap.clear(); |
|||
return nrOfWords; |
|||
}; |
|||
} |
|||
return 0; |
|||
} |
|||
} |
@ -0,0 +1,11 @@ |
|||
package G2_solution; |
|||
|
|||
import G2.ATweetGenerator; |
|||
import G2.ATweetGeneratorTest; |
|||
|
|||
public class TweetGeneratorTest extends ATweetGeneratorTest { |
|||
@Override |
|||
protected ATweetGenerator getInstance() { |
|||
return new TweetGenerator(); |
|||
} |
|||
} |
@ -0,0 +1,15 @@ |
|||
package twitter; |
|||
|
|||
import org.junit.jupiter.api.BeforeEach; |
|||
|
|||
public abstract class AbstractTestClass<T> { |
|||
protected T testObject; |
|||
|
|||
protected abstract T getInstance(); |
|||
|
|||
@BeforeEach |
|||
void setUp() { |
|||
testObject = getInstance(); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,86 @@ |
|||
package twitter; |
|||
|
|||
import java.util.Date; |
|||
import java.util.LinkedList; |
|||
import java.util.List; |
|||
|
|||
public class TweetObject { |
|||
private String id; |
|||
private String created_at; |
|||
private String text; |
|||
private String user; |
|||
private int wordCount; |
|||
private List<String> tags; |
|||
|
|||
public TweetObject() {} |
|||
|
|||
public TweetObject(String id, String created_at, String text) { |
|||
this.id = id; |
|||
this.created_at = created_at; |
|||
this.text = text; |
|||
this.tags = new LinkedList<>(); |
|||
} |
|||
|
|||
public String getId() { |
|||
return id; |
|||
} |
|||
|
|||
public void setId(String id) { |
|||
this.id = id; |
|||
} |
|||
|
|||
public String getCreated_at() { |
|||
return created_at; |
|||
} |
|||
|
|||
public void setCreated_at(String created_at) { |
|||
this.created_at = created_at; |
|||
} |
|||
|
|||
public String getText() { |
|||
return text; |
|||
} |
|||
|
|||
public void setText(String text) { |
|||
this.text = text; |
|||
} |
|||
|
|||
public String getUser() { |
|||
return user; |
|||
} |
|||
|
|||
public void setUser(String user) { |
|||
this.user = user; |
|||
} |
|||
|
|||
public int getWordCount() {return wordCount;} |
|||
|
|||
public void setWordCount(int wordCount) {this.wordCount = wordCount;} |
|||
|
|||
public List<String> getTags() { |
|||
return tags; |
|||
} |
|||
|
|||
public void setTags(List<String> tags) { |
|||
this.tags.addAll(tags); |
|||
} |
|||
|
|||
public void addTag(String tag) {this.tags.add(tag);} |
|||
|
|||
@Override |
|||
public boolean equals(Object obj) { |
|||
if(obj == null) {return false;} |
|||
if(obj instanceof TweetObject) { |
|||
TweetObject that = (TweetObject) obj; |
|||
return this.id.equals(that.id); |
|||
} |
|||
return false; |
|||
} |
|||
|
|||
@Override |
|||
public String toString() { |
|||
return id + ';' + created_at + ';' + text + ';' + user; |
|||
} |
|||
} |
|||
|
|||
|
@ -0,0 +1,17 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<projectDescription> |
|||
<name>2022-SS Testate</name> |
|||
<comment></comment> |
|||
<projects> |
|||
</projects> |
|||
<buildSpec> |
|||
<buildCommand> |
|||
<name>org.eclipse.jdt.core.javabuilder</name> |
|||
<arguments> |
|||
</arguments> |
|||
</buildCommand> |
|||
</buildSpec> |
|||
<natures> |
|||
<nature>org.eclipse.jdt.core.javanature</nature> |
|||
</natures> |
|||
</projectDescription> |
Binary file not shown.
Binary file not shown.
@ -0,0 +1,34 @@ |
|||
package base; |
|||
|
|||
import java.util.Objects; |
|||
|
|||
public class GasStation { |
|||
private String name; |
|||
private int id; |
|||
|
|||
public GasStation(String name, int id) { |
|||
this.name = name; |
|||
this.id = id; |
|||
} |
|||
|
|||
public String getName() { |
|||
return name; |
|||
} |
|||
|
|||
public int getId() { |
|||
return id; |
|||
} |
|||
|
|||
@Override |
|||
public boolean equals(Object o) { |
|||
if(this == o) { return true; } |
|||
if(o == null || getClass() != o.getClass()) { return false; } |
|||
GasStation station = (GasStation) o; |
|||
return id == station.id; |
|||
} |
|||
|
|||
@Override |
|||
public int hashCode() { |
|||
return Objects.hash(id); |
|||
} |
|||
} |
@ -0,0 +1,34 @@ |
|||
package base; |
|||
|
|||
import java.util.Objects; |
|||
|
|||
public class Person { |
|||
private String name; |
|||
private int id; |
|||
|
|||
public Person(String name, int id) { |
|||
this.name = name; |
|||
this.id = id; |
|||
} |
|||
|
|||
public String getName() { |
|||
return name; |
|||
} |
|||
|
|||
public int getId() { |
|||
return id; |
|||
} |
|||
|
|||
@Override |
|||
public boolean equals(Object o) { |
|||
if(this == o) { return true; } |
|||
if(o == null || getClass() != o.getClass()) { return false; } |
|||
Person student = (Person) o; |
|||
return id == student.id; |
|||
} |
|||
|
|||
@Override |
|||
public int hashCode() { |
|||
return Objects.hash(id); |
|||
} |
|||
} |
@ -0,0 +1,12 @@ |
|||
package base; |
|||
|
|||
public class Vaccination { |
|||
|
|||
private int id; |
|||
private String title; |
|||
|
|||
public Vaccination(int id, String title) { |
|||
this.id = id; |
|||
this.title = title; |
|||
} |
|||
} |
@ -0,0 +1,65 @@ |
|||
package solution_1; |
|||
|
|||
import base.Person; |
|||
import base.Vaccination; |
|||
import testat_1.ADigitalVaccinationRegister; |
|||
|
|||
import java.util.*; |
|||
import java.util.function.Consumer; |
|||
|
|||
public class DigitalVaccinationRegister extends ADigitalVaccinationRegister { |
|||
|
|||
private Map<Person, Set<Vaccination>> register = new HashMap<>(); |
|||
|
|||
@Override |
|||
public int size() { |
|||
return register.size(); |
|||
} |
|||
|
|||
@Override |
|||
public boolean add(Person person, Vaccination vaccination) { |
|||
if(person == null || vaccination == null) {return false;} |
|||
var vaccinationSet = register.get(person); |
|||
if(vaccinationSet == null) { |
|||
vaccinationSet = new HashSet<>(); |
|||
register.put(person, vaccinationSet); |
|||
} |
|||
return vaccinationSet.add(vaccination); |
|||
} |
|||
|
|||
@Override |
|||
public int contains(Person person) { |
|||
var vaccinationSet = register.get(person); |
|||
if(vaccinationSet == null) {return 0;} |
|||
return vaccinationSet.size(); |
|||
} |
|||
|
|||
@Override |
|||
public boolean contains(Person person, Vaccination vaccination) { |
|||
var vaccinationSet = register.get(person); |
|||
if(vaccinationSet == null) {return false;} |
|||
return vaccinationSet.contains(vaccination); |
|||
} |
|||
|
|||
@Override |
|||
public Collection<Vaccination> get(Person person) { |
|||
return register.get(person); |
|||
} |
|||
|
|||
@Override |
|||
public boolean remove(Person person, Vaccination vaccination) { |
|||
var vaccinationSet = register.get(person); |
|||
if(vaccinationSet == null) {return false;} |
|||
return vaccinationSet.remove(vaccination); |
|||
} |
|||
|
|||
@Override |
|||
public Collection<Vaccination> remove(Person person) { |
|||
return register.remove(person); |
|||
} |
|||
|
|||
@Override |
|||
public void forEach(Consumer<Collection<Vaccination>> consumer) { |
|||
if(consumer != null) {register.values().forEach(consumer);} |
|||
} |
|||
} |
@ -0,0 +1,11 @@ |
|||
package solution_1; |
|||
|
|||
import testat_1.ADigitalVaccinationRegister; |
|||
import testat_1.ADigitalVaccinationRegisterTest; |
|||
|
|||
public class DigitalVaccinationRegisterTest extends ADigitalVaccinationRegisterTest { |
|||
@Override |
|||
protected ADigitalVaccinationRegister getInstance() { |
|||
return new DigitalVaccinationRegister(); |
|||
} |
|||
} |
@ -0,0 +1,79 @@ |
|||
package solution_2; |
|||
|
|||
import base.GasStation; |
|||
|
|||
import java.util.*; |
|||
import java.util.function.Predicate; |
|||
|
|||
public class LowPriceFinder extends testat_2.ALowPriceFinder { |
|||
|
|||
private static class Entry { |
|||
GasStation station; |
|||
int avgPrice; |
|||
|
|||
public Entry(GasStation station, int avgPrice) { |
|||
this.station = station; |
|||
this.avgPrice = avgPrice; |
|||
} |
|||
} |
|||
|
|||
private Comparator<Entry> comparator = Comparator.comparingInt(e -> e.avgPrice); |
|||
|
|||
private List<Entry> list; |
|||
|
|||
public LowPriceFinder(int maxSize) { |
|||
super(maxSize); |
|||
list = new ArrayList<>(); |
|||
} |
|||
|
|||
@Override |
|||
public int size() { |
|||
return list.size(); |
|||
} |
|||
|
|||
@Override |
|||
public int size(Predicate<GasStation> predicate) { |
|||
return (int) list.stream().filter(e -> predicate.test(e.station)).count(); |
|||
} |
|||
|
|||
@Override |
|||
public int add(GasStation station, int averagePrice) { |
|||
if(station == null || averagePrice <= 0) {return 0;} |
|||
int rank = this.contains(station); |
|||
if(rank > 0) {this.list.get(rank - 1).avgPrice = averagePrice;} |
|||
else {list.add(new Entry(station, averagePrice));} |
|||
list.sort(comparator); |
|||
if(list.size() > maxSize) {list.remove(maxSize);} |
|||
return contains(station); |
|||
} |
|||
|
|||
@Override |
|||
public Collection<GasStation> getStations(int threshold) { |
|||
Set<GasStation> stationSet = new HashSet<>(); |
|||
for(Entry e : list) { |
|||
if(e.avgPrice <= threshold) {stationSet.add(e.station);} |
|||
} |
|||
return stationSet; |
|||
} |
|||
|
|||
|
|||
@Override |
|||
public int contains(GasStation station) { |
|||
for(int i = 0; i < list.size(); i++) { |
|||
if(list.get(i).station.equals(station)) {return i + 1;} |
|||
} |
|||
return 0; |
|||
} |
|||
|
|||
@Override |
|||
public int remove(GasStation station) { |
|||
int rank = this.contains(station); |
|||
if(rank > 0) {this.list.remove(rank - 1);} |
|||
return rank; |
|||
} |
|||
|
|||
@Override |
|||
public GasStation get(int rank) { |
|||
return list.get(rank - 1).station; |
|||
} |
|||
} |
@ -0,0 +1,11 @@ |
|||
package solution_2; |
|||
|
|||
import testat_2.ALowPriceFinder; |
|||
import testat_2.ALowPriceFinderTest; |
|||
|
|||
public class LowPriceFinderTest extends ALowPriceFinderTest { |
|||
@Override |
|||
protected ALowPriceFinder getInstance() { |
|||
return new LowPriceFinder(5); |
|||
} |
|||
} |
@ -0,0 +1,53 @@ |
|||
package testat_1; |
|||
|
|||
import base.Person; |
|||
import base.Vaccination; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.function.Consumer; |
|||
|
|||
public abstract class ADigitalVaccinationRegister { |
|||
|
|||
// Anzahl an gespeicherter Personen (mit mindestens einer Impfung)
|
|||
public abstract int size(); |
|||
|
|||
// Fügt zur Person person die Impfung vaccination hinzu, falls Person
|
|||
// != null und vaccination != null ist. Die Impfung wird nur einmal hinzugefüg
|
|||
// Rückgabe: True falls Impfung hinzugefügt, false sonst
|
|||
// Beachten Sie: Ein Person kann nur einmal enthalten sein
|
|||
public abstract boolean add(Person person, Vaccination vaccination); |
|||
|
|||
// Fügt alle Impfungen der Collection vaccinations zum Person Person hinzu, sofern sie noch
|
|||
// nicht enthalten waren.
|
|||
// Rückgabe: Anzahl an hinzugefügter Impfungen
|
|||
public int addAll(Person person, Collection<Vaccination> vaccinations) { |
|||
int counter = 0; |
|||
for(Vaccination v : vaccinations) { |
|||
if(this.add(person, v)) {counter++;} |
|||
} |
|||
return counter; |
|||
} |
|||
|
|||
// Anzahl Impfungen, die Person person erhalten hat. Rückabe 0, falls Person nicht enthalten ist
|
|||
public abstract int contains(Person person); |
|||
|
|||
// True: Person hat Impfung vaccination erhalten
|
|||
// False sonst
|
|||
public abstract boolean contains(Person person, Vaccination vaccination); |
|||
|
|||
|
|||
// Rückgabe; Collection, die alle Impfungen der Person person enthält
|
|||
// Sind zu Person person keine Impfungen enthalten, wird null zurückgegeben
|
|||
public abstract Collection<Vaccination> get(Person person); |
|||
|
|||
// Löscht die Impfung vaccination der Person person aus der zugeordneten Collection
|
|||
// Rückgabe = True falls Impfung erfolgreich entfernt wurde, false sonst
|
|||
public abstract boolean remove(Person person, Vaccination vaccination); |
|||
|
|||
// Löscht Person person aus der Collection
|
|||
// Rückgabe = Alle Impfungen der Person person
|
|||
public abstract Collection<Vaccination> remove(Person person); |
|||
|
|||
// Wendet consumer.action() auf alle gespeicherten Impfungen an
|
|||
public abstract void forEach(Consumer<Collection<Vaccination>> consumer); |
|||
} |
@ -0,0 +1,301 @@ |
|||
package testat_1; |
|||
|
|||
import base.Person; |
|||
import base.Vaccination; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.function.Consumer; |
|||
|
|||
import static org.junit.jupiter.api.Assertions.assertEquals; |
|||
|
|||
public abstract class ADigitalVaccinationRegisterTest { |
|||
|
|||
Person s1 = new Person("person 1", 1); |
|||
Person s2 = new Person("person 2", 2); |
|||
Person s3 = new Person("person 3", 3); |
|||
Person s4 = new Person("person 4", 4); |
|||
Person s5 = new Person("person 1", 5); |
|||
|
|||
Vaccination l1 = new Vaccination(1, "influenza"); |
|||
Vaccination l2 = new Vaccination(2, "measls"); |
|||
Vaccination l3 = new Vaccination(3, "FSME"); |
|||
Vaccination l4 = new Vaccination(4, "SARS-CoV2"); |
|||
Vaccination l5 = new Vaccination(5, "smallpox"); |
|||
|
|||
|
|||
ADigitalVaccinationRegister register; |
|||
private int counter; |
|||
private Consumer<Collection<Vaccination>> action = c -> { |
|||
counter += c.size(); |
|||
}; |
|||
|
|||
@org.junit.jupiter.api.BeforeEach |
|||
void setUp() { |
|||
register = getInstance(); |
|||
counter = 0; |
|||
} |
|||
|
|||
protected abstract ADigitalVaccinationRegister getInstance(); |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add1a() { |
|||
var actual = register.add(null, l1); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
void add1b() { |
|||
var actual = register.add(s1, null); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2a() { |
|||
var actual = register.add(s1, l1); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2b() { |
|||
register.add(s1, l1); |
|||
var actual = register.add(s1, l2); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2c() { |
|||
register.add(s1, l1); |
|||
var actual = register.add(s1, l1); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2d() { |
|||
addPersons(); |
|||
var actual = register.add(s4, l1); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2e() { |
|||
addPersons(); |
|||
var actual = register.add(s1, l4); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void size1() { |
|||
var actual = register.size(); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void size2() { |
|||
addPersons(); |
|||
var actual = register.size(); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
private void addPersons() { |
|||
register.add(s3, l1); |
|||
register.add(s2, l1); |
|||
register.add(s1, l1); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains1a() { |
|||
var actual = register.contains(s1, null); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains1b() { |
|||
var actual = register.contains(s1, l1); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains2a() { |
|||
addPersons(); |
|||
var actual = register.contains(s1, l1); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains2b() { |
|||
addPersons(); |
|||
var actual = register.contains(s1, l2); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains2c() { |
|||
addPersons(); |
|||
register.add(s1, l5); |
|||
var actual = register.contains(s1, l5); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains3a() { |
|||
var actual = register.contains(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains3b() { |
|||
var actual = register.contains(s1); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains4a() { |
|||
addPersons(); |
|||
var actual = register.contains(s1); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains4b() { |
|||
addPersons(); |
|||
register.add(s1, l4); |
|||
var actual = register.contains(s1); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void get1() { |
|||
var actual = register.get(s1); |
|||
assertEquals(null, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void get2a() { |
|||
addPersons(); |
|||
var actual = register.get(s1); |
|||
assertEquals(1, actual.size()); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void get2b() { |
|||
addPersons(); |
|||
register.add(s1, l4); |
|||
var actual = register.get(s1); |
|||
assertEquals(2, actual.size()); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void get2c() { |
|||
addPersons(); |
|||
register.add(s1, l4); |
|||
var actual = register.get(s1); |
|||
assertEquals(true, actual.contains(l1)); |
|||
assertEquals(true, actual.contains(l4)); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove1() { |
|||
var actual = register.remove(s1); |
|||
assertEquals(null, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove2a() { |
|||
addPersons(); |
|||
var actual = register.remove(s1); |
|||
assertEquals(1, actual.size()); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove2b() { |
|||
addPersons(); |
|||
register.remove(s2); |
|||
var actual = register.contains(s2); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove2c() { |
|||
addPersons(); |
|||
register.remove(s1); |
|||
var actual = register.contains(s2); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove3() { |
|||
addPersons(); |
|||
register.add(s1, l2); |
|||
var actual = register.remove(s1); |
|||
assertEquals(2, actual.size()); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void removeVaccination1a() { |
|||
var actual = register.remove(s1, null); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void removeVaccination1b() { |
|||
var actual = register.remove(s1, l1); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void removeVaccination2a() { |
|||
addPersons(); |
|||
var actual = register.remove(s1, l1); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void removeVaccination2b() { |
|||
addPersons(); |
|||
var actual = register.remove(s1, l2); |
|||
assertEquals(false, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void removeVaccination2c() { |
|||
addPersons(); |
|||
register.add(s1, l5); |
|||
var actual = register.remove(s1, l5); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void removeVaccination3() { |
|||
addPersons(); |
|||
register.add(s1, l5); |
|||
register.remove(s1, l5); |
|||
var actual = register.contains(s1, l5); |
|||
assertEquals(false, actual); |
|||
actual = register.contains(s1, l1); |
|||
assertEquals(true, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void ferEach1a() { |
|||
register.forEach(null); |
|||
var actual = 0; |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void ferEach1b() { |
|||
register.forEach(this.action); |
|||
var actual = counter; |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void ferEach2a() { |
|||
addPersons(); |
|||
register.forEach(this.action); |
|||
var actual = counter; |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,48 @@ |
|||
package testat_2; |
|||
|
|||
import base.GasStation; |
|||
|
|||
import java.util.Collection; |
|||
import java.util.function.Predicate; |
|||
|
|||
public abstract class ALowPriceFinder { |
|||
protected int maxSize; |
|||
|
|||
public ALowPriceFinder(int maxSize) {this.maxSize = maxSize;} |
|||
|
|||
// Anzahl an gespeicherten Tankstellen
|
|||
public abstract int size(); |
|||
|
|||
// Liefert die GasStation auf Rang rank (Rang 1 = bester Platz)
|
|||
public abstract GasStation get(int rank); |
|||
|
|||
// Liefert den Rang von GasStation.
|
|||
// Ist GasStation nicht enthalten, wird 0 zurückgegeben
|
|||
// Hinweis: Platz 1 bedeutet Rang 1
|
|||
public abstract int contains(GasStation station); |
|||
|
|||
// Fügt die GasStation station mit Durchschnittspreis averagePrice hinzu, falls GasStation !=
|
|||
// null und averagePrice > 0.
|
|||
// Ist sie schon enthalten, wird der Preis auf averagePrice gesetzt
|
|||
// Sind maxSize GasStations enthalten, wird die neue GasStation nur aufgenommen, wenn sie
|
|||
// nicht der letzte in der Liste ist (wenn sie nicht den größten averagePrice hat)
|
|||
// In diesem Fall wird die letzte GasStation gelöscht (sodass nicht mehr als maxGasStation
|
|||
// in der Liste sind) und der neue GasStation aufgenommen
|
|||
// Rückgabe: Rang in der HighaveragePrice-Liste; 0, falls der GasStation nicht hinzugefügt wurde
|
|||
// Hinweis: Zur Vereinfachung sind alle averagePrice-Werte ungleich
|
|||
// Beachten Sie: Ein GasStation kann nur einmal enthalten sein
|
|||
public abstract int add(GasStation GasStation, int averagePrice); |
|||
|
|||
// Liefert eine Collection von Tankstellen (GasStation), deren averagePrice <= threshold ist
|
|||
// Rückgabe: Collection, ggf. leer (nicht null)
|
|||
public abstract Collection<GasStation> getStations(int threshold); |
|||
|
|||
|
|||
// Löscht den GasStation GasStation aus der Liste.
|
|||
// Rückgabe = Rang der GasStation, (0, falls GasStation nicht enthalten)
|
|||
public abstract int remove(GasStation station); |
|||
|
|||
// Anzahl an gespeicherter Tankstellen, die das Predicate predicate erfüllen
|
|||
public abstract int size(Predicate<GasStation> predicate); |
|||
|
|||
} |
@ -0,0 +1,325 @@ |
|||
package testat_2; |
|||
|
|||
import base.GasStation; |
|||
|
|||
import java.util.function.Predicate; |
|||
|
|||
import static org.junit.jupiter.api.Assertions.assertEquals; |
|||
|
|||
public abstract class ALowPriceFinderTest { |
|||
|
|||
GasStation p1 = new GasStation("Aral Amtzell", 1); |
|||
GasStation p2 = new GasStation("Aral Weingarten", 2); |
|||
GasStation p3 = new GasStation("Jet Weingarten", 3); |
|||
GasStation p4 = new GasStation("Shell Ravensburg", 4); |
|||
GasStation p5 = new GasStation("Shell Weingarten", 5); |
|||
GasStation p6 = new GasStation("Shell Wurzach", 6); |
|||
|
|||
ALowPriceFinder hs; |
|||
private int counter; |
|||
private Predicate<GasStation> predicate = gasStation -> gasStation.getId() < 3; |
|||
|
|||
@org.junit.jupiter.api.BeforeEach |
|||
void setUp() { |
|||
hs = getInstance(); |
|||
} |
|||
|
|||
protected abstract ALowPriceFinder getInstance(); |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add1a() { |
|||
var actual = hs.add(null, 10); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add1b() { |
|||
var actual = hs.add(p1, 0); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add1c() { |
|||
var actual = hs.add(p1, -1); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2a() { |
|||
var actual = hs.add(p1, 10); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2b() { |
|||
hs.add(p1, 10); |
|||
var actual = hs.add(p1, 11); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2c() { |
|||
hs.add(p1, 10); |
|||
var actual = hs.add(p2, 9); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2d() { |
|||
hs.add(p1, 10); |
|||
hs.add(p2, 20); |
|||
var actual = hs.add(p1, 30); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add2e() { |
|||
hs.add(p2, 5); |
|||
hs.add(p1, 10); |
|||
var actual = hs.add(p1, 2); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add3() { |
|||
hs.add(p3, 5); |
|||
hs.add(p2, 7); |
|||
var actual = hs.add(p1, 1); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add4() { |
|||
addStations(); |
|||
var actual = hs.add(p4, 40); |
|||
assertEquals(4, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add5a() { |
|||
addStations(); |
|||
hs.add(p4, 9); |
|||
hs.add(p1, 40); |
|||
var actual = hs.add(p1, 1); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add6a() { |
|||
addStations(); |
|||
hs.add(p4, 40); |
|||
hs.add(p5, 50); // Liste ist voll
|
|||
var actual = hs.add(p6, 60); // neue Tanke wäre letzte
|
|||
assertEquals(0, actual); // nicht aufnehmen
|
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add6b() { |
|||
addStations(); |
|||
hs.add(p4, 40); |
|||
hs.add(p5, 50); // Liste ist voll
|
|||
var actual = hs.add(p6, 45); // neue Tanke ist vorletzte
|
|||
assertEquals(5, actual); // aufnehmen
|
|||
actual = hs.contains(p5); |
|||
assertEquals(0, actual); // p5 ist rausgeflogen
|
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void add6c() { |
|||
addStations(); |
|||
hs.add(p4, 40); |
|||
hs.add(p5, 50); |
|||
var actual = hs.add(p1, 45); |
|||
assertEquals(4, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void size1() { |
|||
var actual = hs.size(); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void size2() { |
|||
addStations(); |
|||
var actual = hs.size(); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void size3() { |
|||
addStations(); |
|||
hs.add(p4, 1); |
|||
hs.add(p1, 8); |
|||
hs.add(p1, 2); |
|||
var actual = hs.size(); |
|||
assertEquals(4, actual); |
|||
} |
|||
|
|||
private void addStations() { |
|||
hs.add(p3, 30); |
|||
hs.add(p2, 20); |
|||
hs.add(p1, 10); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains1() { |
|||
var actual = hs.contains(p1); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains2() { |
|||
addStations(); |
|||
var actual = hs.contains(p1); |
|||
assertEquals(1, actual); |
|||
actual = hs.contains(p2); |
|||
assertEquals(2, actual); |
|||
actual = hs.contains(p3); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains3() { |
|||
addStations(); |
|||
hs.add(p4, 2); |
|||
hs.add(p5, 1); |
|||
var actual = hs.contains(p4); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains4a() { |
|||
addStations(); |
|||
hs.add(p4, 19); |
|||
var actual = hs.contains(p4); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void contains4b() { |
|||
addStations(); |
|||
hs.add(p4, 11); |
|||
hs.add(p1, 30); |
|||
var actual = hs.contains(p4); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void get1() { |
|||
addStations(); |
|||
var actual = hs.get(1); |
|||
assertEquals(p1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void get2() { |
|||
addStations(); |
|||
var actual = hs.get(3); |
|||
assertEquals(p3, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove1() { |
|||
var actual = hs.remove(p1); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove2a() { |
|||
addStations(); |
|||
var actual = hs.remove(p1); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove2b() { |
|||
addStations(); |
|||
hs.remove(p2); |
|||
var actual = hs.contains(p2); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove2c() { |
|||
addStations(); |
|||
hs.remove(p1); |
|||
var actual = hs.contains(p2); |
|||
assertEquals(1, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove3a() { |
|||
addStations(); |
|||
hs.add(p4, 1); |
|||
var actual = hs.remove(p1); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void remove3b() { |
|||
addStations(); |
|||
hs.add(p4, 25); |
|||
var actual = hs.remove(p4); |
|||
assertEquals(3, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void sizePred1a() { |
|||
var actual = hs.size(null); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
void sizePred1b() { |
|||
var actual = hs.size(predicate); |
|||
assertEquals(0, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void sizePred2a() { |
|||
addStations(); |
|||
hs.add(p4, 7); |
|||
hs.add(p5, 19); |
|||
var actual = hs.size(predicate); |
|||
assertEquals(2, actual); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void getStations1a() { |
|||
var actual = hs.getStations(0); |
|||
assertEquals(0, actual.size()); |
|||
} |
|||
|
|||
void getStations1b() { |
|||
var actual = hs.getStations(25); |
|||
assertEquals(0, actual.size()); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void getStations2a() { |
|||
addStations(); |
|||
hs.add(p4, 7); |
|||
hs.add(p5, 31); |
|||
var actual = hs.getStations(21); |
|||
assertEquals(3, actual.size()); |
|||
} |
|||
|
|||
@org.junit.jupiter.api.Test |
|||
void getStations2b() { |
|||
addStations(); |
|||
hs.add(p4, 7); |
|||
hs.add(p5, 31); |
|||
var stationCollection = hs.getStations(21); |
|||
var actual = stationCollection.contains(p1); |
|||
assertEquals(true, actual); |
|||
actual = stationCollection.contains(p2); |
|||
assertEquals(true, actual); |
|||
actual = stationCollection.contains(p4); |
|||
assertEquals(true, actual); |
|||
actual = stationCollection.contains(p3); |
|||
assertEquals(false, actual); |
|||
actual = stationCollection.contains(p5); |
|||
assertEquals(false, actual); |
|||
} |
|||
} |
|||
|
@ -0,0 +1,12 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<module type="JAVA_MODULE" version="4"> |
|||
<component name="NewModuleRootManager" inherit-compiler-output="true"> |
|||
<exclude-output /> |
|||
<content url="file://$MODULE_DIR$"> |
|||
<sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" /> |
|||
</content> |
|||
<orderEntry type="inheritedJdk" /> |
|||
<orderEntry type="sourceFolder" forTests="false" /> |
|||
<orderEntry type="library" name="junit.jupiter" level="project" /> |
|||
</component> |
|||
</module> |
@ -0,0 +1,17 @@ |
|||
<component name="libraryTable"> |
|||
<library name="junit.jupiter" type="repository"> |
|||
<properties maven-id="org.junit.jupiter:junit-jupiter:5.8.0" /> |
|||
<CLASSES> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter/5.8.0/junit-jupiter-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-api/5.8.0/junit-jupiter-api-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/opentest4j/opentest4j/1.2.0/opentest4j-1.2.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/platform/junit-platform-commons/1.8.0/junit-platform-commons-1.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/apiguardian/apiguardian-api/1.1.2/apiguardian-api-1.1.2.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-params/5.8.0/junit-jupiter-params-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/jupiter/junit-jupiter-engine/5.8.0/junit-jupiter-engine-5.8.0.jar!/" /> |
|||
<root url="jar://$MAVEN_REPOSITORY$/org/junit/platform/junit-platform-engine/1.8.0/junit-platform-engine-1.8.0.jar!/" /> |
|||
</CLASSES> |
|||
<JAVADOC /> |
|||
<SOURCES /> |
|||
</library> |
|||
</component> |
@ -0,0 +1,9 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="MarkdownSettings"> |
|||
<enabledExtensions> |
|||
<entry key="MermaidLanguageExtension" value="false" /> |
|||
<entry key="PlantUMLLanguageExtension" value="false" /> |
|||
</enabledExtensions> |
|||
</component> |
|||
</project> |
@ -0,0 +1,6 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="ProjectRootManager" version="2" languageLevel="JDK_11" default="true" project-jdk-name="11" project-jdk-type="JavaSDK"> |
|||
<output url="file://$PROJECT_DIR$/classes" /> |
|||
</component> |
|||
</project> |
@ -0,0 +1,8 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="ProjectModuleManager"> |
|||
<modules> |
|||
<module fileurl="file://$PROJECT_DIR$/.idea/SimpleArrayMap.iml" filepath="$PROJECT_DIR$/.idea/SimpleArrayMap.iml" /> |
|||
</modules> |
|||
</component> |
|||
</project> |
@ -0,0 +1,6 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="VcsDirectoryMappings"> |
|||
<mapping directory="$PROJECT_DIR$/.." vcs="Git" /> |
|||
</component> |
|||
</project> |
@ -0,0 +1,44 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<project version="4"> |
|||
<component name="AutoImportSettings"> |
|||
<option name="autoReloadType" value="SELECTIVE" /> |
|||
</component> |
|||
<component name="ChangeListManager"> |
|||
<list default="true" id="82cca40d-6a74-4c74-97be-88548b3f41df" name="Changes" comment="" /> |
|||
<option name="SHOW_DIALOG" value="false" /> |
|||
<option name="HIGHLIGHT_CONFLICTS" value="true" /> |
|||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" /> |
|||
<option name="LAST_RESOLUTION" value="IGNORE" /> |
|||
</component> |
|||
<component name="Git.Settings"> |
|||
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$/.." /> |
|||
</component> |
|||
<component name="MarkdownSettingsMigration"> |
|||
<option name="stateVersion" value="1" /> |
|||
</component> |
|||
<component name="ProjectId" id="2FS5DB4h1ZHgsFjtInThNWkKFeC" /> |
|||
<component name="ProjectLevelVcsManager" settingsEditedManually="true" /> |
|||
<component name="ProjectViewState"> |
|||
<option name="hideEmptyMiddlePackages" value="true" /> |
|||
<option name="showLibraryContents" value="true" /> |
|||
</component> |
|||
<component name="PropertiesComponent"> |
|||
<property name="RunOnceActivity.OpenProjectViewOnStart" value="true" /> |
|||
<property name="RunOnceActivity.ShowReadmeOnStart" value="true" /> |
|||
<property name="last_opened_file_path" value="$PROJECT_DIR$/../SimpleLinkedList" /> |
|||
<property name="project.structure.last.edited" value="Project" /> |
|||
<property name="project.structure.proportion" value="0.15" /> |
|||
<property name="project.structure.side.proportion" value="0.2" /> |
|||
</component> |
|||
<component name="SpellCheckerSettings" RuntimeDictionaries="0" Folders="0" CustomDictionaries="0" DefaultDictionary="application-level" UseSingleDictionary="true" transferred="true" /> |
|||
<component name="TaskManager"> |
|||
<task active="true" id="Default" summary="Default task"> |
|||
<changelist id="82cca40d-6a74-4c74-97be-88548b3f41df" name="Changes" comment="" /> |
|||
<created>1664472523385</created> |
|||
<option name="number" value="Default" /> |
|||
<option name="presentableId" value="Default" /> |
|||
<updated>1664472523385</updated> |
|||
</task> |
|||
<servers /> |
|||
</component> |
|||
</project> |
@ -0,0 +1,4 @@ |
|||
package src.testat; |
|||
|
|||
public class SimpleArrayMap { |
|||
} |
Loading…
Reference in new issue