blob: 5a473ba568ba093131ebf6867175ce2743b3a29f [file] [log] [blame]
<?php
/**
* 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.
*
* @category tests
* @package log4php
* @subpackage helpers
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
* @version $Revision$
* @link http://logging.apache.org/log4php
*/
/**
* @group helpers
*/
class LoggerUtilsTest extends PHPUnit_Framework_TestCase {
public function testShorten() {
$name = 'org\\apache\\logging\\log4php\\Foo';
$actual = LoggerUtils::shortenClassName($name, null);
self::assertSame($name, $actual);
$actual = LoggerUtils::shortenClassName($name, 0);
self::assertSame('Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 5);
self::assertSame('o\\a\\l\\l\\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 16);
self::assertSame('o\\a\\l\\l\\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 17);
self::assertSame('o\\a\\l\\log4php\\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 25);
self::assertSame('o\\a\\logging\\log4php\\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 28);
self::assertSame('o\\apache\\logging\\log4php\\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 30);
self::assertSame('org\\apache\\logging\\log4php\\Foo', $actual);
}
/** Dot separated notation must be supported for legacy reasons. */
public function testShortenWithDots() {
$name = 'org.apache.logging.log4php.Foo';
$actual = LoggerUtils::shortenClassName($name, null);
self::assertSame($name, $actual);
$actual = LoggerUtils::shortenClassName($name, 0);
self::assertSame('Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 5);
self::assertSame('o\a\l\l\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 16);
self::assertSame('o\a\l\l\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 17);
self::assertSame('o\a\l\log4php\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 25);
self::assertSame('o\a\logging\log4php\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 28);
self::assertSame('o\apache\logging\log4php\Foo', $actual);
$actual = LoggerUtils::shortenClassName($name, 30);
self::assertSame('org\apache\logging\log4php\Foo', $actual);
}
}