mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-06 15:44:49 +08:00
Moved Velocity tests to JUnit 5
This commit is contained in:
parent
cc8d7b8e9f
commit
b1a299a9b2
@ -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);
|
||||||
|
@ -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());
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user