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


Java Node類代碼示例

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


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

示例1: getPollingEnvVars

import hudson.model.Node; //導入依賴的package包/類
@Nonnull
public static Map<String, String> getPollingEnvVars(@Nonnull Job<?, ?> job, @CheckForNull Node node) throws EnvInjectException {

    final Run<?, ?> lastBuild = job.getLastBuild();
    if (lastBuild != null) {
        if (EnvInjectPluginHelper.isEnvInjectPluginInstalled()) {
            return getEnVars(lastBuild);
        }
    }

    if (node == null) {
        return getFallBackMasterNode(job);
    }
    if (node.getRootPath() == null) {
        return getFallBackMasterNode(job);
    }

    return getDefaultEnvVarsJob(job, node);
}
 
開發者ID:jenkinsci,項目名稱:envinject-api-plugin,代碼行數:20,代碼來源:EnvVarsResolver.java

示例2: getEnVars

import hudson.model.Node; //導入依賴的package包/類
@Nonnull
public static Map<String, String> getEnVars(@Nonnull Run<?, ?> run) throws EnvInjectException {
    Action envInjectAction = EnvInjectActionRetriever.getEnvInjectAction(run);
    if (envInjectAction != null) {
        try {
            Method method = envInjectAction.getClass().getMethod("getEnvMap");
            return (Map<String, String>) method.invoke(envInjectAction);
        } catch (NoSuchMethodException | InvocationTargetException | IllegalAccessException | ClassCastException e) {
            throw new EnvInjectException(e);
        }
    }

    // Retrieve node used for this build
    Node builtOn = (run instanceof AbstractBuild) ? ((AbstractBuild)run).getBuiltOn() : null;
    
    // Check if node is always on. Otherwise, gather master env vars
    if (builtOn == null) {
        return getFallBackMasterNode(run.getParent());
    }
    if (builtOn.getRootPath() == null) {
        return getFallBackMasterNode(run.getParent());
    }

    // Get envVars from the node of the last build
    return getDefaultEnvVarsJob(run.getParent(), builtOn);
}
 
開發者ID:jenkinsci,項目名稱:envinject-api-plugin,代碼行數:27,代碼來源:EnvVarsResolver.java

示例3: findNodeProperty

import hudson.model.Node; //導入依賴的package包/類
/**
 * Finds the {@link NodeProperty} for the external workspace definition.
 *
 * @param node the current node
 * @return the node property for the external workspace manager
 * @throws IOException if node property was not found
 */
@Nonnull
private static ExternalWorkspaceProperty findNodeProperty(Node node) throws IOException {
    DescribableList<NodeProperty<?>, NodePropertyDescriptor> nodeProperties = node.getNodeProperties();

    ExternalWorkspaceProperty exwsNodeProperty = null;
    for (NodeProperty<?> nodeProperty : nodeProperties) {
        if (nodeProperty instanceof ExternalWorkspaceProperty) {
            exwsNodeProperty = (ExternalWorkspaceProperty) nodeProperty;
            break;
        }
    }

    if (exwsNodeProperty == null) {
        String message = format("There is no External Workspace config defined in Node '%s' config", node.getDisplayName());
        throw new AbortException(message);
    }

    return exwsNodeProperty;
}
 
開發者ID:jenkinsci,項目名稱:external-workspace-manager-plugin,代碼行數:27,代碼來源:ExwsExecution.java

示例4: localRootPathToNodeMountPoint

import hudson.model.Node; //導入依賴的package包/類
@LocalData
@Test
public void localRootPathToNodeMountPoint() throws Exception {

    // The node configuration version 1.0.0 contains a localRootPath field.
    // This tests that future versions load this field as nodeMountPoint,
    // in other words it tests NodeDisk.readResolve()

    Computer computer = jr.getInstance().getComputer("node1");
    Node node = computer.getNode();
    DescribableList<NodeProperty<?>,NodePropertyDescriptor> props = node.getNodeProperties();
    ExternalWorkspaceProperty exwsProp = props.get(ExternalWorkspaceProperty.class);

    List<NodeDiskPool> diskPools = exwsProp.getNodeDiskPools();
    assertThat(diskPools.size(), is(1));

    NodeDiskPool diskPool = diskPools.get(0);
    assertThat(diskPool.getDiskPoolRefId(), is ("dp1"));

    List<NodeDisk> disks = diskPool.getNodeDisks();
    assertThat(disks.size(), is(1));

    NodeDisk disk = disks.get(0);
    assertThat(disk.getDiskRefId(), is("d1"));
    assertThat(disk.getNodeMountPoint(), is("/tmp/dp1/d1"));
}
 
開發者ID:jenkinsci,項目名稱:external-workspace-manager-plugin,代碼行數:27,代碼來源:ConfigMigrationTest.java

示例5: removeNode

import hudson.model.Node; //導入依賴的package包/類
private synchronized void removeNode(String instanceId) {
    final Jenkins jenkins=Jenkins.getInstance();
    //noinspection SynchronizationOnLocalVariableOrMethodParameter
    synchronized (jenkins) {
        // If this node is dying, remove it from Jenkins
        final Node n = jenkins.getNode(instanceId);
        if (n != null) {
            try {
                jenkins.removeNode(n);
            } catch(final Exception ex) {
                LOGGER.log(Level.WARNING, "Error removing node " + instanceId);
                throw new IllegalStateException(ex);
            }
        }
    }
}
 
開發者ID:awslabs,項目名稱:ec2-spot-jenkins-plugin,代碼行數:17,代碼來源:EC2FleetCloud.java

示例6: execute

import hudson.model.Node; //導入依賴的package包/類
public static void execute(Run<?, ?> run, FilePath ws, Launcher launcher, String installation, Node node, TaskListener listener, EnvVars envVars, String cliScriptContent) throws IOException, InterruptedException{
	String exe = AppScanSourceInstallation.getExecutable(installation, AppScanSourceCommand.AppScanSourceCLI, node, listener, envVars);
	
	//Create a temp file with our script commands
	FilePath tempFile = ws.createTextTempFile("temp_cli_script_", ".txt", cliScriptContent);
	
	//Build the command line commands with necessary parameters
	JenkinsExecutor runner = new JenkinsExecutor(run, ws, launcher, listener);
	AppScanSourceInvocation invocation = new AppScanSourceInvocation(exe, run, ws, listener); 
	invocation.addScriptFile(tempFile);

	//Execute command line
	if (!invocation.execute(runner)) {
           throw new AbortException("AppScan Source execution failed");
       }			
	//Delete the temp file after we use it
	tempFile.delete();
}
 
開發者ID:kevinfealey,項目名稱:appscansource-scanner,代碼行數:19,代碼來源:AppScanSourceExecutor.java

示例7: createSlaveOnVM

import hudson.model.Node; //導入依賴的package包/類
public Node createSlaveOnVM(ParallelsDesktopVM vm) throws Exception
{
	String vmId = vm.getVmid();
	String slaveName = vm.getSlaveName();
	LOGGER.log(Level.SEVERE, "Starting slave '" + slaveName+ "'");
	LOGGER.log(Level.SEVERE, "Starting virtual machine '" + vmId + "'");
	RunVmCallable command = new RunVmCallable("start", vmId);
	try
	{
		forceGetChannel().call(command);
		LOGGER.log(Level.SEVERE, "Waiting for IP...");
		String ip = getVmIPAddress(vmId);
		LOGGER.log(Level.SEVERE, "Got IP address for VM " + vmId + ": " + ip);
		vm.setLauncherIP(ip);
	}
	catch (Exception ex)
	{
		LOGGER.log(Level.SEVERE, ex.toString());
	}
	return new ParallelsDesktopVMSlave(vm, this);
}
 
開發者ID:Parallels,項目名稱:jenkins-parallels,代碼行數:22,代碼來源:ParallelsDesktopConnectorSlaveComputer.java

示例8: getAllAvailableNodes

import hudson.model.Node; //導入依賴的package包/類
/**
 * Used to get all available {@link Nodes}s in the {@link Label} that are
 * not the Master node.
 * 
 * @param build
 *            the current build
 * @param set
 *            the {@link Label} assigned to the {@link DTJob}.
 * @return a {@link Set} of all available nodes
 * @throws Exception
 * @since 1.0
 */
public static Set<Node> getAllAvailableNodes(AbstractBuild<?, ?> build)
		throws Exception {
	Set<Node> nodes = new HashSet<Node>();
	checkNodes(build);
	for (Node node : getAssignedNodes(build)) {
		if (node.toComputer().isOnline()) {
			if (node.equals(build.getBuiltOn())) {
				nodes.add(node);
			} else {
				if (node.toComputer().isIdle()) {
					nodes.add(node);
				}
			}
		}
	}

	if (nodes.size() < 2) {
		throw PrintMessages.throwNotEnoughSlaves(nodes.size());
	}
	return nodes;
}
 
開發者ID:bombardier-transportation,項目名稱:distributed-test-job,代碼行數:34,代碼來源:NodeUtils.java

示例9: createEnvVarsForNode

import hudson.model.Node; //導入依賴的package包/類
/**
 * Used define additional environment variable for a particular {@link Node}
 * .
 * 
 * @param node
 *            the {@link Node}
 * @param build
 *            the current build
 * @return a new Entry of a node and it's additional environment variables
 * @throws IOException
 * @throws Exception
 * @since 1.0
 */
public static GenericEntry<Node, EnvVars> createEnvVarsForNode(Node node,
		AbstractBuild<?, ?> build, String listFile) throws IOException,
		Exception {
	if (node != null) {
		String nodeTestEnv = ((DTBuild) build).getTestJob()
				.getSlaveTestEnv();
		String projectName = ((DTBuild) build).getTestJob()
				.getDisplayName();
		EnvVars additionalEnvironment = new EnvVars();
		additionalEnvironment.put("$TEST_ENV", nodeTestEnv + "/");
		additionalEnvironment.put("$TEST_LIST", projectName + "/"
				+ listFile);
		additionalEnvironment.put("$TARGET_SCRIPT", projectName + "/"
				+ FilePathUtils.getPathToTargetScript(build).getName());
		additionalEnvironment.put("$TEST_WS", FilePathUtils
				.getPathToRootProjectWorkspaceOnNode(node, build)
				.getRemote()
				+ "/");
		return new GenericEntry<Node, EnvVars>(node, additionalEnvironment);
	} else {
		return null;
	}
}
 
開發者ID:bombardier-transportation,項目名稱:distributed-test-job,代碼行數:37,代碼來源:NodeUtils.java

示例10: testUnixConfigRoundTrip

import hudson.model.Node; //導入依賴的package包/類
public void testUnixConfigRoundTrip() throws Exception {
    String ami = "ami1";
    String description = "foo ami";

    EC2Tag tag1 = new EC2Tag( "name1", "value1" );
    EC2Tag tag2 = new EC2Tag( "name2", "value2" );
    List<EC2Tag> tags = new ArrayList<EC2Tag>();
    tags.add( tag1 );
    tags.add( tag2 );

    SlaveTemplate orig = new SlaveTemplate(ami, EC2AbstractSlave.TEST_ZONE, null, "default", "foo", InstanceType.M1Large, "ttt", Node.Mode.NORMAL, description, "bar", "bbb", "aaa", "10", "rrr", new UnixData("sudo", "22"), "-Xmx1g", false, "subnet 456", tags, null, false, null, "", true, false, "", false, "");

    List<SlaveTemplate> templates = new ArrayList<SlaveTemplate>();
    templates.add(orig);

    AmazonEC2Cloud ac = new AmazonEC2Cloud("us-east-1", false, "abc", "def", "us-east-1", "ghi", "3", templates);
    hudson.clouds.add(ac);

    submit(createWebClient().goTo("configure").getFormByName("config"));
    SlaveTemplate received = ((EC2Cloud)hudson.clouds.iterator().next()).getTemplate(description);
    assertEqualBeans(orig, received, "amiType");
}
 
開發者ID:hudson3-plugins,項目名稱:ec2-plugin,代碼行數:23,代碼來源:SlaveTemplateTest.java

示例11: printPreBuildInfoSuccess

import hudson.model.Node; //導入依賴的package包/類
/**
 * Used to print a success message indicating that the test case suite
 * generation and the copying of relevant files was successful.
 * 
 * @param printStream
 *            the print stream
 * @param pair
 *            containing the {@link Node} and it's assigned test cases
 * @param path
 *            the path to the remote location where files have been copied
 * @since 1.0
 */
public static void printPreBuildInfoSuccess(PrintStream printStream,
		Entry<Node, List<String>> pair, String path) {
	printStream
			.printf("[PREBUILD-INFO] The test case list for %s Slave Node was successfully generated!%n",
					pair.getKey().getDisplayName());
	printStream.printf(
			"%-15s The %slist.lst contains %d test cases in total.%n", " ",
			pair.getKey().getDisplayName(), pair.getValue().size());
	printStream
			.printf("%-15s The test cases specified in %slist.lst were successfully copied.%n",
					" ", pair.getKey().getDisplayName());
	printStream
			.printf("[PREBUILD-INFO]%n Copying list, target script and test cases files ->%n [TO] %s%n",
					pair.getKey().getDisplayName() + " -> " + path);
}
 
開發者ID:bombardier-transportation,項目名稱:distributed-test-job,代碼行數:28,代碼來源:PrintMessages.java

示例12: executeTest

import hudson.model.Node; //導入依賴的package包/類
/**
 * Used to execute/start a remote process that initializes the testing
 * process.
 * 
 * @param build
 *            the current build
 * @param listener
 *            the build's listener
 * @param entry
 *            containing the {@link Node} and its {@link EnvVars}
 * @return the started process
 * @throws InterruptedException
 * @throws IOException
 * @since 1.0
 */
private Proc executeTest(AbstractBuild<?, ?> build, BuildListener listener,
		Entry<Node, EnvVars> entry) throws InterruptedException,
		IOException {
	final EnvVars vars = NodeUtils.getEnvironment(entry.getKey(),
			entry.getValue());
	final Node node = entry.getKey();

	// Get testing environment on the specific node
	FilePath testEnv = FilePathUtils.getPathToTestEnvOnNode(node, build);

	// Create a remote launcher
	RemoteLauncher remoteLaucher = new RemoteLauncher(listener,
			node.getChannel(), true);

	// Create process starter
	ProcStarter starter = remoteLaucher.launch()
			.cmds(buildShellCmds(vars, node, build)).stdout(listener)
			.stderr(listener.getLogger()).pwd(testEnv.getParent());

	// Launch the process
	Proc proc = remoteLaucher.launch(starter);

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

示例13: getZAPProgramNameWithSeparator

import hudson.model.Node; //導入依賴的package包/類
/**
 * Return the ZAProxy program name with separator prefix (\zap.bat or /zap.sh) depending of the build node and the OS.
 * 
 * @param build
 * @return the ZAProxy program name with separator prefix (\zap.bat or /zap.sh)
 * @throws IOException
 * @throws InterruptedException
 */
private String getZAPProgramNameWithSeparator(AbstractBuild<?, ?> build) throws IOException, InterruptedException {
	Node node = build.getBuiltOn();
	String zapProgramName = "";
	
	// Append zap program following Master/Slave and Windows/Unix
	if( "".equals(node.getNodeName())) { // Master
		if( File.pathSeparatorChar == ':' ) { // UNIX
			zapProgramName = "/" + ZAP_PROG_NAME_SH;
		} else { // Windows (pathSeparatorChar == ';')
			zapProgramName = "\\" + ZAP_PROG_NAME_BAT;
		}
	} 
	else { // Slave
		if( "Unix".equals(((SlaveComputer)node.toComputer()).getOSDescription()) ) {
			zapProgramName = "/" + ZAP_PROG_NAME_SH;
		} else {
			zapProgramName = "\\" + ZAP_PROG_NAME_BAT;
		}
	}
	return zapProgramName;
}
 
開發者ID:jenkinsci,項目名稱:zaproxy-plugin,代碼行數:30,代碼來源:ZAProxy.java

示例14: getTemplates

import hudson.model.Node; //導入依賴的package包/類
/**
 * Multiple templates may have the same label.
 *
 * @return Templates matched to requested label assuming slave Mode
 */
@Nonnull
public List<DockerSlaveTemplate> getTemplates(Label label) {
    List<DockerSlaveTemplate> dockerSlaveTemplates = new ArrayList<>();

    for (DockerSlaveTemplate t : templates) {
        if (isNull(label) && t.getMode() == Node.Mode.NORMAL) {
            dockerSlaveTemplates.add(t);
        }

        if (nonNull(label) && label.matches(t.getLabelSet())) {
            dockerSlaveTemplates.add(t);
        }
    }

    return dockerSlaveTemplates;
}
 
開發者ID:KostyaSha,項目名稱:yet-another-docker-plugin,代碼行數:22,代碼來源:AbstractCloud.java

示例15: tearDown

import hudson.model.Node; //導入依賴的package包/類
@Override
public void tearDown(Run<?, ?> run, FilePath workspace, Launcher launcher, TaskListener listener)
        throws IOException, InterruptedException {
    LOG.info("Shutting down slave");
    listener.getLogger().println("Shutting down slave '" + slaveName + "'.");
    final Node slaveNode = Jenkins.getInstance().getNode(slaveName);
    if (isNull(slaveNode)) {
        throw new IllegalStateException("Can't get node " + slaveName);
    }
    final DockerSlaveSingle node = (DockerSlaveSingle) slaveNode;
    try {
        node.terminate();
    } catch (Throwable e) {
        LOG.error("Can't terminate node", e);
        CloudStatistics.ProvisioningListener.get().onFailure(node.getId(), e);
    }

}
 
開發者ID:KostyaSha,項目名稱:yet-another-docker-plugin,代碼行數:19,代碼來源:DockerSimpleBuildWrapper.java


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