Get Started - adcade/saucey GitHub Wiki
#Pour a glass (Init & Install) To make things simpler, we'll use Robo for all of our task management needs. Lets install it! Install all dependancies through composer, if you run in to any issues please see the wiki.
For all instances of <tag> replace it with the tag for the test suite. For example, for my tests in features/getSaucey the tag is saucey.
-
From the root of the project, run:
curl -sS https://getcomposer.org/installer | php -
Then run:
php composer.phar install -
From here, robo takes control, run:
bin/robo init -
For testing with Selenium
locally:bin/robo saucey:tipsy '<tag> <browser>'or, if you want to test with PhantomJS (Headless/Lightweight)
bin/robo saucey:tipsy '<tag>'**Note: Not all tests will work with PhantomJS, i.e. @alert
-
For testing against the
cloud, you have to do three things (see drunk). Set up SauceLabs to use your account:vendor/sauce/connect/bin/sauce_connect user_name access_keyand:
vendor/sauce_config user_name access_keythen, run:
bin/robo saucey:drunk '<tag> <environment> <browser>'
##Winery
-
Run the
Winery Test Suitewith:bin/robo winery:testNotice this opens
report/saucey_report_winery_test.html -
Additionally, you can just open the
wineryvia:bin/robo wineryThen, go to http://127.0.0.1:7890
Be sure to checkout the
Browser-Based Inspector@ http://127.0.0.1:7890/client/#anonymous
##Shots! (examples) ###Local w/ Selenium - Tipsy
-
Given you've installed via
init,install&bin/robo initfrom above... -
Run local examples via:
bin/robo saucey:tipsy 'form firefox'or
bin/robo saucey:tipsy 'web chrome'or
bin/robo saucey:tipsy 'api'or
bin/robo saucey:tipsy 'shell' -
Robo should be running the test suite, upon completion it should open a newly generated report.
-
reports/saucey_report.htmlshould be opened, you should see a bunch of tests that look like:
Feature: SOAP & REST API Functionality
As a tester
I want to make sure api features are up and running
So that I can automate continuous integration and regression tests using it
@api @get
Scenario: Make and validate a GET request
Given send a GET request to "/comments?postId=1&id=1"
Then the response code should be 200
And the response should contain json:
"""
[
{
"postId": 1,
"id": 1,
"name": "id labore ex et quam laborum",
"email": "[email protected]",
"body": "laudantium enim quasi est quidem magnam voluptate ipsam eos\ntempora quo necessitatibus\ndolor quam autem quasi\nreiciendis et nam sapiente accusantium"
}
]###Cloud w/ SauceLabs - Drunk
-
Given you've installed via
init,install&bin/robo initfrom above... -
To point saucey to SauceLabs, you'd need your
user_nameandaccess_key. Sign up and register for a free SauceLabs account. -
Get your username and api-key. Should be available via /account. Copy the info into your clipboard.
-
Open the
behat.ymlfile with your favorite IDE and replace all instances ofusername:api-keywith your username (used to log in) and api-key. Save. -
Run a sanity suite via:
bin/robo saucey:drunk 'web mac chrome' -
Then, go to https://saucelabs.com/account and view your running/completed tests. Navigate through and download meta-data, screenshots and video recordings of the entire suite.
####localhost testing on the cloud To test something on a localhost in the cloud, you can open a tunnel with sauce connect. With your username and api-key/access_key from the steps above, run:
vendor/bin/sauce_config user_name access_key
To start the connect tunnel:
vendor/sauce/connect/bin/sauce_connect
###Mobile & Tablet ####For iOS:
bin/robo saucey:drunk '<tag> ios_phone'
bin/robo saucey:drunk '<tag> ios_tablet'
bin/robo saucey:drunk '<tag> ios_tablet_landscape'
####For Android:
bin/robo saucey:drunk '<tag> android_phone'
bin/robo saucey:drunk '<tag> android_tablet'
bin/robo saucey:drunk '<tag> android_tablet_landscape'
On Mac OS X, (with the exception of LAMP for Windows) saucey requires the below dependancies. For now, the Pour a glass section above should cover all dependancies. However, if there are errors thrown upon running php composer.phar install or php composer.phar update in terminal you can reference the sources below. They should also be maintained.
- XCode & Developer Tools
- Java JDK, see documentation
- cURL
-
WAMP
Windows Only - PHP just incase, should be covered by composer.