This is an automated email from the ASF dual-hosted git repository.
ffang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/karaf.git
The following commit(s) were added to refs/heads/master by this push:
new 0511376 add EventLoggerTest back
0511376 is described below
commit 0511376286e855d83fed82cb0092bdf47c3091c1
Author: Freeman Fang <[email protected]>
AuthorDate: Thu Jul 5 14:53:28 2018 +0800
add EventLoggerTest back
---
.../apache/karaf/audit/logger/EventLoggerTest.java | 266 +++++++++++++++++++++
1 file changed, 266 insertions(+)
diff --git
a/audit/src/test/java/org/apache/karaf/audit/logger/EventLoggerTest.java
b/audit/src/test/java/org/apache/karaf/audit/logger/EventLoggerTest.java
new file mode 100644
index 0000000..dee4129
--- /dev/null
+++ b/audit/src/test/java/org/apache/karaf/audit/logger/EventLoggerTest.java
@@ -0,0 +1,266 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.apache.karaf.audit.logger;
+
+import org.apache.karaf.audit.Event;
+import org.apache.karaf.audit.EventLayout;
+import org.apache.karaf.audit.EventLogger;
+import org.apache.karaf.audit.MapEvent;
+import org.apache.karaf.audit.layout.GelfLayout;
+import org.apache.karaf.audit.layout.Rfc3164Layout;
+import org.apache.karaf.audit.layout.Rfc5424Layout;
+import org.junit.Test;
+
+import javax.management.ObjectName;
+import java.io.IOException;
+import java.net.DatagramPacket;
+import java.net.DatagramSocket;
+import java.net.InetSocketAddress;
+import java.net.ServerSocket;
+import java.net.Socket;
+import java.nio.charset.StandardCharsets;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Locale;
+import java.util.Map;
+import java.util.TimeZone;
+import java.util.concurrent.Executors;
+import java.util.concurrent.TimeUnit;
+import java.util.stream.Collectors;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
+
+public class EventLoggerTest {
+
+ private static final String INVOKE = "invoke";
+ private static final String[] INVOKE_SIG = new String[]
{ObjectName.class.getName(), String.class.getName(), Object[].class.getName(),
String[].class.getName()};
+
+ @Test
+ public void testUdp() throws Exception {
+ Map<String, Object> map = new HashMap<>();
+ map.put("type", Event.TYPE_JMX);
+ map.put("subtype", INVOKE);
+ map.put("method", INVOKE);
+ map.put("signature", INVOKE_SIG);
+ map.put("params", new Object[] { new
ObjectName("org.apache.karaf.Mbean:type=foo"), "myMethod", new Object[] {
String.class.getName() }, new String[] { "the-param "}});
+ Event event = new MapEvent(map, 1510902000000L);
+
+ int port = getNewPort();
+
+ DatagramSocket socket = new DatagramSocket(port);
+ List<DatagramPacket> packets = new ArrayList<>();
+ new Thread(() -> {
+ try {
+ DatagramPacket dp = new DatagramPacket(new byte[1024], 1024);
+ socket.receive(dp);
+ packets.add(dp);
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+
+ }).start();
+
+ Thread.sleep(100);
+
+ EventLayout layout = new Rfc3164Layout(16, 5,
Rfc5424Layout.DEFAULT_ENTERPRISE_NUMBER, TimeZone.getTimeZone("GMT+01:00"),
Locale.ENGLISH);
+ EventLogger logger = new UdpEventLogger("localhost", port, "UTF-8",
layout);
+ logger.write(event);
+
+ Thread.sleep(100);
+
+ assertEquals(1, packets.size());
+ DatagramPacket p = packets.get(0);
+ String str = new String(p.getData(), 0, p.getLength(),
StandardCharsets.UTF_8);
+ assertTrue(str.startsWith("<133>Nov 17 08:00:00 "));
+ assertTrue(str.endsWith(" jmx [jmx@18060 type=\"jmx\"
subtype=\"invoke\" method=\"invoke\" signature=\"[javax.management.ObjectName,
java.lang.String, [Ljava.lang.Object;, [Ljava.lang.String;\\]\"
params=\"[org.apache.karaf.Mbean:type=foo, myMethod, [java.lang.String\\],
[the-param \\]\\]\"]"));
+ System.out.println(str);
+ }
+
+ @Test
+ public void testTcp() throws Exception {
+ Map<String, Object> map = new HashMap<>();
+ map.put("type", Event.TYPE_JMX);
+ map.put("subtype", INVOKE);
+ map.put("method", INVOKE);
+ map.put("signature", INVOKE_SIG);
+ map.put("params", new Object[] { new
ObjectName("org.apache.karaf.Mbean:type=foo"), "myMethod", new Object[] {
String.class.getName() }, new String[] { "the-param "}});
+ Event event = new MapEvent(map, 1510902000000L);
+
+ int port = getNewPort();
+
+ List<String> packets = new ArrayList<>();
+ new Thread(() -> {
+ try (ServerSocket ssocket = new ServerSocket(port)) {
+ ssocket.setReuseAddress(true);
+ try (Socket socket = ssocket.accept()) {
+ byte[] buffer = new byte[1024];
+ int nb = socket.getInputStream().read(buffer);
+ packets.add(new String(buffer, 0, nb,
StandardCharsets.UTF_8));
+ }
+ } catch (IOException e) {
+ e.printStackTrace();
+ }
+
+ }).start();
+
+ Thread.sleep(100);
+
+ EventLayout layout = new Rfc5424Layout(16, 5,
Rfc5424Layout.DEFAULT_ENTERPRISE_NUMBER, TimeZone.getTimeZone("GMT+01:00"));
+ EventLogger logger = new TcpEventLogger("localhost", port, "UTF-8",
layout);
+ logger.write(event);
+ logger.flush();
+
+ Thread.sleep(100);
+
+ assertEquals(1, packets.size());
+ String str = packets.get(0);
+ System.out.println(str);
+ assertTrue(str.startsWith("<133>1 2017-11-17T08:00:00.000+01:00 "));
+ assertTrue(str.indexOf(" jmx [jmx@18060 type=\"jmx\"
subtype=\"invoke\" method=\"invoke\" signature=\"[javax.management.ObjectName,
java.lang.String, [Ljava.lang.Object;, [Ljava.lang.String;\\]\"
params=\"[org.apache.karaf.Mbean:type=foo, myMethod, [java.lang.String\\],
[the-param \\]\\]\"]") > 0);
+ }
+
+ @Test
+ public void testFile() throws Exception {
+ Map<String, Object> map = new HashMap<>();
+ map.put("type", Event.TYPE_JMX);
+ map.put("subtype", INVOKE);
+ map.put("method", INVOKE);
+ map.put("signature", INVOKE_SIG);
+ map.put("params", new Object[] { new
ObjectName("org.apache.karaf.Mbean:type=foo"), "myMethod", new Object[] {
String.class.getName() }, new String[] { "the-param "}});
+
+ EventLayout layout = new GelfLayout();
+ Path path = Files.createTempDirectory("file-logger");
+ String file = path.resolve("file.log").toString();
+ EventLogger logger = new FileEventLogger(file, "UTF-8", "daily", 2,
false, Executors.defaultThreadFactory(), layout);
+
+ logger.write(new MapEvent(map, 1510902000000L));
+ logger.write(new MapEvent(map, 1510984800000L));
+ logger.close();
+
+ Thread.sleep(100);
+
+ List<Path> paths =
Files.list(path).sorted().collect(Collectors.toList());
+ Collections.sort(paths);
+ assertEquals(2, paths.size());
+ assertEquals("file-2017-11-18.log",
paths.get(0).getFileName().toString());
+ assertEquals("file.log", paths.get(1).getFileName().toString());
+
+ List<String> lines = Files.readAllLines(paths.get(0),
StandardCharsets.UTF_8);
+ assertEquals(1, lines.size());
+ String str = lines.get(0);
+ System.out.println(str);
+ assertTrue(str.startsWith("{ version=\"1.1\" host=\""));
+ assertTrue(str.endsWith("timestamp=1510902000.000
short_message=\"jmx.invoke\" _type=\"jmx\" _subtype=\"invoke\"
_method=\"invoke\" _signature=\"[javax.management.ObjectName, java.lang.String,
[Ljava.lang.Object;, [Ljava.lang.String;]\"
_params=\"[org.apache.karaf.Mbean:type=foo, myMethod, [java.lang.String],
[the-param ]]\" }"));
+
+ lines = Files.readAllLines(paths.get(1), StandardCharsets.UTF_8);
+ assertEquals(1, lines.size());
+ str = lines.get(0);
+ System.out.println(str);
+ assertTrue(str.startsWith("{ version=\"1.1\" host=\""));
+ assertTrue(str.endsWith("timestamp=1510984800.000
short_message=\"jmx.invoke\" _type=\"jmx\" _subtype=\"invoke\"
_method=\"invoke\" _signature=\"[javax.management.ObjectName, java.lang.String,
[Ljava.lang.Object;, [Ljava.lang.String;]\"
_params=\"[org.apache.karaf.Mbean:type=foo, myMethod, [java.lang.String],
[the-param ]]\" }"));
+ }
+
+ @Test
+ public void testFileMaxFiles() throws Exception {
+ Map<String, Object> map = new HashMap<>();
+ map.put("type", Event.TYPE_SHELL);
+ map.put("subtype", "executed");
+ map.put("script", "a-script");
+
+ EventLayout layout = new GelfLayout();
+ Path path = Files.createTempDirectory("file-logger");
+ String file = path.resolve("file.log").toString();
+ EventLogger logger = new FileEventLogger(file, "UTF-8", "daily", 2,
false, Executors.defaultThreadFactory(), layout);
+
+ for (int i = 0; i < 10; i++) {
+ logger.write(new MapEvent(map, 1510902000000L +
TimeUnit.DAYS.toMillis(i)));
+ }
+ logger.close();
+
+ Thread.sleep(100);
+
+ List<String> paths = Files.list(path)
+ .map(Path::getFileName).map(Path::toString)
+ .sorted().collect(Collectors.toList());
+ assertEquals(Arrays.asList("file-2017-11-25.log",
"file-2017-11-26.log", "file.log"), paths);
+ }
+
+ @Test
+ public void testFileSize() throws Exception {
+ Map<String, Object> map = new HashMap<>();
+ map.put("type", Event.TYPE_SHELL);
+ map.put("subtype", "executed");
+ map.put("script", "a-script");
+
+ EventLayout layout = new GelfLayout();
+ Path path = Files.createTempDirectory("file-logger");
+ String file = path.resolve("file.log").toString();
+ EventLogger logger = new FileEventLogger(file, "UTF-8", "size(10)", 2,
false, Executors.defaultThreadFactory(), layout);
+
+ for (int i = 0; i < 10; i++) {
+ logger.write(new MapEvent(map, 1510902000000L +
TimeUnit.HOURS.toMillis(i)));
+ }
+ logger.close();
+
+ Thread.sleep(100);
+
+ List<String> paths = Files.list(path)
+ .map(Path::getFileName).map(Path::toString)
+ .sorted().collect(Collectors.toList());
+ assertEquals(Arrays.asList("file-2017-11-17-2.log",
"file-2017-11-17.log", "file.log"), paths);
+ }
+
+ @Test
+ public void testFileSizeCompress() throws Exception {
+ Map<String, Object> map = new HashMap<>();
+ map.put("type", Event.TYPE_SHELL);
+ map.put("subtype", "executed");
+ map.put("script", "a-script");
+
+ EventLayout layout = new GelfLayout();
+ Path path = Files.createTempDirectory("file-logger");
+ String file = path.resolve("file.log").toString();
+ EventLogger logger = new FileEventLogger(file, "UTF-8", "size(10)", 2,
true, Executors.defaultThreadFactory(), layout);
+
+ for (int i = 0; i < 10; i++) {
+ logger.write(new MapEvent(map, 1510902000000L +
TimeUnit.HOURS.toMillis(i)));
+ }
+ logger.close();
+
+ Thread.sleep(100);
+
+ List<String> paths = Files.list(path)
+ .map(Path::getFileName).map(Path::toString)
+ .sorted().collect(Collectors.toList());
+ assertEquals(Arrays.asList("file-2017-11-17-2.log.gz",
"file-2017-11-17.log.gz", "file.log"), paths);
+ }
+
+ private int getNewPort() throws IOException {
+ try (ServerSocket socket = new ServerSocket()) {
+ socket.setReuseAddress(true);
+ socket.bind(new InetSocketAddress("localhost", 0));
+ return socket.getLocalPort();
+ }
+ }
+
+}