Comparaison de différents logiciels d'intégration continue

Java

Utilisateur de CruiseControl depuis presque 2 ans, au moment d'installer et de mettre celui-ci en place dans ma nouvelle équipe je me suis demandé s'il n'existe pas d'autres solutions d'intégration continue. J'avais entendu parler de Luntbuild et Anthill. Mais bon, quelques tests plus tard je pense que CruiseControl pour de l'intégration continue d'un projet Java est le plus puissant et le plus simple à installer. Il a l'avantage d'être gratuit et open source. Sur cette page vous trouverez un tableau récapitulatif des différentes fonctionalités de CruiseControl comparées à ses concurrents.

J'ai rencontré un petit problème sur l'application web de Cruise Control. Lorsque le visiteur clique sur l'onglet "Metrics" une page blanche est affichée et une exception est levée sur Tomcat.

2006-01-25 09:09:30 StandardContext[/cruisecontrol]jsp: http://ptxsfrabench2:8080/cruisecontrol/buildresults/kiwi: (null)
java.lang.NoClassDefFoundError
        at org.jfree.chart.ChartFactory.createPieChart(Unknown Source)
        at de.laures.cewolf.taglib.CewolfChartFactory.getChartInstance(CewolfChartFactory.java:76)
        at de.laures.cewolf.taglib.SimpleChartDefinition.produceChart(SimpleChartDefinition.java:30)
        at de.laures.cewolf.taglib.AbstractChartDefinition.getChart(AbstractChartDefinition.java:81)
        at de.laures.cewolf.taglib.ChartImageDefinition.ensureRendered(ChartImageDefinition.java:131)
        at de.laures.cewolf.taglib.ChartImageDefinition.getBytes(ChartImageDefinition.java:125)
        at de.laures.cewolf.storage.SerializableChartImage.(SerializableChartImage.java:51)
        at de.laures.cewolf.storage.SessionStorage.storeChartImage(SessionStorage.java:57)
        at de.laures.cewolf.storage.SessionStorage.storeChartImage(SessionStorage.java:35)
        at de.laures.cewolf.taglib.tags.ChartImgTag.doStartTag(ChartImgTag.java:74)
        at org.apache.jsp.main_jsp._jspx_meth_cewolf_img_0(main_jsp.java:959)
        at org.apache.jsp.main_jsp._jspService(main_jsp.java:640)
        at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:94)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
        at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:324)
        at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:292)
        at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:236)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:237)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:157)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:214)
        at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
        at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
        at org.apache.catalina.core.StandardContextValve.invokeInternal(StandardContextValve.java:198)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:152)
        at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
        at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137)
        at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:118)
        at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:102)
        at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
        at org.apache.catalina.core.StandardValveContext.invokeNext(StandardValveContext.java:104)
        at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:520)
        at org.apache.catalina.core.ContainerBase.invoke(ContainerBase.java:929)
        at org.apache.coyote.tomcat5.CoyoteAdapter.service(CoyoteAdapter.java:160)
        at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:799)
        at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.processConnection(Http11Protocol.java:705)
        at org.apache.tomcat.util.net.TcpWorkerThread.runIt(PoolTcpEndpoint.java:577)
        at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:683)
        at java.lang.Thread.run(Thread.java:536)


3 mn sous Google plus tard, j'ai trouvé la solution. Le problème vient du fait que j'ai installé CC sur une SUN sans display et donc sans serveur X.
Il faut simplement modifier le script de démarrage de Tomcat en ajoutant les options suivantes

   # For X11 and CruiseControl Metrics tab
   JAVA_OPTS=-Djava.awt.headless=true
   export JAVA_OPTS

Commentaires (0)

Aucun commentaire pour le moment.