Add log4j2 agent tests
[lttng-ust-java-tests.git] / lttng-ust-java-tests-log4j2 / src / test / java / org / lttng / ust / agent / utils / Log4j2TestContext.java
diff --git a/lttng-ust-java-tests-log4j2/src/test/java/org/lttng/ust/agent/utils/Log4j2TestContext.java b/lttng-ust-java-tests-log4j2/src/test/java/org/lttng/ust/agent/utils/Log4j2TestContext.java
new file mode 100644 (file)
index 0000000..96b2683
--- /dev/null
@@ -0,0 +1,60 @@
+/*
+ * Copyright (C) 2022, EfficiOS Inc.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+package org.lttng.ust.agent.utils;
+
+import java.net.URI;
+import java.net.URL;
+
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.core.LoggerContext;
+
+public class Log4j2TestContext {
+
+    private final URI configFileUri;
+
+    private LoggerContext loggerContext;
+
+    public Log4j2TestContext(String configFile) {
+
+        URL resource = getClass().getClassLoader().getResource(configFile);
+
+        if (resource == null) {
+            throw new IllegalArgumentException("Config file not found: " + configFile);
+        }
+
+        try {
+            this.configFileUri = resource.toURI();
+        } catch (Exception e) {
+            throw new IllegalArgumentException("Config file invalid URI: " + resource);
+        }
+    }
+
+    public synchronized LoggerContext getLoggerContext() {
+        return loggerContext;
+    }
+
+    public synchronized void beforeTest() {
+        loggerContext = (LoggerContext) LogManager.getContext(
+                ClassLoader.getSystemClassLoader(), false, configFileUri);
+    }
+
+    public synchronized void afterTest() {
+        loggerContext.stop();
+    }
+}
This page took 0.024953 seconds and 4 git commands to generate.