statoolinfos/test/fr/devinsy/statoolinfos/metrics/http/VisitCountersTest.java

277 lines
9.9 KiB
Java

/*
* Copyright (C) 2021 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.http;
import java.time.LocalDateTime;
import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;
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.metrics.PathCounter;
import fr.devinsy.statoolinfos.metrics.PathCounters;
/**
* The Class VisitCountersTest.
*/
public class VisitCountersTest
{
private static org.slf4j.Logger logger = org.slf4j.LoggerFactory.getLogger(VisitCountersTest.class);
/**
* Test 01.
*
* @throws Exception
* the exception
*/
@Test
public void test01() throws Exception
{
VisitCounters visitCounters = new VisitCounters();
//
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setTime(LocalDateTime.of(2020, 10, 20, 23, 0));
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
visitCounters.putVisit(log);
//
visitCounters.storeTimeMarks("2020-10");
PathCounters counters = visitCounters.getCounters("metrics.aaa");
for (PathCounter counter : counters.values())
{
logger.info(counter.getPath() + " " + counter.getTimeMark() + " " + counter.getCounter());
}
Assert.assertEquals(1, counters.size());
Assert.assertEquals(1, counters.get("metrics.aaa", "2020-10").getCounter());
}
/**
* Test 02.
*
* @throws Exception
* the exception
*/
@Test
public void test02() throws Exception
{
VisitCounters visitCounters = new VisitCounters();
//
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 0));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 20));
visitCounters.putVisit(log);
}
//
visitCounters.storeTimeMarks("2020-10");
PathCounters counters = visitCounters.getCounters("metrics.aaa");
for (PathCounter counter : counters.values())
{
logger.info(counter.getPath() + " " + counter.getTimeMark() + " " + counter.getCounter());
}
Assert.assertEquals(1, counters.size());
Assert.assertEquals(1, counters.get("metrics.aaa", "2020-10").getCounter());
}
/**
* Test 03.
*
* @throws Exception
* the exception
*/
@Test
public void test03() throws Exception
{
VisitCounters visitCounters = new VisitCounters();
//
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 0));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 20));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 55));
visitCounters.putVisit(log);
}
//
visitCounters.storeTimeMarks("2020-10");
PathCounters counters = visitCounters.getCounters("metrics.aaa");
for (PathCounter counter : counters.values())
{
logger.info(counter.getPath() + " " + counter.getTimeMark() + " " + counter.getCounter());
}
Assert.assertEquals(1, counters.size());
Assert.assertEquals(2, counters.get("metrics.aaa", "2020-10").getCounter());
}
/**
* Test 04.
*
* @throws Exception
* the exception
*/
@Test
public void test04() throws Exception
{
VisitCounters visitCounters = new VisitCounters();
//
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 0));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 55));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 20));
visitCounters.putVisit(log);
}
//
visitCounters.storeTimeMarks("2020-10");
PathCounters counters = visitCounters.getCounters("metrics.aaa");
for (PathCounter counter : counters.values())
{
logger.info(counter.getPath() + " " + counter.getTimeMark() + " " + counter.getCounter());
}
Assert.assertEquals(1, counters.size());
Assert.assertEquals(2, counters.get("metrics.aaa", "2020-10").getCounter());
}
/**
* Test 05.
*
* @throws Exception
* the exception
*/
@Test
public void test05() throws Exception
{
VisitCounters visitCounters = new VisitCounters();
//
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 0));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 35));
visitCounters.putVisit(log);
}
{
HttpAccessLog log = new HttpAccessLog();
log.setRemoteAddress("192.168.1.1");
log.setUserAgent(new UserAgent("Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.117 Safari/537.36"));
log.setTime(LocalDateTime.of(2020, 10, 20, 12, 20));
visitCounters.putVisit(log);
}
//
visitCounters.storeTimeMarks("2020-10");
PathCounters counters = visitCounters.getCounters("metrics.aaa");
for (PathCounter counter : counters.values())
{
logger.info(counter.getPath() + " " + counter.getTimeMark() + " " + counter.getCounter());
}
Assert.assertEquals(1, counters.size());
Assert.assertEquals(1, counters.get("metrics.aaa", "2020-10").getCounter());
}
/**
* 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
{
BasicConfigurator.configure();
Logger.getRootLogger().setLevel(Level.DEBUG);
}
}