http-service: fix test. irritatingly can't make slf4j-simple the only slf4j implementation during tests
This commit is contained in:
@@ -78,6 +78,7 @@
|
|||||||
<groupId>com.commongroundpublishing</groupId>
|
<groupId>com.commongroundpublishing</groupId>
|
||||||
<artifactId>slf4j-servletcontext</artifactId>
|
<artifactId>slf4j-servletcontext</artifactId>
|
||||||
<version>1.0.0</version>
|
<version>1.0.0</version>
|
||||||
|
<scope>runtime</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|||||||
@@ -24,6 +24,7 @@
|
|||||||
*/
|
*/
|
||||||
package net.runelite.http.service;
|
package net.runelite.http.service;
|
||||||
|
|
||||||
|
import com.commongroundpublishing.slf4j.impl.ServletContextLogger;
|
||||||
import com.google.gson.Gson;
|
import com.google.gson.Gson;
|
||||||
import com.google.inject.Guice;
|
import com.google.inject.Guice;
|
||||||
import com.google.inject.Injector;
|
import com.google.inject.Injector;
|
||||||
@@ -33,6 +34,7 @@ import com.google.inject.testing.fieldbinder.BoundFieldModule;
|
|||||||
import java.io.InputStreamReader;
|
import java.io.InputStreamReader;
|
||||||
import java.net.HttpURLConnection;
|
import java.net.HttpURLConnection;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
import javax.servlet.ServletContext;
|
||||||
import javax.sql.DataSource;
|
import javax.sql.DataSource;
|
||||||
import net.runelite.http.api.hiscore.HiscoreResult;
|
import net.runelite.http.api.hiscore.HiscoreResult;
|
||||||
import net.runelite.http.api.hiscore.Skill;
|
import net.runelite.http.api.hiscore.Skill;
|
||||||
@@ -43,6 +45,7 @@ import org.junit.Before;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.mockito.Answers;
|
import org.mockito.Answers;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import spark.Spark;
|
import spark.Spark;
|
||||||
@@ -50,18 +53,18 @@ import spark.Spark;
|
|||||||
public class ServiceTest
|
public class ServiceTest
|
||||||
{
|
{
|
||||||
private static final String URL_BASE = "http://localhost:4567";
|
private static final String URL_BASE = "http://localhost:4567";
|
||||||
|
|
||||||
private Service service;
|
private Service service;
|
||||||
|
|
||||||
@Bind
|
@Bind
|
||||||
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
|
||||||
@Named("Runelite JDBC")
|
@Named("Runelite JDBC")
|
||||||
private DataSource dataSource;
|
private DataSource dataSource;
|
||||||
|
|
||||||
@Bind
|
@Bind
|
||||||
@Mock
|
@Mock
|
||||||
private HiscoreService hiscoreService;
|
private HiscoreService hiscoreService;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void before()
|
public void before()
|
||||||
{
|
{
|
||||||
@@ -70,36 +73,38 @@ public class ServiceTest
|
|||||||
// Inject everything in the test object
|
// Inject everything in the test object
|
||||||
Injector injector = Guice.createInjector(BoundFieldModule.of(this));
|
Injector injector = Guice.createInjector(BoundFieldModule.of(this));
|
||||||
injector.injectMembers(this);
|
injector.injectMembers(this);
|
||||||
|
|
||||||
|
ServletContextLogger.setServletContext(mock(ServletContext.class));
|
||||||
|
|
||||||
service = injector.getInstance(Service.class);
|
service = injector.getInstance(Service.class);
|
||||||
service.setupRoutes();
|
service.setupRoutes();
|
||||||
|
|
||||||
Spark.awaitInitialization();
|
Spark.awaitInitialization();
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
public void after()
|
public void after()
|
||||||
{
|
{
|
||||||
Spark.stop();
|
Spark.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInit() throws Exception
|
public void testInit() throws Exception
|
||||||
{
|
{
|
||||||
HiscoreResult result = new HiscoreResult();
|
HiscoreResult result = new HiscoreResult();
|
||||||
result.setAttack(new Skill(1, 99, 42));
|
result.setAttack(new Skill(1, 99, 42));
|
||||||
|
|
||||||
when(hiscoreService.lookup("zezima")).thenReturn(result);
|
when(hiscoreService.lookup("zezima")).thenReturn(result);
|
||||||
|
|
||||||
URL url = new URL(URL_BASE + "/hiscore?username=zezima");
|
URL url = new URL(URL_BASE + "/hiscore?username=zezima");
|
||||||
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
|
||||||
connection.setRequestMethod("GET");
|
connection.setRequestMethod("GET");
|
||||||
connection.connect();
|
connection.connect();
|
||||||
|
|
||||||
Gson gson = new Gson();
|
Gson gson = new Gson();
|
||||||
HiscoreResult res = gson.fromJson(new InputStreamReader(connection.getInputStream()), HiscoreResult.class);
|
HiscoreResult res = gson.fromJson(new InputStreamReader(connection.getInputStream()), HiscoreResult.class);
|
||||||
|
|
||||||
Assert.assertEquals(result, res);
|
Assert.assertEquals(result, res);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user