点击FxCop会导致Jenkins违规插件进入空白页面

点击FxCop会导致Jenkins违规插件进入空白页面,jenkins,fxcop,Jenkins,Fxcop,我有一个Jenkins作业,其中我指定了类似以下FxCop命令的内容: FxCopCmd.exe"/file:"test.dll" /out:"FxCop_Output.xml" /ignoregeneratedcode /project:"C:\Jenkins\extra\Modified_Rules.FxCop" /s /searchgac 当Jenkins作业运行时,它会发现大量代码冲突,并显示一个图形以及文件名列表,其中包含文件中的冲突数量。然而,如果我点击一个非C-Sharp文件,我

我有一个Jenkins作业,其中我指定了类似以下FxCop命令的内容:

FxCopCmd.exe"/file:"test.dll" /out:"FxCop_Output.xml" /ignoregeneratedcode /project:"C:\Jenkins\extra\Modified_Rules.FxCop" /s /searchgac
当Jenkins作业运行时,它会发现大量代码冲突,并显示一个图形以及文件名列表,其中包含文件中的冲突数量。然而,如果我点击一个非C-Sharp文件,我会被带到一个带有红色三角形感叹号的页面,但是没有显示代码,也没有FxCop错误列表


我是否缺少某种FxCop配置?如何让违规插件显示这些文件的代码违规?

我想您可能会看到(在Jenkins JIRA中报道)。在显示StyleCop结果时也存在类似的问题。你能确认你的Jenkins和违规插件版本吗?

我最终下载并修改了违规插件代码,以显示没有源代码的文件的违规列表,然后重新编译违规插件(并手动将修改后的插件加载到Jenkins中)

文件名也没有显示出来,正如我的原始屏幕截图所示,“getFileNameAlt”函数只是正确地获取了名称,下面jelly脚本中的“File:${it.fileNameAlt}”行显示了它(请参见下面屏幕截图的链接)

我将以下内容添加到~\inflictions\src\main\java\hudson\plugins\inflictions\render\FileModelProxy.java中,以呈现该表:

public String getFileNameAlt() {
    return new File(fileModel.getDisplayName()).getName();
}

public String getSummaryTable() {

    StringBuilder gst = new StringBuilder();
    int count = 0;

    gst.append(" <table class='violations' width='100%'>\n");
    gst.append("   <tr>\n");
    gst.append("     <td class='violations-header'> # </td>\n");
    gst.append("     <td class='violations-header'> Type </td>\n");
    gst.append("     <td class='violations-header'> Class</td>\n");
    gst.append("     <td class='violations-header'> Message</td>\n");
    gst.append("     <td class='violations-header'> Description</td>\n");
    gst.append("   </tr>\n");

    Set<Violation> violations = fileModel.getLineViolationMap().get(0);

    for (Violation v: violations) {
        ++count;
        gst.append("   <tr>\n");
        gst.append("     <td class='violations'>");
        gst.append(count);
        gst.append("</td>\n");
        gst.append("     <td class='violations'>");
        gst.append(v.getType());
        gst.append("</td>\n");
        gst.append("     <td class='violations'>");
        gst.append(v.getSource());
        gst.append("</td>\n");
        gst.append("     <td class='violations'>");
        gst.append(v.getMessage());
        gst.append("</td>\n");
        gst.append("     <td class='violations'>");
        gst.append(v.getPopupMessage());
        gst.append("</td>\n");
        gst.append("   </tr>\n");
    }
    //}
    gst.append(" </table>\n");
    gst.append("<p><br>\n");
    gst.append("<h3>Total Number of violations:  \n");
    gst.append(count);
    gst.append("</h3><p>\n");
    return gst.toString();
}
下图显示了没有源代码的文件的结果表。在我的情况下,文件不以“.cs”结尾


您是否在“源路径模式”中提供了源文件的路径?它位于项目配置中违规插件设置的末尾。应该在原始问题中包含该信息。我现在运行Jenkins 1.514和违规插件版本0.7.15。我按照你的建议修复了插件。可以在这里下载它的一个版本:是否可以用类似的方式修复StyleCop的问题?@MoJo2600如何使用你创建的插件。请help@MoJo2600你能更新Jenkins的插件以便人们可以使用更新的版本吗?
<j:set
  var="iconDir"
  value="${rootURL}/plugin/violations/images/16x16"/>

<j:set var="href" value="${it.showLines}"/>
<h1><img src="${image}"/> File: ${it.fileNameAlt}</h1>

<j:out value="${it.summaryTable}"/>

<j:forEach var="t" items="${model.typeMap.entrySet()}">
  <table class="pane">
    <tbody>
      <tr><td class="pane-header" colspan="5"><j:out value="${it.typeLine(t.key)}"/></td></tr>
      <j:forEach var="v" items="${t.value}">
        <tr>
          <td class="pane">
            <j:if test="${href}">
              <a href="#line${v.line}">${v.line}</a>
            </j:if>
            <j:if test="${!href}">
              ${v.line}
            </j:if>
          </td>
          <!--<td class="pane">${v.source}</td> -->
          <td class="pane"><j:out value="${it.severityColumn(v)}"/></td>
          <td class="pane" width="99%">${v.message}</td>
        </tr>
      </j:forEach>
    </tbody>
  </table>
  <p></p>
</j:forEach>
.violations  {
  margin-top: 4px;
}
.violations td {
  padding: 4px 4px 3px 4px;
}

table.violations {
  width: 100%;
  border-collapse: collapse;
  border: 1px #bbb solid;
}
table.violations > tbody > tr > td:last-child {
  border-right: 1px #bbb solid;
}

td.violations {
  border: 1px #bbb solid;
  padding: 3px 4px 3px 4px;
  vertical-align: middle;
}

td.violations-header {
  border: 1px #bbb solid;
  border-right: none;
  border-left: none;
  background-color: #f0f0f0;
  font-weight: bold;
}

th.violations {
  border: 1px #bbb solid;
  font-weight: bold;
}