calabash-cucumber 0.9.127.pre1 → 0.9.128

Sign up to get free protection for your applications and to get access to all the features.
@@ -44,28 +44,13 @@ def build(options={:build_dir=>"Calabash",
44
44
  res
45
45
  end
46
46
 
47
- def console(options={:script => "irb_ios5.sh"})
48
- path = File.join(@source_dir,".irbrc")
49
- if File.exists?(".irbrc")
50
- old_str = File.read(".irbrc")
51
- new_str = File.read(path)
52
- if old_str != new_str
53
- puts "Moving old .irbrc file to .irbrc.old"
54
- FileUtils.mv(".irbrc", ".irbrc.old")
55
- puts "Copying calabash-ios .irbrc file to current directory..."
56
- FileUtils.cp(path, ".")
57
- end
58
- else
59
- puts "Copying calabash-ios .irbrc file to current directory..."
60
- FileUtils.cp(path, ".")
61
- end
62
-
63
- if !File.exists?(options[:script])
64
- puts "Copying calabash-ios #{options[:script]} file to current directory..."
65
- FileUtils.cp(File.join(@source_dir,options[:script]), ".")
47
+ def console
48
+ unless ENV['IRBRC']
49
+ path = File.expand_path(File.join(@script_dir,".irbrc"))
50
+ ENV['IRBRC'] = path
66
51
  end
67
- puts "Running irb with ./.irbrc..."
68
- system("./#{options[:script]}")
52
+ puts "Running irb..."
53
+ exec("irb")
69
54
  end
70
55
 
71
56
 
@@ -13,9 +13,6 @@ def calabash_scaffold
13
13
  exit 2 unless STDIN.gets.chomp == ''
14
14
 
15
15
  FileUtils.cp_r(@source_dir, @features_dir)
16
- FileUtils.mv "#{@features_dir}/.irbrc", "."
17
- FileUtils.mv "#{@features_dir}/irb_ios4.sh", "."
18
- FileUtils.mv "#{@features_dir}/irb_ios5.sh", "."
19
16
 
20
17
  msg("Info") do
21
18
  puts "Features subdirectory created. \n"
@@ -25,5 +25,6 @@ Gem::Specification.new do |s|
25
25
  s.add_dependency( "httpclient","2.2.7")
26
26
  s.add_dependency( "bundler", "~> 1.1")
27
27
  s.add_dependency( "run_loop", "0.0.3" )
28
+ s.add_dependency( "awesome_print")
28
29
 
29
30
  end
@@ -33,6 +33,13 @@ Then /^I (?:press|touch) the "([^\"]*)" button$/ do |name|
33
33
  sleep(STEP_PAUSE)
34
34
  end
35
35
 
36
+ Then /^I (?:press|touch) (?:input|text) field number (\d+)$/ do |index|
37
+ index = index.to_i
38
+ screenshot_and_raise "Index should be positive (was: #{index})" if (index<=0)
39
+ touch("textField index:#{index-1}")
40
+ sleep(STEP_PAUSE)
41
+ end
42
+
36
43
  Then /^I (?:press|touch) the "([^\"]*)" (?:input|text) field$/ do |name|
37
44
  touch("textField placeholder:'#{name}'")
38
45
  sleep(STEP_PAUSE)
@@ -90,7 +97,10 @@ Then /^I fill in "([^\"]*)" with "([^\"]*)"$/ do |text_field, text_to_type|
90
97
  end
91
98
 
92
99
  Then /^I use the native keyboard to enter "([^\"]*)" into the "([^\"]*)" (?:text|input) field$/ do |text_to_type, field_name|
93
- raise "Native keyboard entering is not yet implemented on iOS"
100
+ macro %Q|I touch the "#{field_name}" text field|
101
+ await_keyboard()
102
+ keyboard_enter_text(text_to_type)
103
+ sleep(STEP_PAUSE)
94
104
  end
95
105
 
96
106
  Then /^I fill in text fields as follows:$/ do |table|
@@ -105,11 +115,13 @@ Then /^I enter "([^\"]*)" into (?:input|text) field number (\d+)$/ do |text, ind
105
115
  set_text("textField index:#{index-1}",text)
106
116
  end
107
117
 
108
- Then /^I use the native keyboard to enter "([^\"]*)" into (?:input|text) field number (\d+)$/ do |text, index|
109
- raise "Native keyboard entering is not yet implemented on iOS"
118
+ Then /^I use the native keyboard to enter "([^\"]*)" into (?:input|text) field number (\d+)$/ do |text_to_type, index|
119
+ macro %Q|I touch text field number #{index}|
120
+ await_keyboard()
121
+ keyboard_enter_text(text_to_type)
122
+ sleep(STEP_PAUSE)
110
123
  end
111
124
 
112
-
113
125
  When /^I clear "([^\"]*)"$/ do |name|
114
126
  macro %Q|I enter "" into the "#{name}" text field|
115
127
  end
@@ -507,7 +507,7 @@ EOF
507
507
  body = @http.get(options[:uri], options[:body]).body
508
508
  end
509
509
  break
510
- rescue HTTPClient::TimeoutError => e
510
+ rescue HTTPClient::TimeoutError, HTTPClient::KeepAliveDisconnected => e
511
511
  if count < CAL_HTTP_RETRY_COUNT-1
512
512
  sleep(0.5)
513
513
  @http.reset_all
@@ -519,6 +519,7 @@ EOF
519
519
  puts "Failing... #{e.class}"
520
520
  raise e
521
521
  end
522
+
522
523
  rescue Exception => e
523
524
  if retryable_errors.include?(e)
524
525
  if count < CAL_HTTP_RETRY_COUNT-1
@@ -1,6 +1,6 @@
1
1
  module Calabash
2
2
  module Cucumber
3
- VERSION = "0.9.127.pre1"
3
+ VERSION = "0.9.128"
4
4
  FRAMEWORK_VERSION = "0.9.126"
5
5
  end
6
6
  end
@@ -1,6 +1,8 @@
1
1
  require 'rubygems'
2
2
  require 'irb/completion'
3
3
  require 'irb/ext/save-history'
4
+ require 'awesome_print'
5
+ AwesomePrint.irb!
4
6
 
5
7
  ARGV.concat [ "--readline",
6
8
  "--prompt-mode",
metadata CHANGED
@@ -1,15 +1,15 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: calabash-cucumber
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.9.127.pre1
5
- prerelease: 8
4
+ version: 0.9.128
5
+ prerelease:
6
6
  platform: ruby
7
7
  authors:
8
8
  - Karl Krukow
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-12-19 00:00:00.000000000 Z
12
+ date: 2013-01-21 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: cucumber
@@ -155,6 +155,22 @@ dependencies:
155
155
  - - '='
156
156
  - !ruby/object:Gem::Version
157
157
  version: 0.0.3
158
+ - !ruby/object:Gem::Dependency
159
+ name: awesome_print
160
+ requirement: !ruby/object:Gem::Requirement
161
+ none: false
162
+ requirements:
163
+ - - ! '>='
164
+ - !ruby/object:Gem::Version
165
+ version: '0'
166
+ type: :runtime
167
+ prerelease: false
168
+ version_requirements: !ruby/object:Gem::Requirement
169
+ none: false
170
+ requirements:
171
+ - - ! '>='
172
+ - !ruby/object:Gem::Version
173
+ version: '0'
158
174
  description: calabash-cucumber drives tests for native iOS apps. You must link your
159
175
  app with calabash-ios-server framework to execute tests.
160
176
  email:
@@ -180,9 +196,6 @@ files:
180
196
  - calabash-cucumber.gemspec
181
197
  - doc/calabash-ios-help.txt
182
198
  - epl-v10.html
183
- - features-skeleton/.irbrc
184
- - features-skeleton/irb_ios4.sh
185
- - features-skeleton/irb_ios5.sh
186
199
  - features-skeleton/my_first.feature
187
200
  - features-skeleton/step_definitions/calabash_steps.rb
188
201
  - features-skeleton/step_definitions/my_first_steps.rb
@@ -280,6 +293,7 @@ files:
280
293
  - lib/calabash-cucumber/tests_helpers.rb
281
294
  - lib/calabash-cucumber/version.rb
282
295
  - lib/calabash-cucumber/wait_helpers.rb
296
+ - scripts/.irbrc
283
297
  - scripts/data/.GlobalPreferences.plist
284
298
  - scripts/data/clients.plist
285
299
  - scripts/data/com.apple.Accessibility.plist
@@ -299,9 +313,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
299
313
  required_rubygems_version: !ruby/object:Gem::Requirement
300
314
  none: false
301
315
  requirements:
302
- - - ! '>'
316
+ - - ! '>='
303
317
  - !ruby/object:Gem::Version
304
- version: 1.3.1
318
+ version: '0'
305
319
  requirements: []
306
320
  rubyforge_project:
307
321
  rubygems_version: 1.8.23
@@ -310,3 +324,4 @@ specification_version: 3
310
324
  summary: Client for calabash-ios-server for automated functional testing on iOS
311
325
  test_files:
312
326
  - features/step_definitions/calabash_steps.rb
327
+ has_rdoc:
@@ -1,2 +0,0 @@
1
- #!/bin/bash
2
- IRBRC=.irbrc OS=ios4 irb
@@ -1,2 +0,0 @@
1
- #!/bin/bash
2
- IRBRC=.irbrc irb