Richard Johansson
Richard Johansson

Reputation: 420

How to capture output from a remote command in Capistrano?

I want to run a remote command (git diff of current_revision and HEAD in a few folders) and capture the output.

I've tried run("git diff rev1 rev2 -- folder | cat"), but the method always returns seems to return nil (even when I can see the diff output in the Capistrano output).

Any ideas? Can I use different means of piping the command, or anything like that? Im not a Unix wizard, so it could be something trivial Im missing here.

Upvotes: 23

Views: 15879

Answers (2)

gmsharky
gmsharky

Reputation: 131

If you want to capture the output of multiple hosts, use run with a block: e.g.:

 desc "capture output from multiple servers"
  task :capture_multiple_servers, :roles => [:some_servers] do
    results = {}
    run "hostname --fqdn" do |channel, stream, data|
      if stream == :out
        results[channel[:host]] = [] unless results.key?(channel[:host])
        results[channel[:host]] << data if stream == :out
      end
    end
    puts "Your results were:"
    results.keys.sort.each do | host |
      puts "#{host}:#{results[host].join}"
    end
  end

Upvotes: 6

Heikki
Heikki

Reputation: 15417

Maybe capture?

"The capture helper will execute the given command on the first matching server, and will return the output of the command as a string."

https://github.com/capistrano/capistrano/wiki/2.x-DSL-Action-Inspection-Capture

Upvotes: 39

Related Questions