Разработка плагинов Jenkins - постоянство

Я все еще изучаю плагин Dev. Это мой первый.

Я хотел бы сохранить конфигурацию моего плагина, но он не будет работать.

Не могли бы вы сказать мне, что я делаю не так?

Я попытался отладить процесс, начиная с добавления плагина к заданию и сохраняя конфигурацию задания.

Я обнаружил, что внутри метода load() дескриптора не найден xml-файл!

Путь, который он ищет, выглядит примерно так: c:\users\Peter\workspace\r-script.\ Work\whatEverDir\xy.xml

Я не думаю, что. \ Part приводит к тому, что файл конфигурации не может быть найден, но, поскольку это класс Jenkins, генерирующий этот путь, я бы не стал на него ставить. Хотя система могла бы попытаться создать его здесь в первую очередь.

Заранее спасибо!

Scriptrunner.jelly

    <f:block>
        <f:entry title="RScript" field="command">
            <f:textarea  style="width:99%" />
        </f:entry>
        </f:block>

    <f:entry field="installedPackages" title="Installed packages">
        <f:select style="width:40%" /> 
    </f:entry> 

    <f:entry field="mirrors" title="Choose a mirror">
        <f:select style="width:40%" />
    </f:entry>

    <f:entry>
            <f:repeatableProperty field="availablePackages" minimum="1"/>
    </f:entry>            

AvailablePackage.jelly

<f:entry field="availablePackages">
    <f:select style="width:40%" />
    <f:repeatableDeleteButton /> 
</f:entry>

ScriptRunner.java

public class ScriptRunner extends Builder {
 private static final String fileExtension = ".R";
 private ArrayList<AvailablePackage> availablePackages;
 private String command;
 private String chosenMirror;
 private List<String> mirrorList = new ArrayList<String>();

 @DataBoundConstructor
 public ScriptRunner(String command, ArrayList<String> installedPackages,     ArrayList<String> mirrors, ArrayList<AvailablePackage> availablePackages) {
this.chosenMirror = mirrors.get(0);
this.availablePackages = availablePackages;
this.command = command;
  }

  public final String getCommand() {
  return command;
  }

  @Override
  public boolean perform(AbstractBuild<?, ?> build, Launcher launcher,
    BuildListener listener) throws InterruptedException {
  return perform(build, launcher, (TaskListener) listener);
  } 

  public boolean perform(AbstractBuild<?, ?> build, Launcher launcher,
    TaskListener listener) throws InterruptedException {
FilePath workSpace = build.getWorkspace();
FilePath rScript = null;
if (workSpace == null) {
    try {
    throw new NoSuchFileException("Workspace could not be set!");
    } catch (NoSuchFileException e) {
    e.printStackTrace();
    }
}
try {
    try {
    String fullScript;
    if (command.contains("options(repos=structure(")) {
            fullScript = PackagesManager.singleton().createFullScript(availablePackages, "", command);
    } else {
        fullScript = PackagesManager.singleton().createFullScript(availablePackages, chosenMirror, command);
    }
    rScript = workSpace.createTextTempFile("RScriptTemp",
        getFileExtension(), fullScript, false);
    } catch (IOException e) {
    Util.displayIOException(e, listener);
    e.printStackTrace(listener.fatalError(Messages
        .CommandInterpreter_UnableToProduceScript()));
    return false;
    }

    boolean successfullyRan = false;
    try {
    EnvVars envVars = build.getEnvironment(listener);
    for (Map.Entry<String, String> e : build.getBuildVariables()
        .entrySet()) {
        envVars.put(e.getKey(), e.getValue());
    }

    if (launcher.launch().cmds(buildCommandLine(rScript))
        .envs(envVars).stdout(listener).pwd(workSpace).join() == 1) {
        successfullyRan = true;
    }
    } catch (IOException e) {
    Util.displayIOException(e, listener);
    e.printStackTrace(listener.fatalError(Messages
        .CommandInterpreter_CommandFailed()));

    }
    return successfullyRan;
} finally {
    try {
    if (rScript != null) {
        rScript.delete();
    }
    } catch (IOException e) {
    Util.displayIOException(e, listener);
    e.printStackTrace(listener.fatalError(Messages
        .CommandInterpreter_UnableToDelete(rScript)));
    } catch (Exception e) {
    e.printStackTrace(listener.fatalError(Messages
        .CommandInterpreter_UnableToDelete(rScript)));
    }
}
}

public String[] buildCommandLine(FilePath script) {
return new String[] { "Rscript", script.getRemote() };
}

protected String getFileExtension() {
return fileExtension;
}

public List<String> getMirrorList() {
return mirrorList;
}

public void setMirrorList(List<String> mirrorList) {
this.mirrorList = mirrorList;
}

public String getChosenMirror() {
return chosenMirror;
}

public void setChosenMirror(String chosenMirror) {
this.chosenMirror = chosenMirror;
}

public ArrayList<AvailablePackage> getAvailablePackages() {
return availablePackages;
}

@Override
public ScriptBuildStepDescriptorImplementation getDescriptor() {
    return (ScriptBuildStepDescriptorImplementation)super.getDescriptor();
}

@Extension
public static class ScriptBuildStepDescriptorImplementation extends
    BuildStepDescriptor<Builder> {

private boolean showInstalled;
private String command;
private String chosenMirror;
private ArrayList<AvailablePackage> availablePackages;

public ScriptBuildStepDescriptorImplementation() {
    load();
}

 @Override
    public boolean configure(StaplerRequest req, JSONObject formData) throws FormException {
        req.bindJSON(this, formData);
        save();
        return super.configure(req,formData);
    }

@Override
public String getDisplayName() {
    return "Advanced R script runner";
}

@Override
public boolean isApplicable(Class<? extends AbstractProject> jobType) {
    return true;
}

public ListBoxModel doFillInstalledPackagesItems() {
    ListBoxModel mirrors = new ListBoxModel();
    Set<String> mirrorsList = PackagesManager.singleton()
        .getInstalledPackages();
    for (String entry : mirrorsList) {
    mirrors.add(entry);
    }
    return mirrors;
}

public ListBoxModel doFillAvailablePackagesItems() {
    ListBoxModel packages = new ListBoxModel();
    List<String> packageList = PackagesManager.singleton().getAvailablePackages();
    Set<String> alreadyInstalled = PackagesManager.singleton().getInstalledPackages();
    for (String entry : packageList) {
    if (!alreadyInstalled.contains(entry)) {
    packages.add(entry);
    }
    }
    return packages;
}

public ListBoxModel doFillMirrorsItems() {
    ListBoxModel mirrors = new ListBoxModel();
    String[] mirrorsList = MirrorManager.singleton().getMirrors();
    int selected = 34;
    for (int i = 0; i < mirrorsList.length; i++) {
    String[] splitCurrent = mirrorsList[i].split(" - ");
    if (chosenMirror != null && chosenMirror.equals(splitCurrent[1])) {
        selected = i;
    }
    mirrors.add(splitCurrent[1], splitCurrent[0]);
    }   
    mirrors.get(selected).selected = true;
    return mirrors;
}

public boolean getShowInstalled() {
    return showInstalled;
}

public void setShowInstalled(boolean showInstalled) {
    this.showInstalled = showInstalled;
}

public String getCommand() {
    return command;
}

public void setCommand(String command) {
    this.command = command;
}

 public String getChosenMirror() {
    return chosenMirror;
 }

   public void setChosenMirror(String chosenMirror) {
     this.chosenMirror = chosenMirror;
  }
    }
}

AvailablePackage.java

public class AvailablePackage extends AbstractDescribableImpl<AvailablePackage> {
private String name;

@DataBoundConstructor
public AvailablePackage(String availablePackages) {
this.name = availablePackages;
}

public String getName() {
return name;
}

@Override
public DescriptorImpl getDescriptor() {
    return (DescriptorImpl)super.getDescriptor();
}

@Extension
public static class DescriptorImpl extends Descriptor<AvailablePackage> {
private String name;

public DescriptorImpl() {
    load(); 
}

 @Override
 public boolean configure(StaplerRequest req, JSONObject formData) throws FormException {
     req.bindJSON(this, formData);
     save();
     return super.configure(req,formData);
    }

    public ListBoxModel doFillAvailablePackagesItems() {
        return PackagesManager.singleton().getAvailablePackagesAsListBoxModel(name);
    }

    @Override
    public String getDisplayName() {
        return "";
    }

    public String getName() {
        return name;
    }
}

}

Извините за форматирование кода! Первый таймер при отправке кода на стеке

1 ответ

Я думаю, что вы, возможно, должны прокомментировать эту строку

@Override
public boolean configure(StaplerRequest req, JSONObject formData) throws FormException {
    req.bindJSON(this, formData);
    save();
    //return super.configure(req,formData);
    return true;
}

как это будет затем сохранить снова, но без полей.

Хорошее место, чтобы найти примеры плагинов Jenkins - это https://github.com/jenkinsci

Другие вопросы по тегам