/* * ApplicationInsights-Java * Copyright (c) Microsoft Corporation * All rights reserved. * * MIT License * Permission is hereby granted, free of charge, to any person obtaining a copy of this * software and associated documentation files (the ""Software""), to deal in the Software * without restriction, including without limitation the rights to use, copy, modify, merge, * publish, distribute, sublicense, and/or sell copies of the Software, and to permit * persons to whom the Software is furnished to do so, subject to the following conditions: * The above copyright notice and this permission notice shall be included in all copies or * substantial portions of the Software. * THE SOFTWARE IS PROVIDED *AS IS*, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, * INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR * PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE * FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. */ package com.microsoft.applicationinsights.agent.internal.logger; import org.junit.Before; import org.junit.Test; import java.lang.reflect.Field; import static org.junit.Assert.*; public final class InternalAgentLoggerTest { @Before public void preTest() throws NoSuchFieldException, IllegalAccessException { Field field = InternalAgentLogger.class.getDeclaredField("initialized"); field.setAccessible(true); field.set(InternalAgentLogger.INSTANCE, false); field = InternalAgentLogger.class.getDeclaredField("loggingLevel"); field.setAccessible(true); field.set(InternalAgentLogger.INSTANCE, InternalAgentLogger.LoggingLevel.OFF); } @Test public void testInitializeWithBadValue() { InternalAgentLogger.INSTANCE.initialize("asdf"); assertFalse(InternalAgentLogger.INSTANCE.isTraceEnabled()); } @Test public void testInitializeWithEmptyValue() { InternalAgentLogger.INSTANCE.initialize(""); assertTrue(InternalAgentLogger.INSTANCE.isTraceEnabled()); } @Test public void testInitializeWithNullyValue() { InternalAgentLogger.INSTANCE.initialize(null); assertTrue(InternalAgentLogger.INSTANCE.isTraceEnabled()); } @Test public void testNotInitialized() { assertFalse(InternalAgentLogger.INSTANCE.isTraceEnabled()); } @Test public void testInitializedTwice() { InternalAgentLogger.INSTANCE.initialize("WARN"); InternalAgentLogger.INSTANCE.initialize("TRACE"); assertTrue(InternalAgentLogger.INSTANCE.isWarnEnabled()); assertTrue(InternalAgentLogger.INSTANCE.isErrorEnabled()); assertFalse(InternalAgentLogger.INSTANCE.isTraceEnabled()); } }