-
Notifications
You must be signed in to change notification settings - Fork 237
/
release.txt
288 lines (211 loc) · 11.4 KB
/
release.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
# Rhodes Release procedure
## Install Rhodes beta
gem uninstall rhodes
gem install rhodes --pre --no-ri --no-rdoc
add <gem>/bin to PATH environment variable
copy rhobuild.yml from rhodes to gem
## Test procedures
Remove Rhodes application from Device and Simulators, clean Simulator and remove files from device
### Framework spec
Run on simulator from gem folder:
rake run:win32:framework_spec
rake run:android:framework_spec
rake run:iphone:framework_spec
Build and Run on device:
rake device:wm:production
rake device:android:production
rake device:iphone:production
### Phone spec
Run on simulator from gem folder:
rake run:win32:phone_spec
rake run:android:phone_spec
rake run:iphone:phone_spec
rake run:bb:phone_spec
rake run:wp:phone_spec
Build and Run on device:
rake device:wm:production
rake device:android:production
rake device:iphone:production
rake device:bb:production
rake device:wp:production
### New generated application
rhodes app mytest
Run on RhoSimulator from 'mytest' folder:
rake run:win32:rhosimulator
Run on Platform Simulator from 'mytest' folder.
### System-api-samples
git clone git@github.com:rhomobile/rhodes-system-api-samples.git
* Check application loading image (loading.png) - for iPhone you should see image correspondent to your device and orientation(only for iPad).
* My Contacts : you should see contacts from SIM card and phone memory(if available), create new contact, go to phone book, you should see new record. Go back to app, edit some properties, than delete. Make sure that record deleted from phone book
* My Events : you should see events from Calendar(if available), create new event, go to phone calendar, you should see new event. Go back to app, edit some properties, than delete. Make sure that event deleted from phone calendar
* My Location: go outside building and wait 5 minutes, you should see your coordinates
* My camera Images:
- choose picture: you should see list of phone pictures, <br/>select one, it should displayed by rhodes
- take picture: camera should open, make photo, rhodes should display new picture
* Signature Capture test(only for iPhone and Android): open "My Signatures" page. Press [Take Signature] - new screen with custom toolbar/set of buttons(depends of platform) opened. Draw signature by you finger. select [Done]/[OK] button. You should see you signature as image on signature page.
* Screen rotation callback
* Select date/time: press Edit link for each edit, first time press OK, second time press Cancel:
- Date and Time: you should see 2 fields Date, Time
- Date only: only date should be displayed
- Time only: only time should be displayed
- rotate phone - screen should be rotated
When you reopen DateTime Picker you should see current date time always.
* Select date/time using AJAX: press Edit link or just touch field for each edit, first time press OK, second time press Cancel:
- Date and Time: you should see 2 fields Date, Time
- Date only: only date should be displayed
- Time only: only time should be displayed
Setting date/time should be processed without reload page. When you reopen DateTime Picker you should see date time from field (previously set).
* Alerts: select each link. you should see corresponding actions
* Ringtones: all phone ring-tones should be listed. Select 2 of them - you should listen some sound. On second press [stop], sound should stopped immediately
* AsyncHttpTest: Apache license page should be displayed
* AsyncHttpsTest: gmail login page should be displayed
* Async Download file: you should see image with many r
* System test:
- check system settings
- press JS popup: you should see javascript alert
- press execute_js: you should see javascript alert (Blackberry is not supported)
* Localization test: you should see Russian text, dates and currency in various formats
* Dynamic menu test:
- see description on the page and press menu button, check all items
- press call callback menu item: you should see text Callback called at the bottom of the page
- press 'Test back with alert', enter some text to edit, when press Back button - you should see<br/> Alert with message 'Do you want to leave?'. Press No - text from edit should not disappear. <br/>Press back again, on alert press Yes - you should return to dynamic menu test
- press 'Test back with close', when press Back button - application should exit
* Rho tests: press on each link, you should see corresponding page with message
* Barcode recognize test: open "My Barcode recognize ..." press [scan] under image - see Alert with correct recognized code. Press [Take Picture] for make shot of barcode by camera and see Alert with recognized code or "[]" if not recognized.
* Bluetooth Chat Demo:
1. Phone and external Bluetooth device (for example external GPS Bluetooth device) - for Android, Windows Mobile and Blackberry only.
- pair device with phone
- open "Bluetooth Chat Demo" page and press "Connect as Client"
- select external device
- you should see received data from device
2. Phone and another phone. - for iPhone only another iPhone/iPad supported !
- pair devices (skip for iPhones)
- open "Bluetooth Chat Demo" on both devices
- select "Connect as Server" on first device and "Connect as Client" on second device
- on second device select first device from list of Bluetooth devices
- write message and press [Send](on first or second device) - on another device you should see received message
* Custom URI schemes:
- mailto should invoke send mail display with filled reviver field
- tel should display phone app with filled phone number
- sms should invoke sms sending screen with filled phone number
* Select some link(not home page), move app to background, when click on app icon, you should see selected page(not home page)
* On iPhone: Go to "Native bar test" page, select "No bar", "Toolbar", "Tab bar" one-by-one. On tab bar page select tabs one-by-one.
After each of operation, trigger "Out of memory" error by selecting simulator menu item "Hardware -> Simulate memory warning".
Expected behavior - silent handle of this event. There MUST NOT be crash.
* On iPhone and Android: Go to "Native bar test" page, select "Tab bar". Select "Switch to Tab 1" - you should switched to Tab 1 with Home tasklist screen.
* On iPhone and Android: Go to "Native bar test" page, select "Tab bar". Scroll screen up and down: header bar should “reseating” properly at the top of the screen.
* Open Settings page, Login with empty credentials, open Image - you should see some images there.
### Store
git clone git@github.com:rhomobile/store.git
Run and Login with empty credentials, you should see Products and Customers
### Network connectivity test on each platform device
* turn ON - wifi and GPRS
* run system api samples, run AsyncHttp test - it should pass
* move app to background, turn OFF wifi
* run system api samples, run AsyncHttp test - it should pass
* move app to background, turn OFF GPRS
* run system api samples, run AsyncHttp test - it should failed
* move app to background, turn ON GPRS
* run system api samples, run AsyncHttp test - it should pass
* move app to background, turn OFF GPRS, turn ON WIFI
* run system api samples, run AsyncHttp test - it should pass
## Install Eclipse plug-in beta
* Install Eclipse >=3.6
* Install plug-in: http://rhostudio.s3.amazonaws.com/beta
## Test Eclipse plug-in
See [http://rhostudio.rhomobile.com]
* Create new Rhodes application
* Run and Debug using RhoSimulator: set breakpoint, see variables, see application log in console
##Install Rhodes Eclipse
Download and unzip: http://rhostudio.s3.amazonaws.com/bundle/win/RhoStudio.zip
## Test Rhodes Eclipse
Same procedure as for plug-in
##Build Rhodes gem
### Local machine steps
git clone git@github.com:rhomobile/rhodes.git
1. CHANGELOG
2. Make sure the major.minor.patch version
match what you want to release:
$ rake get_version
Use set_version to update if it is not correct:
$ rake set_version[2.3.1]
3. Edit rhodes.gemspec, set s.version :
BETA:
s.version = "2.3.1.beta.1"
RELEASE:
s.version = Rhodes::VERSION
4. Build RhoSimulator:
rake build:win32:rhosimulator
1. Zip files in folder 'rhodes\platform\win32\RhoSimulator' and copy to:
http://rhosimulator.s3.amazonaws.com/RhoSimulator
5. Build IronRuby:
rake build:wp:ironruby
6. Push changes to git
git commit -m "bumping version for release"
git push
7. Put tag:
git tag -m "rhodes release" 2.3.1 0548dea055f0aa00642a66c18ea207bd7344dda7
git push --tags
### cijoe steps:
1. Run commands:
ssh rhomobile@cijoe.rhomobile.com
cd ~/rhodes-release
rm -rf *
git reset --hard
git pull
2. Copy 'rhodes\platform\wp7\IronRuby\bin\Silverlight3Release' to cijoe from local computer
3. Copy 'rhodes\platform\win32\RhoSimulator' to cijoe from local computer
4. Copy 'rhodes\platform\osx\bin\RhoSimulator\Rhosimulator.app
5. Build and push gem:
rake gem
gem push rhodes-<version>.gem
##Build Eclipse plug-in
0. download Eclipse for RAP/RPC developer
1. clone git repository (git@github.com:rhomobile/rhostudio.git)
2. Import project into Eclipse (File/Import/'Existing project into Workspace')
3. Install additional components
3.1 DLTK 2.0 (eclipse update site - http://download.eclipse.org/technology/dltk/updates/)
3.2 Egit plugin (eclipse update site - http://download.eclipse.org/egit/updates)
4. Import into workspace DLTK plugins
Select 'Plugins and Fragments' item in Import Dialog and going to 'Selection' page.
In left list of plugins select items with names:
org.eclipse.dltk.debug
org.eclipse.dltk.ruby.ui
org.eclipse.dltk.ui
org.eclipse.dltk.console.ui
org.eclipse.dltk.console
org.eclipse.dltk.core
org.eclipse.dltk.debug.ui
org.eclipse.egit.ui
After import procedure in workspace should appears seven plugin projects.
5. Add imported plugins to java build paths (Project properties/Java build path/Libraries/Add JAR).
6. Select imported plugins in Project properties/Java build path/Libraries/Order and Export
7. Build and run Eclipse configuration
8. Export. Select File/Export/Plugin Development
8.1 For update site need select - Deployable features
8.2 For installer (or for export only Rhostudio plugin) need select Deployable plugin and fragments
##Build Rhodes Eclipse
1. Install (http://www.eclipse.org/egit/)
2. import plugin org.eclipse.platform
3. Start export product (File/Export/Plugin development/Eclipse product)
4. Select destination folder and export
##Build & Test RhoSimulator for Mac
1. Download and install Qt Libraries for Mac:
* Go to [http://qt-project.org/downloads](http://qt-project.org/downloads)
* Jump to `Qt libraries`
* Download [Qt libraries 4.8.4 for Mac](http://releases.qt-project.org/qt4/source/qt-mac-opensource-4.8.4.dmg) (185 MB)
* Install Qt libraries for Mac
2. Build RhoSimulator for Mac:
$ cd <rhodes>
$ rake build:rhosimulator
3. Test RhoSimulator for Mac:
* Use `rhodes-system-api-samples`
* Make sure you have an appropriate `rhosimulator/rhosimconfig.txt`, e.g.:
rhodes_path='...full path to rhodes...'
app_name='rhodes-system-api-samples'
debug_port=9000
debug_host='127.0.0.1'
platform='APPLE'
* Run RhoSimulator for Mac:
cd <rhodes-system-api-samples>
rake run:rhosimulator