/**
* Copyright (C) 2005 - 2011 Eric Van Dewoestine
*
* 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 3 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, see <http://www.gnu.org/licenses/>.
*/
package org.eclim.plugin.jdt.command.log4j;
import java.util.List;
import java.util.Map;
import org.eclim.Eclim;
import org.eclim.plugin.jdt.Jdt;
import org.junit.Test;
import static org.junit.Assert.*;
/**
* Test case for ValidateCommand.
*
* @author Eric Van Dewoestine
*/
public class ValidateCommandTest
{
private static final String TEST_FILE = "log4j/log4j.xml";
@Test
@SuppressWarnings("unchecked")
public void validateXmlErrors()
{
List<Map<String,Object>> results = (List<Map<String,Object>>)
Eclim.execute(new String[]{
"log4j_validate", "-p", Jdt.TEST_PROJECT,
"-f", TEST_FILE
});
assertEquals("Wrong number of results", 6, results.size());
String file = Eclim.resolveFile(Jdt.TEST_PROJECT, TEST_FILE);
Map<String,Object> error = results.get(0);
assertEquals(error.get("filename"), file);
assertEquals(error.get("message"),
"Element type \"pram\" must be declared.");
assertEquals(error.get("line"), 23);
assertEquals(error.get("column"), 45);
assertEquals(error.get("warning"), false);
error = results.get(1);
assertEquals(error.get("filename"), file);
assertEquals(error.get("message"),
"The content of element type \"appender\" must match " +
"\"(errorHandler?,param*,layout?,filter*,appender-ref*)\".");
assertEquals(error.get("line"), 27);
assertEquals(error.get("column"), 14);
assertEquals(error.get("warning"), false);
error = results.get(2);
assertEquals(error.get("filename"), file);
assertEquals(error.get("message"),
"Type 'org.apache.log4j.RollingFileAppender' not found " +
"in project 'eclim_unit_test_java'.");
assertEquals(error.get("line"), 9);
assertEquals(error.get("column"), 1);
assertEquals(error.get("warning"), false);
error = results.get(3);
assertEquals(error.get("filename"), file);
assertEquals(error.get("message"),
"Type 'org.apache.log4j.PatternLayout' not found " +
"in project 'eclim_unit_test_java'.");
assertEquals(error.get("line"), 14);
assertEquals(error.get("column"), 1);
assertEquals(error.get("warning"), false);
error = results.get(4);
assertEquals(error.get("filename"), file);
assertEquals(error.get("message"),
"Type 'org.eclim.util.logging.ConsoleAppender' not found " +
"in project 'eclim_unit_test_java'.");
assertEquals(error.get("line"), 22);
assertEquals(error.get("column"), 1);
assertEquals(error.get("warning"), false);
error = results.get(5);
assertEquals(error.get("filename"), file);
assertEquals(error.get("message"),
"Type 'org.apache.log4j.PatternLayout' not found " +
"in project 'eclim_unit_test_java'.");
assertEquals(error.get("line"), 24);
assertEquals(error.get("column"), 1);
assertEquals(error.get("warning"), false);
}
}