Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Commands With No Output Always Timeout #11

Open
michael-hay opened this issue Sep 19, 2016 · 4 comments
Open

Commands With No Output Always Timeout #11

michael-hay opened this issue Sep 19, 2016 · 4 comments

Comments

@michael-hay
Copy link

michael-hay commented Sep 19, 2016

If you run a command that does not return any output we will sit and poll expecting an output till we hit the timeout.

String serverName = new String("remoteServer");
Sting cmd = new String("Remove-Item "E:\temp\*" -recurse");

    private static String executePowerShellCmd(PowerShell powerShell, String cmd, String timeout) throws InterruptedException {
        printCmd(cmd);
        Map<String, String> myConfig = new HashMap<>();
        myConfig.put("maxWait", timeout);
        PowerShellResponse response = powerShell.configuration(myConfig).executeCommand(cmd);
        return response.getCommandOutput();
    }

    public static void executeRemoteCmd(String cmd, String automationHome, String serverName, String timeout) throws Exception {
        PowerShell powerShell = null;
        try {
            powerShell = PowerShell.openSession();
            System.out.println(executePowerShellCmd(powerShell, "Invoke-Command -ComputerName " + serverName + " {" + cmd + "}", timeout));
        } catch(PowerShellNotAvailableException ex) {
            throw new RuntimeException("Failed to run PowerShell", ex);
        } finally {
            if (powerShell != null)
                 powerShell.close();
        }
    }
@profesorfalken
Copy link
Owner

Hello,

Yes, this is related with the previous issue. As we do not handle the return code of the process we cannot see if it finish if it does not return anything. That happens in your case because you are launching a command to a remote server.

I will see if I can do something similar to what I did in issue #8. I guess I could create a temp script for each command and append a return string to this script. In that case I will be able to guarantee that there is always an output.

@michael-hay
Copy link
Author

A good test command for this is:

Invoke-Command -ComputerName serverName {(Get-Service serviceName).WaitForStatus('Running','02:00:00')}

Thx very much. These classes are quite useful.

@profesorfalken
Copy link
Owner

Hi,

If you use the v1.7 you should have no problem. You only have to enable the remote mode.

Map<String, String> myConfig = new HashMap<>();
myConfig.put("remoteMode", "true");
response = powerShell.configure(myConfig).executeCommand("Invoke-Command -ComputerName serverName {(Get-Service serviceName).WaitForStatus('Running','02:00:00')}");

Best regards

@Tuupertunut
Copy link

Is there any situation where you wouldn't want to use remote mode?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants