當前位置: 首頁>>代碼示例>>Java>>正文


Java Node.toComputer方法代碼示例

本文整理匯總了Java中hudson.model.Node.toComputer方法的典型用法代碼示例。如果您正苦於以下問題:Java Node.toComputer方法的具體用法?Java Node.toComputer怎麽用?Java Node.toComputer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在hudson.model.Node的用法示例。


在下文中一共展示了Node.toComputer方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: startZAP

import hudson.model.Node; //導入方法依賴的package包/類
/**
 * Start ZAProxy using command line. It uses host and port configured in Jenkins admin mode and
 * ZAProxy program is launched in daemon mode (i.e without UI).
 * ZAProxy is started on the build's machine (so master machine ou slave machine) thanks to 
 * {@link FilePath} object and {@link Launcher} object.
 * 
 * @param build
 * @param listener the listener to display log during the job execution in jenkins
 * @param launcher the object to launch a process locally or remotely
 * @throws InterruptedException 
 * @throws IOException 
 * @throws IllegalArgumentException 
 */
public void startZAP(AbstractBuild<?, ?> build, BuildListener listener, Launcher launcher) 
		throws IllegalArgumentException, IOException, InterruptedException {
	checkParams(build, listener);
	
	FilePath ws = build.getWorkspace();
	if (ws == null) {
		Node node = build.getBuiltOn();
		if (node == null) {
			throw new NullPointerException("no such build node: " + build.getBuiltOnStr());
		}
		throw new NullPointerException("no workspace from node " + node + " which is computer " + node.toComputer() + " and has channel " + node.getChannel());
	}
	
	// Contains the absolute path to ZAP program
	FilePath zapPathWithProgName = new FilePath(ws.getChannel(), zapProgram + getZAPProgramNameWithSeparator(build));
	listener.getLogger().println("Start ZAProxy [" + zapPathWithProgName.getRemote() + "]");
	
	// Command to start ZAProxy with parameters
	List<String> cmd = new ArrayList<String>();
	cmd.add(zapPathWithProgName.getRemote());
	cmd.add(CMD_LINE_DAEMON);
	cmd.add(CMD_LINE_HOST);
	cmd.add(zapProxyHost);
	cmd.add(CMD_LINE_PORT);
	cmd.add(String.valueOf(zapProxyPort));
	cmd.add(CMD_LINE_CONFIG);
	cmd.add(CMD_LINE_API_KEY + "=" + API_KEY);
	
	// Set the default directory used by ZAP if it's defined and if a scan is provided
	if(scanURL && zapDefaultDir != null && !zapDefaultDir.isEmpty()) {
		cmd.add(CMD_LINE_DIR);
		cmd.add(zapDefaultDir);
	}
	
	// Adds command line arguments if it's provided
	if(!cmdLinesZAP.isEmpty()) {
		addZapCmdLine(cmd);
	}
		
	EnvVars envVars = build.getEnvironment(listener);
	// on Windows environment variables are converted to all upper case,
	// but no such conversions are done on Unix, so to make this cross-platform,
	// convert variables to all upper cases.
	for(Map.Entry<String,String> e : build.getBuildVariables().entrySet())
		envVars.put(e.getKey(),e.getValue());
	
	FilePath workDir = new FilePath(ws.getChannel(), zapProgram);
	
	// JDK choice
	computeJdkToUse(build, listener, envVars);
	
	// Launch ZAP process on remote machine (on master if no remote machine)
	launcher.launch().cmds(cmd).envs(envVars).stdout(listener).pwd(workDir).start();
	
	// Call waitForSuccessfulConnectionToZap(int, BuildListener) remotely
	build.getWorkspace().act(new WaitZAProxyInitCallable(this, listener));
}
 
開發者ID:jenkinsci,項目名稱:zaproxy-plugin,代碼行數:71,代碼來源:ZAProxy.java

示例2: lockSlaveExecutors

import hudson.model.Node; //導入方法依賴的package包/類
/**
 * Used to lock the executors for each available slave assigned to this
 * build. <br />
 * <br />
 * <b>(Can be modified to get the auto-generated projects and their
 * builds)</b>
 * 
 * @param availableNodes
 *            the available nodes
 * @param build
 *            the current build
 * @param stream
 *            the printing stream
 * @return the locked set of nodes
 * @throws Exception
 */
private Set<Node> lockSlaveExecutors(Set<Node> availableNodes,
		AbstractBuild<?, ?> build, PrintStream stream) throws Exception {
	ArrayList<Future<FreeStyleBuild>> futureBuildList = new ArrayList<Future<FreeStyleBuild>>();

	ArrayList<FreeStyleProject> projectList = new ArrayList<FreeStyleProject>();

	Set<Node> nodeSet = new HashSet<Node>();

	Computer c = null;

	for (Node n : availableNodes) {

		c = n.toComputer();

		nodeSet.add(n);

		for (Executor e : c.getExecutors()) {

			if (e.isIdle()) {
				String lockProjectName = NodeUtils.getLockedProjectName(
						build.getProject().getName(), n, e);

				Jenkins jenkins = Jenkins.getInstance();

				NodeUtils.deleteLockingProject(lockProjectName, stream);

				FreeStyleProject project = jenkins.createProject(
						FreeStyleProject.class, lockProjectName);

				final String projectName = build.getProject().getName();

				project.getBuildersList().add(
						new DTDumbBuilder(projectName));

				project.setAssignedNode(n);

				QueueTaskFuture<FreeStyleBuild> buildFuture = project
						.scheduleBuild2(0);

				futureBuildList.add(buildFuture);
				projectList.add(project);

			}
		}
	}

	return nodeSet;
}
 
開發者ID:bombardier-transportation,項目名稱:distributed-test-job,代碼行數:65,代碼來源:DTBuilder.java


注:本文中的hudson.model.Node.toComputer方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。