reorganize tests
This commit is contained in:
parent
70a1da8c8c
commit
97473c4aae
7 changed files with 118 additions and 9 deletions
|
@ -1,4 +1,4 @@
|
||||||
package eu.m724.wtapi;
|
package eu.m724.wtapi.object;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package eu.m724.wtapi;
|
package eu.m724.wtapi.thunder;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ import eu.m724.wtapi.object.Coordinates;
|
||||||
import eu.m724.wtapi.thunder.ThunderProvider;
|
import eu.m724.wtapi.thunder.ThunderProvider;
|
||||||
import eu.m724.wtapi.thunder.impl.lightningmaps.LightningMapsProvider;
|
import eu.m724.wtapi.thunder.impl.lightningmaps.LightningMapsProvider;
|
||||||
|
|
||||||
public class TestLM {
|
public class LightningMapsTest {
|
||||||
@Test
|
@Test
|
||||||
public void lightningMapsTest() throws InterruptedException {
|
public void lightningMapsTest() throws InterruptedException {
|
||||||
ArrayList<Coordinates> coordinatesList = new ArrayList<>();
|
ArrayList<Coordinates> coordinatesList = new ArrayList<>();
|
||||||
|
@ -28,6 +28,7 @@ public class TestLM {
|
||||||
}
|
}
|
||||||
|
|
||||||
System.out.printf("Strikes in the last 10s: %d\n", coordinatesList.size());
|
System.out.printf("Strikes in the last 10s: %d\n", coordinatesList.size());
|
||||||
|
if (coordinatesList.size() > 0) // lightningmaps can be unreliable
|
||||||
System.out.printf("%f %f", coordinatesList.get(0).latitude, coordinatesList.get(0).longitude);
|
System.out.printf("%f %f", coordinatesList.get(0).latitude, coordinatesList.get(0).longitude);
|
||||||
|
|
||||||
}
|
}
|
73
src/test/java/eu/m724/wtapi/thunder/MockThunderProvider.java
Normal file
73
src/test/java/eu/m724/wtapi/thunder/MockThunderProvider.java
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
package eu.m724.wtapi.thunder;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
|
import eu.m724.wtapi.object.Coordinates;
|
||||||
|
import eu.m724.wtapi.provider.exception.ProviderException;
|
||||||
|
import eu.m724.wtapi.thunder.ThunderProvider;
|
||||||
|
import eu.m724.wtapi.thunder.impl.lightningmaps.TimedStrike;
|
||||||
|
|
||||||
|
public class MockThunderProvider extends ThunderProvider {
|
||||||
|
ArrayList<Consumer<Coordinates>> strikeHandlers = new ArrayList<>();
|
||||||
|
ArrayList<TimedStrike> strikes = new ArrayList<>();
|
||||||
|
Random rnd = new Random();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void init() throws ProviderException {
|
||||||
|
System.out.println("mock thunder init");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void start() throws ProviderException {
|
||||||
|
System.out.println("mock thunder start");
|
||||||
|
|
||||||
|
long now = System.currentTimeMillis();
|
||||||
|
|
||||||
|
for (int i=0; i<40; i++) {
|
||||||
|
strikes.add(new TimedStrike(now + i * 100,
|
||||||
|
new Coordinates(
|
||||||
|
rnd.nextDouble(-90, 90),
|
||||||
|
rnd.nextDouble(-180, 180)
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void stop() {
|
||||||
|
System.out.println("mock thunder stop");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void tick() {
|
||||||
|
long now = System.currentTimeMillis();
|
||||||
|
|
||||||
|
while (strikes.size() > 0) {
|
||||||
|
TimedStrike str = strikes.get(0);
|
||||||
|
if (now > str.timestamp) {
|
||||||
|
System.out.printf("mock thunder given: %d\n", str.timestamp);
|
||||||
|
strikeHandlers.forEach(con -> con.accept(str.coordinates));
|
||||||
|
strikes.remove(0);
|
||||||
|
} else break;
|
||||||
|
}
|
||||||
|
System.out.println("mock thunder tick");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void registerStrikeHandler(Consumer<Coordinates> runnable) {
|
||||||
|
strikeHandlers.add(runnable);
|
||||||
|
System.out.println("mock thunder strike handler added");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getDelay() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return 10000;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
36
src/test/java/eu/m724/wtapi/thunder/ThunderProviderTest.java
Normal file
36
src/test/java/eu/m724/wtapi/thunder/ThunderProviderTest.java
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
package eu.m724.wtapi.thunder;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import eu.m724.wtapi.object.Coordinates;
|
||||||
|
import eu.m724.wtapi.thunder.ThunderProvider;
|
||||||
|
|
||||||
|
public class ThunderProviderTest {
|
||||||
|
@Test
|
||||||
|
public void testThunderProvider() throws InterruptedException {
|
||||||
|
ArrayList<Coordinates> coordinatesList = new ArrayList<>();
|
||||||
|
|
||||||
|
ThunderProvider provider = new MockThunderProvider();
|
||||||
|
|
||||||
|
provider.registerStrikeHandler(coordinates ->
|
||||||
|
coordinatesList.add(coordinates));
|
||||||
|
|
||||||
|
provider.init();
|
||||||
|
|
||||||
|
provider.start();
|
||||||
|
|
||||||
|
for (int i=0; i < 50; i++) {
|
||||||
|
provider.tick();
|
||||||
|
Thread.sleep(50);
|
||||||
|
}
|
||||||
|
|
||||||
|
provider.stop();
|
||||||
|
|
||||||
|
System.out.printf("Strikes in the last 5s: %d\n", coordinatesList.size());
|
||||||
|
System.out.printf("%f %f", coordinatesList.get(0).latitude, coordinatesList.get(0).longitude);
|
||||||
|
|
||||||
|
assert coordinatesList.size() == 25;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package eu.m724.wtapi.impl;
|
package eu.m724.wtapi.weather;
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
import eu.m724.wtapi.object.Coordinates;
|
import eu.m724.wtapi.object.Coordinates;
|
|
@ -1,4 +1,4 @@
|
||||||
package eu.m724.wtapi;
|
package eu.m724.wtapi.weather;
|
||||||
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ import eu.m724.wtapi.object.Weather;
|
||||||
import eu.m724.wtapi.provider.WeatherProvider;
|
import eu.m724.wtapi.provider.WeatherProvider;
|
||||||
import eu.m724.wtapi.provider.impl.openweathermap.OpenWeatherMapProvider;
|
import eu.m724.wtapi.provider.impl.openweathermap.OpenWeatherMapProvider;
|
||||||
|
|
||||||
public class TestOWM {
|
public class OpenWeatherMapTest {
|
||||||
@Test
|
@Test
|
||||||
public void openWeatherMapTest() throws InterruptedException, ExecutionException {
|
public void openWeatherMapTest() throws InterruptedException, ExecutionException {
|
||||||
String apiKey = "f3198d2a4ae3076e0aa47c821a253447";
|
String apiKey = "f3198d2a4ae3076e0aa47c821a253447";
|
|
@ -1,4 +1,4 @@
|
||||||
package eu.m724.wtapi;
|
package eu.m724.wtapi.weather;
|
||||||
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.junit.Assert.assertNull;
|
import static org.junit.Assert.assertNull;
|
||||||
|
@ -10,7 +10,6 @@ import java.util.concurrent.ExecutionException;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import eu.m724.wtapi.impl.MockWeatherProvider;
|
|
||||||
import eu.m724.wtapi.object.Coordinates;
|
import eu.m724.wtapi.object.Coordinates;
|
||||||
import eu.m724.wtapi.object.Weather;
|
import eu.m724.wtapi.object.Weather;
|
||||||
import eu.m724.wtapi.provider.WeatherProvider;
|
import eu.m724.wtapi.provider.WeatherProvider;
|
Loading…
Reference in a new issue