Yeti stands for "Yet Extraordinary Test Infrastructure" and is an rspec-based basic validation test for cloud foundry environments.
Under development
This repository contains tests for vcap.
- Ruby 1.9.2
- Bundle >= 1.1
- admin user/password is needed for parallel run, if you don't have it, run serial like:
bundle exec rake full[1]
It is recommended to manage Ruby runtime via RVM or rbenv
- Mac OS X 64bit, 10.6 and above
- Ubuntu 10.04 LTS 64bit
git clone git://github.com/cloudfoundry/vcap-yeti.git
cd vcap-yeti
./update ## this is not required for running administrative test cases
bundle exec rake full
- During the first time, Yeti will prompt you for information about your environment:
- target
- test user/test password
- admin user/admin password
target should be a complete url which starts with 'api.' or 'ccng.'.
This information except password is saved to ~/.bvt/config.yml file.
When run the second time around, Yeti will not prompt for the information again.
Yeti basic:
||Environment Variables ||Function ||Example ||
|VCAP_BVT_TARGET |target environment |api.cloudfoundry.com |
|VCAP_BVT_USER |test user |[email protected] |
|VCAP_BVT_USER_PASSWD |test user password |<MY-PASSWORD> |
|VCAP_BVT_ADMIN_USER |admin user |[email protected] |
|VCAP_BVT_ADMIN_USER_PASSWD |admin user password |<ADMIN-PASSWD> |
Yeti advance:
||Environment Variables ||Function ||Example ||
|VCAP_BVT_SHOW_PENDING |show pending cases |true |
|VCAP_BVT_LONGEVITY |run testing N times |100 |
|VCAP_BVT_CONFIG_FILE |specify config file |***/config.yml |
Service/App related:
||Environment Variables ||Function ||Example ||
|VCAP_BVT_SERVICE_PG_MAXDBSIZE|service quota(MB) |128 |
|SERVICE_BROKER_TOKEN |service broker token |<token> |
|SERVICE_BROKER_URL |service broker url |http://... |
|VCAP_BVT_SERVICE_PLAN |service plan |P100 |
|VCAP_BVT_REDIS_MANIFEST |service manifest |{:vendor=>"redis", :version=>"2.2", :provider=>"core"}|
|VCAP_BVT_RUNTIME |app runtime |{:ruby=>"ruby19", :java=>"java6", :node=>"node"} |
ACL related:
||Environment Variables ||Function ||Example ||
|ACM_URL |acm base url |<URL> |
|ACM_USER |acm user |<user> |
|ACM_PASSWORD |acm user password |<***> |
UAA related:
||Environment Variables ||Function ||Example ||
|VCAP_BVT_ADMIN_CLIENT |admin client of uaa |admin |
|VCAP_BVT_ADMIN_SECRET |admin secret of uaa |adminsecret |
Marketplace gateway related:
||Environment Variables ||Function ||Example ||
|MPGW_TOKEN |specify mpgw token |MPGW_TOKEN=testmarketplacetoken |
|MPGW_URL |specify mpgw url |MPGW_URL=http://test-mpgw.... |
- In order to support parallel running, and administrative test cases, Yeti will ask administrative
account information.
However, yeti will not abuse administrative privileges, just list users, create users,
delete users created by the test script. - rake full use parallel by default, you could run in serial by specifying thread number=1:
bundle exec rake full[1]
- As dev setup has limited resources, we strongly recommend running 1-4 threads against dev_setup.
-
What does "pending" mean and what is the correct number of pending cases?
A: Pending means your target environment is missing some prerequisites, usually a service, framework or runtime.
The number of pending cases depends on your target environment and environment variables.- For example, php/python is not available in the production environment so all php/python related test cases should be pending.
-
What's update.sh?
A: For assets that need to be compiled such as Java applications, Yeti leverages a common blob store to hold all these precompiled assets. Therefore, users do not need maven to build java-based applications locally, the binaries just need to be sync'd from blobs.cloudfoundry.com. update.sh script automatically checks to see if there are new assets, so Yeti users need to run the update.sh script before running Yeti tests. -
What is an example?
A: An Example is an RSpec naming convention for a test case scenario which may include several steps, if any of the steps within an example fail then the test case will be marked as failed. -
Where are binary assets stored?
A: Binary assets are stored in http://blobs.cloudfoundry.com which is a simple Sinatra application with blob service backend hosted on Cloud Foundry. These assets are then synchronized via the update.sh script into the .assets-binaries directory of vcap-yeti. -
How do I submit binary assets?
A: Currently binaries are generated manually based on source code updates to vcap-assets. In the near future, source code updates will trigger a job to compile sources and update blobs.cloudfoundry.com. -
Where is the log file stored?
A: There are runtime log and junit-format report.- Runtime log is stored in ~/.bvt/bvt.[target].log
- Junit-format report is under [yeti_home]/reports. The junitResult.xml is the summary.
-
What runtimes/frameworks/services should my environment have?
Dev setup:- runtimes: java, ruby18, ruby19, node, node06, node08, php, python2, erlangR14B01
- frameworks: java_web, sinatra, grails, rack, play, lift, spring, rails3, node, standalone, php, django, wsgi, otp_rebar
- services: mongodb, mysql, postgresql, rabbitmq, redis, vblob, filesystem
(env variable CLOUD_FOUNDRY_EXCLUDED_COMPONENT can disable components, for details, please check README under vcap/dev_setup.)
Dev instance:
- runtimes: java, java7, ruby18, ruby19, node, node06, node08
- frameworks: java_web, sinatra, grails, rack, play, lift, spring, rails3, node, standalone
- services: mongodb, mysql, postgresql, rabbitmq, redis, vblob
Production:
- runtimes: java, java7, ruby18, ruby19, node, node06, node08
- frameworks: java_web, sinatra, grails, rack, play, lift, spring, rails3, node, standalone
- services: mongodb, mysql, postgresql, rabbitmq, redis
(updated on July 19th, 2012)
-
Runtime errors
Sometimes runtime errors happen during Yeti execution,- 504 Gateway Error: Application fail to be started in 30 seconds
- 502 Internal Error: Application fail to connect to service instance, including provision/un-provision bind/unbind.
- 404 Not Found: Route fail to redirect request to specific application URL
-
Run specific case
User can run specific case via passing spec file with specify line number of an example or group as parameter For example: bundle exec rspec ./spec/simple/rails_console/ruby18_rails3_spec.rb:95 -
Build java-based assets
Please refer to docs/how-to-build-assets.md
- admin
run admin test cases - tests
run core tests in parallel, e.g. rake test[5] (default to 10, max = 16) - full
run full tests in parallel, e.g. rake full[5] (default to 10, max = 16) - random
run all bvts randomly, e.g. rake random[1023] to re-run seed 1023 - java
run java tests (spring, java_web) in parallel
e.g. rake java[5] (default to 10, max = 16) - jvm
run jvm tests (spring, java_web, grails, lift) in parallel
e.g. rake jvm[5] (default to 10, max = 16) - ruby
run ruby tests (rails3, sinatra, rack) in parallel
e.g. rake ruby[5] (default to 10, max = 16) - services
run service tests (mongodb/redis/mysql/postgres/rabbitmq/neo4j/vblob) in parallel
e.g. rake services[5] (default to 10, max = 16) - core
run core tests for verifying that an installation meets minimal Cloud Foundry compatibility requirements
e.g. rake core[5] (default to 10, max = 16) - mcf
run Micro Cloud Foundry tests
e.g. rake mcf[5] (default to 10, max = 16) - rerun_failure
rerun failed cases of the last run
e.g. rake rerun_failure[5] (default to 10, max = 16) - clean
clean up test environment(only run this task after interruption).
1, Remove all apps and services under test user
2, Remove all test users created in admin_user_spec.rb - help
list help commands
To file a bug against Cloud Foundry Open Source and its components, sign up and use our bug tracking system: http://cloudfoundry.atlassian.net