avdi / greenletters Goto Github PK
View Code? Open in Web Editor NEWRuby console automation a la Expect
Ruby console automation a la Expect
In certain cases, time_to_live
could be high, but there is no way to control this with wait_for
. You can control it at instantiation, using timeout: xx
, but for some applications you may only want to control it for a single wait.
Is there any way to update this? or is this a limitation of the ruby library? I attempted to use .kill!
with SIGWINCH
to force it to update to my terminal width, but unsurprisingly that didn't work. I'm not experienced with PTYs at all, so this is all a bit of a mystery to me.
A question more than an issue...
I am interacting with a shell a la: @adv = Greenletters::Process.new("/bin/sh",:transcript => $stdout)
I want to parse what is returned from the shell in order to make decisions about which command to send next. I can see what is returned in $stdout. Ok. If I send the transcript elsewhere - like to @transcript, I get peculiar behavior related to IO issues that are a little above my comfort zone.
Can you describe a way of accessing / parsing what is returned after I send a @adv << command + "\n" ?
Thanks,
M
I believe there's a typo in the timeout cucumber step definition, namely that :"default"
is used whereas elsewhere "default"
is used.
This causes a default process to not be found when specifying a timeout for it.
The two possible fixes are:
:"default"
with "default"
:default
.I chose the latter when rebuilding the gem locally, though also confirmed the former fixed the issue.
Colourised terminal output prevents correct matching.
I've fixed this in greenletters.rb
by modifying the beginning of OutputTrigger#match_one
. This should be patched and the same change made to OutputTrigger#match_multiple
also.
def match_one(process)
#scanner = process.output_buffer
# Patched to strip term colour output from process stdout.
# Author:: N David Brown
scanner = StringScanner.new(process.output_buffer.string.gsub(/(\e\[([\d;]+)m)+/,''))
I'm using Ruby 2.0.0 and trying to automate password protecting a zip file using the zip command. It asks for a password and then the verification, but sending '\n' isn't triggering the next step. It works on a mac with the same ruby version.
zip = Greenletters::Process.new("zip -e #{zipfile_name} #{filename}", :transcript => $stdout)
zip.start!
zip.wait_for(:output, /Enter password:/i)
zip << "#{password}\n"
zip.wait_for(:output, /Verify password:/i)
zip << "#{password}\n"
The error is:
<path>/vendor/bundle/ruby/2.0.0/gems/greenletters-0.3.0/lib/greenletters.rb:648:in `process_interruption': Interrupted (timeout) while waiting for output matching /Verify password:/. (Greenletters::SystemError)
Any suggestions?
Platform: Mandriva 2008.0
Ruby version: ruby 1.8.6 (2007-03-13 patchlevel 0) [i586-linux-gnu]
The following code:
#!/usr/bin/ruby
require 'rubygems'
require 'greenletters'
target = Greenletters::Process.new("echo Hello, World!", :transcript => $stdout)
target.on(:exit) do |process|
puts "end"
end
puts "Start test 1"
target.start!
target.wait_for(:output, /World/)
puts "End"
produces error:
/usr/lib/ruby/gems/1.8/gems/greenletters-0.1.0/lib/greenletters.rb:245:in `call': undefined method `exitstatus' for nil:NilClass (NoMethodError) from /usr/lib/ruby/gems/1.8/gems/greenletters-0.1.0/lib/greenletters.rb:549:in `check_trigger' from /usr/lib/ruby/gems/1.8/gems/greenletters-0.1.0/lib/greenletters.rb:635:in `catchup_trigger!' from /usr/lib/ruby/gems/1.8/gems/greenletters-0.1.0/lib/greenletters.rb:339:in `add_nonblocking_trigger' from /usr/lib/ruby/gems/1.8/gems/greenletters-0.1.0/lib/greenletters.rb:324:in `on' from ./greenbug.rb:6
Is this ruby version supported?
Thank you
Andrea Galimberti
You have a step containing succesfully
. This should be successfully
, note the extra 's'.
Hey,
So code:
require 'greenletters'
adv = Greenletters::Process.new("ssh [email protected]", :transcript => $stdout)
adv.on(:output, /password/i) do |process, match_data|
adv << "mypassword\n"
end
puts "Starting adventure..."
adv.start!
adv.wait_for(:output, /Last /i)
adv << "touch afile\n"
command line output:
ruby cc.rb
/home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:275: Use RbConfig instead of obsolete and deprecated Config.
Starting adventure...
[email protected]'s password: /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:131:in block in initialize': wrong number of arguments (2 for 0) (ArgumentError) from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:167:in
call'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:167:in match_one' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:158:in
call'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:549:in check_trigger' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:540:in
block in handle_triggers'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:538:in each' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:538:in
handle_triggers'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:478:in process_output' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:455:in
block (2 levels) in process_events'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:455:in each' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:455:in
block in process_events'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:588:in block in handle_child_exit' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:597:in
handle_eio'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:587:in handle_child_exit' from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:440:in
process_events'
from /home/jumpingcloud/.rvm/gems/ruby-1.9.3-p194/gems/greenletters-0.1.0/lib/greenletters.rb:330:in wait_for' from cc.rb:14:in
It's getting in but not touching that file.
What am I doing wrong?
Thanks,
Chris
I am on Mac OS X 10.8 using ruby 1.9.3p194 and greenletters gem version 0.2.0.
When executing the following relevant code..
cmd = "avidemux2_cli --rebuild-index --load \"#{ifile}\" --output-format MP4 --save \"#{ofile}\" --quit"
# set up process
mux = Greenletters::Process.new(cmd)
# handle safe mode question
mux.on(:output, /do you want to use that mode/i) do |process, match_data|
mux << "n\n"
end
mux.start!
mux.wait_for(:exit)
puts "ok" if $? == 0
I get an exception
greenletters-0.2.0/lib/greenletters.rb:525:in `process_error': process_error() (NotImplementedError)
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:471:in `block (2 levels) in process_events'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:471:in `each'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:471:in `block in process_events'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:605:in `block in handle_child_exit'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:614:in `handle_eio'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:604:in `handle_child_exit'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:456:in `process_events'
from /Users/Tim/.rvm/gems/ruby-1.9.3-p194@global/gems/greenletters-0.2.0/lib/greenletters.rb:337:in `wait_for'
from /Users/Tim/bin/muxtest.rb:82:in `remux'
Any idea what I'm doing wrong here?
Also, will my check of $? return the exit status of the child process or is there some other way I should check for successful execution?
Cheers,
Tim
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.