kopia lustrzana https://github.com/bertrik/ttnhabbridge
124 wiersze
4.5 KiB
Java
124 wiersze
4.5 KiB
Java
package nl.sikken.bertrik.hab.habitat;
|
|
|
|
import java.io.IOException;
|
|
import java.time.Instant;
|
|
import java.util.Arrays;
|
|
|
|
import org.junit.Ignore;
|
|
import org.junit.Test;
|
|
import org.mockito.Mockito;
|
|
|
|
import nl.sikken.bertrik.hab.Sentence;
|
|
import retrofit2.mock.Calls;
|
|
|
|
/**
|
|
* Unit tests for HabitatUploader.
|
|
*/
|
|
public final class HabitatUploaderTest {
|
|
|
|
private static final Location LOCATION = new Location(52.0162, 4.4735, 5.0);
|
|
|
|
/**
|
|
* Happy flow scenario for payload upload.
|
|
* @throws IOException
|
|
*/
|
|
@Test
|
|
public void testUploadPayload() throws IOException {
|
|
// create a mocked rest client
|
|
final IHabitatRestApi restClient = Mockito.mock(IHabitatRestApi.class);
|
|
Mockito.when(restClient.updateListener(Mockito.anyString(), Mockito.anyString()))
|
|
.thenReturn(Calls.response("OK"));
|
|
Mockito.when(restClient.getUuids(Mockito.anyInt()))
|
|
.thenReturn(Calls.response(new UuidsList(Arrays.asList("uuid1", "uuid2"))));
|
|
|
|
final HabitatUploader uploader = new HabitatUploader(restClient);
|
|
|
|
// verify upload using the uploader
|
|
uploader.start();
|
|
try {
|
|
final HabReceiver receiver = new HabReceiver("BERTRIK", LOCATION);
|
|
final Instant instant = Instant.now();
|
|
final Sentence sentence = new Sentence("NOTAFLIGHT", 1, instant, 52.0182307, 4.695772, 1000);
|
|
|
|
uploader.schedulePayloadTelemetryUpload(sentence.format(), Arrays.asList(receiver), instant);
|
|
Mockito.verify(restClient, Mockito.timeout(3000).times(1)).updateListener(Mockito.anyString(),
|
|
Mockito.anyString());
|
|
} finally {
|
|
uploader.stop();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Happy flow scenario for listener upload.
|
|
*/
|
|
@Test
|
|
public void testUploadListener() {
|
|
// create a mocked rest client
|
|
final IHabitatRestApi restClient = Mockito.mock(IHabitatRestApi.class);
|
|
Mockito.when(restClient.getUuids(Mockito.anyInt()))
|
|
.thenReturn(Calls.response(new UuidsList(Arrays.asList("uuid1", "uuid2"))));
|
|
Mockito.when(restClient.uploadDocument(Mockito.anyString(), Mockito.anyString()))
|
|
.thenReturn(Calls.response(new UploadResult(true, "id", "rev")));
|
|
|
|
final HabitatUploader uploader = new HabitatUploader(restClient);
|
|
|
|
// verify upload using the uploader
|
|
uploader.start();
|
|
try {
|
|
final HabReceiver receiver = new HabReceiver("BERTRIK", LOCATION);
|
|
final Instant instant = Instant.now();
|
|
|
|
uploader.scheduleListenerDataUpload(receiver, instant);
|
|
|
|
// expect two documents
|
|
Mockito.verify(restClient, Mockito.timeout(3000).times(2)).uploadDocument(Mockito.anyString(),
|
|
Mockito.anyString());
|
|
} finally {
|
|
uploader.stop();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Verifies upload of payload telemetry to the actual habitat server on the internet.
|
|
*
|
|
* @throws InterruptedException in case the sleep got interrupted
|
|
*/
|
|
@Test
|
|
@Ignore("this is not a junit test")
|
|
public void testActualPayloadUpload() throws InterruptedException {
|
|
final IHabitatRestApi restClient = HabitatUploader.newRestClient("http://habitat.habhub.org", 3000);
|
|
final HabitatUploader uploader = new HabitatUploader(restClient);
|
|
uploader.start();
|
|
try {
|
|
final Instant instant = Instant.now();
|
|
final Sentence sentence = new Sentence("NOTAFLIGHT", 1, instant, 52.0182307, 4.695772, 1000);
|
|
final HabReceiver receiver = new HabReceiver("BERTRIK", null);
|
|
uploader.schedulePayloadTelemetryUpload(sentence.format(), Arrays.asList(receiver), instant);
|
|
Thread.sleep(3000);
|
|
} finally {
|
|
uploader.stop();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Verifies upload of listener information and telemetry to the actual habitat server on the internet.
|
|
*
|
|
* @throws InterruptedException in case the sleep got interrupted
|
|
*/
|
|
@Test
|
|
@Ignore("this is not a junit test")
|
|
public void testActualListenerUpload() throws InterruptedException {
|
|
final IHabitatRestApi restClient = HabitatUploader.newRestClient("http://habitat.habhub.org", 3000);
|
|
final HabitatUploader uploader = new HabitatUploader(restClient);
|
|
try {
|
|
final Instant instant = Instant.now();
|
|
final HabReceiver receiver = new HabReceiver("BERTRIK", new Location(52.0182307, 4.695772, 15.0));
|
|
uploader.scheduleListenerDataUpload(receiver, instant);
|
|
Thread.sleep(3000);
|
|
} finally {
|
|
uploader.stop();
|
|
}
|
|
}
|
|
|
|
}
|