Moved Velocity tests to JUnit 5

This commit is contained in:
Rsl1122 2019-08-10 08:51:09 +03:00
parent cc8d7b8e9f
commit b1a299a9b2
3 changed files with 47 additions and 44 deletions

View File

@ -23,35 +23,31 @@ import com.djrapitops.plan.system.settings.config.PlanConfig;
import com.djrapitops.plan.system.settings.paths.ProxySettings; import com.djrapitops.plan.system.settings.paths.ProxySettings;
import com.djrapitops.plan.system.settings.paths.WebserverSettings; import com.djrapitops.plan.system.settings.paths.WebserverSettings;
import com.google.common.util.concurrent.MoreExecutors; import com.google.common.util.concurrent.MoreExecutors;
import org.junit.ClassRule; import org.junit.jupiter.api.Test;
import org.junit.Test; import org.junit.jupiter.api.io.TempDir;
import org.junit.rules.TemporaryFolder; import org.junit.platform.runner.JUnitPlatform;
import org.junit.runner.RunWith; import org.junit.runner.RunWith;
import org.mockito.junit.MockitoJUnitRunner;
import rules.ComponentMocker;
import rules.VelocityComponentMocker;
import utilities.RandomData; import utilities.RandomData;
import utilities.mocks.VelocityMockComponent;
import java.nio.file.Path;
import static org.junit.jupiter.api.Assertions.assertTrue;
import static org.junit.Assert.assertTrue;
/** /**
* Test for Velocity PlanSystem. * Test for Velocity PlanSystem.
* *
* @author Rsl1122 * @author Rsl1122
*/ */
@RunWith(MockitoJUnitRunner.Silent.class) @RunWith(JUnitPlatform.class)
public class VelocitySystemTest { public class VelocitySystemTest {
@ClassRule
public static TemporaryFolder temporaryFolder = new TemporaryFolder();
@ClassRule
public static ComponentMocker component = new VelocityComponentMocker(temporaryFolder);
private final int TEST_PORT_NUMBER = RandomData.randomInt(9005, 9500); private final int TEST_PORT_NUMBER = RandomData.randomInt(9005, 9500);
@Test @Test
public void velocityEnables() throws Exception { void velocityEnables(@TempDir Path temp) throws Exception {
PlanSystem velocitySystem = component.getPlanSystem(); PlanSystem velocitySystem = new VelocityMockComponent(temp).getPlanSystem();
try { try {
PlanConfig config = velocitySystem.getConfigSystem().getConfig(); PlanConfig config = velocitySystem.getConfigSystem().getConfig();
config.set(WebserverSettings.PORT, TEST_PORT_NUMBER); config.set(WebserverSettings.PORT, TEST_PORT_NUMBER);

View File

@ -19,16 +19,18 @@ package com.djrapitops.plan.system.tasks.velocity;
import com.djrapitops.plan.PlanVelocity; import com.djrapitops.plan.PlanVelocity;
import com.velocitypowered.api.proxy.Player; import com.velocitypowered.api.proxy.Player;
import com.velocitypowered.api.proxy.ProxyServer; import com.velocitypowered.api.proxy.ProxyServer;
import org.junit.Before; import org.junit.jupiter.api.BeforeEach;
import org.junit.Test; import org.junit.jupiter.api.Test;
import org.junit.platform.runner.JUnitPlatform;
import org.junit.runner.RunWith;
import org.mockito.Mockito; import org.mockito.Mockito;
import utilities.TestConstants; import utilities.TestConstants;
import utilities.mocks.PlanVelocityMocker; import utilities.mocks.PlanVelocityMocker;
import java.util.Optional; import java.util.Optional;
import static org.junit.Assert.assertFalse; import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.Assert.assertTrue; import static org.junit.jupiter.api.Assertions.assertTrue;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
/** /**
@ -36,13 +38,14 @@ import static org.mockito.Mockito.when;
* *
* @author Rsl1122 * @author Rsl1122
*/ */
@RunWith(JUnitPlatform.class)
public class PingCountTimerVelocityTest { public class PingCountTimerVelocityTest {
private PlanVelocity plugin; private PlanVelocity plugin;
private Player player; private Player player;
@Before @BeforeEach
public void setUp() { void setUp() {
PlanVelocityMocker mocker = PlanVelocityMocker.setUp() PlanVelocityMocker mocker = PlanVelocityMocker.setUp()
.withProxy(); .withProxy();
plugin = mocker.getPlanMock(); plugin = mocker.getPlanMock();
@ -56,7 +59,7 @@ public class PingCountTimerVelocityTest {
} }
@Test @Test
public void offlinePlayerIsRemovedFromPlayerHistory() { void offlinePlayerIsRemovedFromPlayerHistory() {
PingCountTimerVelocity counter = new PingCountTimerVelocity(plugin, null, null, null, null); PingCountTimerVelocity counter = new PingCountTimerVelocity(plugin, null, null, null, null);
assertTrue(counter.playerHistory.isEmpty()); assertTrue(counter.playerHistory.isEmpty());

View File

@ -14,42 +14,46 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Plan. If not, see <https://www.gnu.org/licenses/>. * along with Plan. If not, see <https://www.gnu.org/licenses/>.
*/ */
package rules; package utilities.mocks;
import com.djrapitops.plan.DaggerPlanVelocityComponent; import com.djrapitops.plan.DaggerPlanVelocityComponent;
import com.djrapitops.plan.PlanPlugin;
import com.djrapitops.plan.PlanVelocity; import com.djrapitops.plan.PlanVelocity;
import com.djrapitops.plan.PlanVelocityComponent; import com.djrapitops.plan.PlanVelocityComponent;
import com.djrapitops.plan.system.PlanSystem; import com.djrapitops.plan.system.PlanSystem;
import org.junit.rules.ExternalResource;
import org.junit.rules.TemporaryFolder;
import utilities.mocks.PlanVelocityMocker;
public class VelocityComponentMocker extends ExternalResource implements ComponentMocker { import java.nio.file.Path;
private final TemporaryFolder testFolder;
/**
* Test utility for creating a dagger PlanComponent using a mocked Plan.
*
* @author Rsl1122
*/
public class VelocityMockComponent {
private final Path tempDir;
private PlanVelocity planMock; private PlanVelocity planMock;
private PlanVelocityComponent component; private PlanVelocityComponent component;
public VelocityComponentMocker(TemporaryFolder testFolder) { public VelocityMockComponent(Path tempDir) {
this.testFolder = testFolder; this.tempDir = tempDir;
} }
@Override public PlanVelocity getPlanMock() throws Exception {
protected void before() throws Throwable { if (planMock == null) {
PlanVelocityMocker mocker = PlanVelocityMocker.setUp() planMock = PlanVelocityMocker.setUp()
.withDataFolder(testFolder.newFolder()) .withDataFolder(tempDir.toFile())
.withResourceFetchingFromJar() .withResourceFetchingFromJar()
.withProxy(); .withProxy()
planMock = mocker.getPlanMock(); .getPlanMock();
component = DaggerPlanVelocityComponent.builder().plan(planMock).build();
} }
public PlanPlugin getPlanMock() {
return planMock; return planMock;
} }
public PlanSystem getPlanSystem() { public PlanSystem getPlanSystem() throws Exception {
if (component == null) {
component = DaggerPlanVelocityComponent.builder().plan(getPlanMock()).build();
}
return component.system(); return component.system();
} }
} }