Profesjonalny uzależniony od Internetu • Entuzjasta gier • Twórca technologii
Profesjonalny uzależniony od Internetu • Entuzjasta gier • Twórca technologii

Uruchamianie Checkstyle jako automatycznego testu JUnit

Jak uruchomić Checkstyle jako automatyczny test JUnit!
Ta strona została przetłumaczona z języka angielskiego przez moich niezwykle zmotywowanych stażystów ds. sztucznej inteligencji, dla Państwa wygody. Wciąż się uczą, więc mogło umknąć im kilka błędów. Aby uzyskać najdokładniejsze informacje, prosimy o zapoznanie się z wersją angielską.
Dom Blog Uruchamianie Checkstyle jako automatycznego testu JUnit

Proszę pamiętać, że ten wpis na blogu został opublikowany w czerwcu 2010 roku, więc w zależności od tego, kiedy go czytasz, niektóre fragmenty mogą być nieaktualne. Niestety, nie zawsze jestem w stanie na bieżąco aktualizować te wpisy, aby zapewnić aktualność informacji.

    If you are looking for a great code analysis tool to help you review your Java code, Checkstyle is a good choice. It basically checks your code towards a set of given checks of your choice, everything from checking that the code is following naming conventions, to spotting duplicated code.
    There are several ways to use Checkstyle, either by using it with a build automation tool such as Apache Maven or as an Ant task, but you can also simply execute it through a command line.
    However if you are interested you can also wrap it into a JUnit test. Even though it is really not a unit test, it could be really convenient as it allows you run it along with the rest of your tests.
    Here is a basic example code:
    public class CheckStyleTest extends TestCase { @Test public void testCheckStyle() throws Exception { /* * Files */ File ROOT = new File("src/"); System.out.println("Root is set to "" + ROOT.getAbsolutePath() + ""."); List files = new ArrayList(); listFiles(files, ROOT, "java"); System.out.println("Found " + files.size() + " Java source files."); /* * Listener */ ByteArrayOutputStream sos = new ByteArrayOutputStream(); AuditListener listener = new DefaultLogger(sos, false); /* * Configuration */ InputSource inputSource = new InputSource(CheckStyleTest.class.getResourceAsStream("configuration.xml")); Configuration configuration = ConfigurationLoader.loadConfiguration(inputSource, new PropertiesExpander(System.getProperties()), false); /* * Create checker */ Checker checker = new Checker(); checker.setModuleClassLoader(Checker.class.getClassLoader()); checker.configure(configuration); checker.addListener(listener); /* * Process */ int errors = checker.process(files); System.out.println("Found " + errors + " check style errors."); System.out.println(sos.toString()); assertTrue(errors + " check style errors found. " + sos.toString(), errors == 0); /* * Clean up */ checker.destroy(); } private static void listFiles(List files, File folder, String extension) { if (folder.canRead()) { if (folder.isDirectory()) { for (File f : folder.listFiles()) { listFiles(files, f, extension); } } else if (folder.toString().endsWith("." + extension)) { files.add(folder); } } } }
    As you can notice the test will try and read from a file called "configuration.xml". File this has to be in the same folder as where you put this test. "configuration.xml" is simply the checks that Checkstyle should perform. How to write this document is described on the their configuration page.
    A sample of the "configuration.xml" file would be:
    <module name="Checker"> <module name="TreeWalker"> <module name="CovariantEquals"/> <module name="EmptyStatement"/> <module name="FallThrough"/> <module name="SuperClone"/> <module name="AvoidStarImport"/> <module name="UnusedImports"/> <module name="AvoidStaticImport"/> <module name="EqualsHashCode"/> </module> </module>

    Napisane przez Special Agent Squeaky. Pierwsze opublikowanie 29.06.2010. Ostatnia aktualizacja 29.06.2010.

    📺 Obejrzyj najnowszy film Squeaky!

    Jak dodać proste napisy w czasie rzeczywistym do Twojej transmisji na żywo