Added tests about http access logs.
This commit is contained in:
parent
3ca13aad0c
commit
33455ae54f
12 changed files with 2268 additions and 0 deletions
|
@ -0,0 +1,97 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2021-2024 Christian Pierre MOMON <christian@momon.org>
|
||||||
|
*
|
||||||
|
* This file is part of StatoolInfos, simple key value database.
|
||||||
|
*
|
||||||
|
* StatoolInfos is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* StatoolInfos 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 Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with StatoolInfos. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package fr.devinsy.statoolinfos.metrics.httpaccess;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.Level;
|
||||||
|
import org.apache.logging.log4j.core.config.Configurator;
|
||||||
|
import org.apache.logging.log4j.core.config.DefaultConfiguration;
|
||||||
|
import org.junit.AfterClass;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import fr.devinsy.statoolinfos.core.StatoolInfosException;
|
||||||
|
import fr.devinsy.statoolinfos.util.Files;
|
||||||
|
import fr.devinsy.statoolinfos.util.FilesUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Class HttpAccessLogIteratorTest.
|
||||||
|
*/
|
||||||
|
public class HttpAccessLogIteratorTest
|
||||||
|
{
|
||||||
|
private static org.slf4j.Logger logger = org.slf4j.LoggerFactory.getLogger(HttpAccessLogIteratorTest.class);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test 01.
|
||||||
|
*
|
||||||
|
* @throws Exception
|
||||||
|
* the exception
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void test01() throws Exception
|
||||||
|
{
|
||||||
|
System.out.println(System.getProperty("user.dir"));
|
||||||
|
|
||||||
|
String source = "./test/fr/devinsy/statoolinfos/metrics/httpaccess/data/lseu/www*";
|
||||||
|
Files files = FilesUtils.searchByWildcard(source);
|
||||||
|
for (File file : files)
|
||||||
|
{
|
||||||
|
System.out.println(file);
|
||||||
|
}
|
||||||
|
HttpAccessLogs logs = new HttpAccessLogs(files);
|
||||||
|
HttpAccessLogIterator iterator = (HttpAccessLogIterator) logs.iterator();
|
||||||
|
while (iterator.hasNext())
|
||||||
|
{
|
||||||
|
HttpAccessLog log = iterator.next();
|
||||||
|
// System.out.println(log.toStringLog());
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println(iterator.getLogCount());
|
||||||
|
System.out.println(iterator.getFailedLogCount());
|
||||||
|
|
||||||
|
Assert.assertEquals(7146, iterator.getLogCount());
|
||||||
|
Assert.assertEquals(0, iterator.getFailedLogCount());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* After class.
|
||||||
|
*
|
||||||
|
* @throws StatoolInfosException
|
||||||
|
* the Juga exception
|
||||||
|
*/
|
||||||
|
@AfterClass
|
||||||
|
public static void afterClass() throws StatoolInfosException
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Before class.
|
||||||
|
*
|
||||||
|
* @throws StatoolInfosException
|
||||||
|
* the Juga exception
|
||||||
|
*/
|
||||||
|
@BeforeClass
|
||||||
|
public static void beforeClass() throws StatoolInfosException
|
||||||
|
{
|
||||||
|
Configurator.initialize(new DefaultConfiguration());
|
||||||
|
Configurator.setRootLevel(Level.DEBUG);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,131 @@
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2021-2024 Christian Pierre MOMON <christian@momon.org>
|
||||||
|
*
|
||||||
|
* This file is part of StatoolInfos, simple key value database.
|
||||||
|
*
|
||||||
|
* StatoolInfos is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* StatoolInfos 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 Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with StatoolInfos. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
package fr.devinsy.statoolinfos.metrics.httpaccess;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.Level;
|
||||||
|
import org.apache.logging.log4j.core.config.Configurator;
|
||||||
|
import org.apache.logging.log4j.core.config.DefaultConfiguration;
|
||||||
|
import org.junit.AfterClass;
|
||||||
|
import org.junit.Assert;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import fr.devinsy.statoolinfos.core.Configuration;
|
||||||
|
import fr.devinsy.statoolinfos.core.StatoolInfosException;
|
||||||
|
import fr.devinsy.statoolinfos.metrics.PathCounters;
|
||||||
|
import fr.devinsy.statoolinfos.metrics.Prober;
|
||||||
|
import fr.devinsy.statoolinfos.util.Files;
|
||||||
|
import fr.devinsy.statoolinfos.util.FilesUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Class HttpAccessLogsAnalyzerTest.
|
||||||
|
*/
|
||||||
|
public class HttpAccessLogsAnalyzerTest
|
||||||
|
{
|
||||||
|
private static org.slf4j.Logger logger = org.slf4j.LoggerFactory.getLogger(HttpAccessLogsAnalyzerTest.class);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void test01() throws Exception
|
||||||
|
{
|
||||||
|
// System.out.println(System.getProperty("user.dir"));
|
||||||
|
|
||||||
|
Files files = FilesUtils.searchByWildcard("./test/fr/devinsy/statoolinfos/metrics/httpaccess/data/lseu/www*");
|
||||||
|
// for (File file : files)
|
||||||
|
// {
|
||||||
|
// System.out.println(file);
|
||||||
|
// }
|
||||||
|
HttpAccessLogs logs = new HttpAccessLogs(files);
|
||||||
|
|
||||||
|
PathCounters counters = HttpAccessLogAnalyzer.probe(logs);
|
||||||
|
|
||||||
|
// for (String prefix : counters.getPrefixes())
|
||||||
|
// {
|
||||||
|
// System.out.println(prefix);
|
||||||
|
// }
|
||||||
|
|
||||||
|
System.out.println("Prefix count: " + counters.getPrefixes().size());
|
||||||
|
|
||||||
|
Assert.assertEquals(41, counters.getPrefixes().size());
|
||||||
|
Assert.assertEquals(1035, counters.getCount("metrics.http.hits", "2022-11"));
|
||||||
|
Assert.assertEquals(1031, counters.getCount("metrics.http.hits", "2022-W44"));
|
||||||
|
Assert.assertEquals(964, counters.getCount("metrics.http.hits", "2022-11-01"));
|
||||||
|
Assert.assertEquals(1016, counters.getCount("metrics.http.hits", "2023-01"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @throws Exception
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void test02() throws Exception
|
||||||
|
{
|
||||||
|
// System.out.println(System.getProperty("user.dir"));
|
||||||
|
|
||||||
|
Configuration configuration = new Configuration();
|
||||||
|
configuration.add("conf.probe.types", "HttpAccessLog");
|
||||||
|
configuration.add("conf.probe.httpaccesslog.file", "./test/fr/devinsy/statoolinfos/metrics/httpaccess/data/lseu/www*");
|
||||||
|
// configuration.add("conf.probe.httperrorlog.pattern", "");
|
||||||
|
// configuration.add("conf.probe.httperrorlog.dateTimePattern", "");
|
||||||
|
|
||||||
|
PathCounters counters = Prober.probeHttpAccessLog(configuration);
|
||||||
|
|
||||||
|
// for (String counter : counters.keySet())
|
||||||
|
// {
|
||||||
|
// System.out.println(counter + " " +
|
||||||
|
// counters.get(counter).getCounter());
|
||||||
|
// }
|
||||||
|
|
||||||
|
Assert.assertEquals(983, counters.size());
|
||||||
|
|
||||||
|
//
|
||||||
|
Assert.assertEquals(2056, counters.getCount("metrics.http.hits", "2022"));
|
||||||
|
Assert.assertEquals(1035, counters.getCount("metrics.http.hits", "2022-11"));
|
||||||
|
Assert.assertEquals(1031, counters.getCount("metrics.http.hits", "2022-W44"));
|
||||||
|
Assert.assertEquals(964, counters.getCount("metrics.http.hits", "2022-11-01"));
|
||||||
|
|
||||||
|
Assert.assertEquals(",,,,,,,,,,1035,1021", counters.getMonthsValuesLine("metrics.http.hits", "2022"));
|
||||||
|
Assert.assertEquals(",,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,1031,,4,,1021,,,,1014", counters.getWeeksValuesLine("metrics.http.hits", "2022"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* After class.
|
||||||
|
*
|
||||||
|
* @throws StatoolInfosException
|
||||||
|
* the Juga exception
|
||||||
|
*/
|
||||||
|
@AfterClass
|
||||||
|
public static void afterClass() throws StatoolInfosException
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Before class.
|
||||||
|
*
|
||||||
|
* @throws StatoolInfosException
|
||||||
|
* the Juga exception
|
||||||
|
*/
|
||||||
|
@BeforeClass
|
||||||
|
public static void beforeClass() throws StatoolInfosException
|
||||||
|
{
|
||||||
|
Configurator.initialize(new DefaultConfiguration());
|
||||||
|
Configurator.setRootLevel(Level.DEBUG);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
From Apache server.
|
||||||
|
|
||||||
|
Anonymize with Logar.
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
@ -0,0 +1 @@
|
||||||
|
10.222.42.55 - - [01/Dec/2021:01:01:03 +0100] "GET /.well-known/statoolinfos/libre-service.eu.properties HTTP/1.1" 200 6387 "-" "Java/11.0.13"
|
Loading…
Reference in a new issue