mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2024-12-21 05:50:18 +08:00
Fixed issues with peak player count query optimization
This commit is contained in:
parent
226bc20e3f
commit
776fa3327f
@ -216,16 +216,17 @@ public class TPSQueries {
|
||||
}
|
||||
|
||||
public static Query<Optional<DateObj<Integer>>> fetchPeakPlayerCount(ServerUUID serverUUID, long afterDate) {
|
||||
String subQuery = '(' + SELECT + DATE + ",MAX(" + PLAYERS_ONLINE + ") as " + PLAYERS_ONLINE + FROM + TABLE_NAME +
|
||||
String subQuery = '(' + SELECT + "MAX(" + PLAYERS_ONLINE + ") as " + PLAYERS_ONLINE + FROM + TABLE_NAME +
|
||||
WHERE + SERVER_ID + "=" + ServerTable.SELECT_SERVER_ID +
|
||||
AND + DATE + ">= ?)";
|
||||
AND + DATE + ">= ?" +
|
||||
GROUP_BY + SERVER_ID + ")";
|
||||
String sql = SELECT +
|
||||
"t." + DATE + ',' + "t." + PLAYERS_ONLINE +
|
||||
FROM + TABLE_NAME + " t" +
|
||||
INNER_JOIN + subQuery + " max on t." + DATE + "=max." + DATE + AND + "t." + PLAYERS_ONLINE + "=max." + PLAYERS_ONLINE +
|
||||
INNER_JOIN + subQuery + " max on t." + PLAYERS_ONLINE + "=max." + PLAYERS_ONLINE +
|
||||
WHERE + SERVER_ID + "=" + ServerTable.SELECT_SERVER_ID +
|
||||
AND + "t." + DATE + ">= ?" +
|
||||
ORDER_BY + DATE + " DESC LIMIT 1";
|
||||
ORDER_BY + "t." + DATE + " DESC LIMIT 1";
|
||||
|
||||
return new QueryStatement<>(sql) {
|
||||
@Override
|
||||
|
@ -0,0 +1,105 @@
|
||||
/*
|
||||
* This file is part of Player Analytics (Plan).
|
||||
*
|
||||
* Plan is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License v3 as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Plan is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
package com.djrapitops.plan.identification;
|
||||
|
||||
import com.djrapitops.plan.delivery.webserver.Addresses;
|
||||
import com.djrapitops.plan.exceptions.database.DBOpException;
|
||||
import com.djrapitops.plan.identification.properties.ServerProperties;
|
||||
import com.djrapitops.plan.identification.storage.ServerDBLoader;
|
||||
import com.djrapitops.plan.identification.storage.ServerFileLoader;
|
||||
import com.djrapitops.plan.processing.Processing;
|
||||
import com.djrapitops.plan.settings.config.PlanConfig;
|
||||
import com.djrapitops.plan.settings.locale.Locale;
|
||||
import com.djrapitops.plan.storage.database.DBSystem;
|
||||
import net.playeranalytics.plugin.server.PluginLogger;
|
||||
import org.junit.jupiter.api.AfterEach;
|
||||
import org.junit.jupiter.api.BeforeEach;
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.api.extension.ExtendWith;
|
||||
import org.mockito.InjectMocks;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.Spy;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
import utilities.TestConstants;
|
||||
import utilities.TestErrorLogger;
|
||||
import utilities.TestPluginLogger;
|
||||
import utilities.mocks.TestProcessing;
|
||||
|
||||
import java.util.Optional;
|
||||
import java.util.concurrent.CompletionException;
|
||||
import java.util.logging.Level;
|
||||
import java.util.logging.Logger;
|
||||
|
||||
import static org.mockito.ArgumentMatchers.any;
|
||||
import static org.mockito.Mockito.*;
|
||||
|
||||
/**
|
||||
* @author AuroraLS3
|
||||
*/
|
||||
@ExtendWith(MockitoExtension.class)
|
||||
class ServerServerInfoTest {
|
||||
|
||||
@Mock
|
||||
DBSystem dbSystem;
|
||||
@InjectMocks
|
||||
@Spy
|
||||
ServerDBLoader fromDatabase;
|
||||
|
||||
@Mock
|
||||
ServerProperties serverProperties;
|
||||
@Mock
|
||||
ServerFileLoader fromFile;
|
||||
@Mock
|
||||
PlanConfig config;
|
||||
@Mock
|
||||
Addresses addresses;
|
||||
@Mock
|
||||
Locale locale;
|
||||
@Spy
|
||||
PluginLogger logger = new TestPluginLogger();
|
||||
@Spy
|
||||
Processing processing = new TestProcessing(() -> locale, logger, new TestErrorLogger());
|
||||
|
||||
ServerServerInfo underTest;
|
||||
|
||||
@BeforeEach
|
||||
void setUp() {
|
||||
TestErrorLogger.throwErrors(false);
|
||||
underTest = new ServerServerInfo(
|
||||
TestConstants.VERSION,
|
||||
serverProperties, fromFile, fromDatabase, processing, config, addresses, locale, logger
|
||||
);
|
||||
when(fromFile.load(any())).thenReturn(Optional.of(new Server(1, TestConstants.SERVER_UUID, TestConstants.SERVER_NAME, "", false, TestConstants.VERSION)));
|
||||
}
|
||||
|
||||
@AfterEach
|
||||
void tearDown() {
|
||||
for (Throwable throwable : TestErrorLogger.getCaught()) {
|
||||
Logger.getGlobal().log(Level.WARNING, "test", throwable);
|
||||
}
|
||||
|
||||
TestErrorLogger.throwErrors(true);
|
||||
}
|
||||
|
||||
@Test
|
||||
void databaseThrowsErrorOnSave() {
|
||||
doThrow(new CompletionException(new DBOpException("Test exception")))
|
||||
.when(fromDatabase).save(any());
|
||||
underTest.loadServerInfo();
|
||||
verify(fromFile, times(0)).save(any());
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user