[buildout] eggs-directory = {{ eggs_directory }} develop-eggs-directory = {{ develop_eggs_directory }} offline = true parts = deploy-unit-test deploy-scalability-test request-resilient-kvm deploy-standalone-resiliency-test [directory] recipe = slapos.cookbook:mkdirectory home = ${buildout:directory} etc = ${:home}/etc/ var = ${:home}/var/ srv = ${:home}/srv/ bin = ${:home}/bin/ tmp = ${:home}/tmp/ log = ${:var}/log/ services = ${:etc}/service/ scripts = ${:etc}/run/ [deploy-scalability-test] recipe = slapos.cookbook:wrapper # XXX: put it in etc/run in case of scalability test so that it runs automatically. wrapper-path = ${directory:bin}/runKVMResiliencyTestSuite testnode-parameters = --test-result-path={{ slapparameter_dict.get('test-result-path') }} --revision={{ slapparameter_dict.get('test-suite-revision') }} --node-title={{ slapparameter_dict.get('scalability-launcher-title') }} --test-suite={{ slapparameter_dict.get('test-suite') }} --test-suite-master-url={{ slapparameter_dict.get('test-suite-master-url') }} --log-path=${directory:log} kvm-test-parameters = server_url=${slap-connection:server-url} key_file=${slap-connection:key-file} cert_file=${slap-connection:cert-file} computer_id=${slap-connection:computer-id} partition_id=${slap-connection:partition-id} software=${slap-connection:software-release-url} namebase=kvm root_instance_name='${request-resilient-kvm:name}' command-line = {{ bin_directory }}/runResiliencyScalabilityTestNode ${:testnode-parameters} ${:kvm-test-parameters} [deploy-unit-test] recipe = collective.recipe.template #testnode-parameters = --test-result-path={{ slapparameter_dict.get('test-result-path') }} --revision={{ slapparameter_dict.get('test-suite-revision') }} --node-title={{ slapparameter_dict.get('scalability-launcher-title') }} --test-suite={{ slapparameter_dict.get('test-suite') }} --test-suite-master-url={{ slapparameter_dict.get('test-suite-master-url') }} --log-path=${directory:log} kvm-test-parameters = server_url=${slap-connection:server-url} key_file=${slap-connection:key-file} cert_file=${slap-connection:cert-file} computer_id=${slap-connection:computer-id} partition_id=${slap-connection:partition-id} software=${slap-connection:software-release-url} namebase=kvm root_instance_name='${request-resilient-kvm:name}' input = inline: #!/bin/sh exec {{ bin_directory }}/runResiliencyUnitTestTestNode $@ ${:kvm-test-parameters} output = ${directory:bin}/runTestSuite mode = 755 [deploy-standalone-resiliency-test] # Used to manually run the KVM test if we don't have a running testnode. recipe = slapos.cookbook:wrapper wrapper-path = ${directory:bin}/runStandaloneResiliencyTestSuite command-line = {{ bin_directory }}/runStandaloneResiliencyTest --test-suite-title=kvm ${:kvm-test-parameters} kvm-test-parameters = server_url=${slap-connection:server-url} key_file=${slap-connection:key-file} cert_file=${slap-connection:cert-file} computer_id=${slap-connection:computer-id} partition_id=${slap-connection:partition-id} software=${slap-connection:software-release-url} namebase=kvm root_instance_name='${request-resilient-kvm:name}' [request-resilient-kvm] <= slap-connection recipe = slapos.cookbook:request software-url = ${slap-connection:software-release-url} software-type = kvm-resilient name = Resilient KVM (Root Instance) {% for key, value in slapparameter_dict.get('cluster', {}).iteritems() -%} config-{{ key }} = {{ dumps(value) }} {% endfor -%} config-virtual-hard-drive-url = ${slap-parameter:virtual-hard-drive-url} config-virtual-hard-drive-md5sum = ${slap-parameter:virtual-hard-drive-md5sum} config-resiliency-backup-periodicity = */5 * * * * config-resilient-clone-number = 1 config-ignore-known-hosts-file = false return = ipv6 # XXX What to do? sla-computer_guid = ${slap-connection:computer-id} [slap-parameter] virtual-hard-drive-url = http://www.nexedi.org/static/slapos/kvm_resiliency_test/virtual.qcow2 virtual-hard-drive-md5sum = 465e1024447997e7b86ee2e5151e031b