poolparty 0.2.84 → 1.2.2
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +7 -0
- data/License.txt +1 -1
- data/PostInstall.txt +1 -1
- data/README.txt +13 -22
- data/Rakefile +26 -35
- data/VERSION.yml +4 -0
- data/bin/cloud +24 -3
- data/bin/cloud-bootstrap +31 -0
- data/bin/cloud-configure +36 -20
- data/bin/{pool-console → cloud-console} +0 -0
- data/bin/cloud-contract +7 -7
- data/bin/cloud-describe +28 -0
- data/bin/cloud-expand +13 -6
- data/bin/cloud-handle-load +3 -3
- data/bin/cloud-list +9 -14
- data/bin/cloud-osxcopy +6 -5
- data/bin/cloud-provision +17 -22
- data/bin/cloud-setup-dev +11 -11
- data/bin/cloud-show +28 -0
- data/bin/cloud-spec +2 -2
- data/bin/cloud-ssh +10 -3
- data/bin/cloud-start +21 -23
- data/bin/cloud-terminate +15 -7
- data/bin/cloud-verify +32 -0
- data/bin/install-poolparty +216 -0
- data/bin/server-butterfly +25 -0
- data/bin/server-cloud-elections +37 -0
- data/bin/server-ensure-provisioning +33 -0
- data/bin/server-get-load +9 -12
- data/bin/server-list-active +25 -12
- data/bin/server-manage-election +67 -0
- data/bin/server-monitor.ru +42 -0
- data/bin/server-query-agent +15 -0
- data/bin/server-rerun +1 -1
- data/bin/server-write-new-nodes +2 -2
- data/config/jeweler.rb +52 -0
- data/config/requirements.rb +1 -9
- data/examples/basic.rb +10 -10
- data/examples/deploy.rb +5 -0
- data/examples/fairchild.rb +28 -0
- data/examples/fairchild_chef.rb +19 -0
- data/examples/maize.rb +37 -0
- data/examples/paparazzi.conf.erb +21 -0
- data/generators/poolspec/poolspec_generator.rb +1 -9
- data/generators/poolspec/templates/pool_spec_template.erb +0 -1
- data/lib/poolparty/{aska/aska.rb → aska.rb} +19 -28
- data/lib/poolparty/base_packages/haproxy.rb +48 -31
- data/lib/poolparty/base_packages/heartbeat.rb +6 -62
- data/lib/poolparty/base_packages/poolparty.rb +5 -105
- data/lib/poolparty/base_packages/ruby.rb +4 -4
- data/lib/poolparty/base_packages/runit.rb +1 -1
- data/lib/poolparty/core/array.rb +21 -3
- data/lib/poolparty/core/hash.rb +45 -10
- data/lib/poolparty/core/kernel.rb +30 -8
- data/lib/poolparty/core/nil.rb +8 -0
- data/lib/poolparty/core/object.rb +34 -25
- data/lib/poolparty/core/ordered_hash.rb +99 -0
- data/lib/poolparty/core/string.rb +112 -15
- data/lib/poolparty/core/symbol.rb +10 -0
- data/lib/poolparty/dependencies.rb +49 -0
- data/lib/poolparty/dependency_resolver/chef_resolver.rb +237 -0
- data/lib/poolparty/dependency_resolver/dependency_resolver.rb +42 -0
- data/lib/poolparty/dependency_resolver/dependency_resolver_cloud_extensions.rb +29 -0
- data/lib/poolparty/{dependency_resolutions → dependency_resolver}/puppet.rb +34 -29
- data/lib/poolparty/dependency_resolver/puppet_resolver.rb +188 -0
- data/lib/poolparty/exceptions/MasterException.rb +2 -2
- data/lib/poolparty/exceptions/RemoteException.rb +1 -1
- data/lib/poolparty/exceptions/dependency_resolver_exception.rb +5 -0
- data/lib/poolparty/exceptions/package_exception.rb +7 -0
- data/lib/poolparty/extra/deployments.rb +7 -7
- data/lib/poolparty/helpers/binary.rb +26 -32
- data/lib/poolparty/helpers/console.rb +1 -1
- data/lib/poolparty/helpers/display.rb +1 -5
- data/lib/poolparty/helpers/hash_printer.rb +44 -0
- data/lib/poolparty/helpers/loading.rb +4 -0
- data/lib/poolparty/helpers/optioner.rb +39 -25
- data/lib/poolparty/lite.rb +30 -0
- data/lib/poolparty/modules/callbacks.rb +44 -0
- data/lib/poolparty/modules/cloud_dsl.rb +38 -8
- data/lib/poolparty/modules/cloud_resourcer.rb +67 -97
- data/lib/poolparty/modules/daemonizable.rb +141 -0
- data/lib/poolparty/modules/definable_resource.rb +8 -14
- data/lib/poolparty/modules/file_writer.rb +25 -17
- data/lib/poolparty/modules/pinger.rb +28 -0
- data/lib/poolparty/modules/pretty_printer.rb +1 -1
- data/lib/poolparty/modules/resourcing_dsl.rb +55 -40
- data/lib/poolparty/modules/searchable_paths.rb +91 -0
- data/lib/poolparty/modules/thread_pool.rb +107 -106
- data/lib/poolparty/modules/user_helpers.rb +20 -0
- data/lib/poolparty/monitors/base_monitor.rb +18 -75
- data/lib/poolparty/monitors/monitor_rack.rb +123 -0
- data/lib/poolparty/monitors/monitors/favicon_monitor.rb +12 -0
- data/lib/poolparty/monitors/monitors/load_monitor.rb +9 -0
- data/lib/poolparty/monitors/monitors/memory_monitor.rb +9 -9
- data/lib/poolparty/monitors/monitors/neighborhood_monitor.rb +77 -0
- data/lib/poolparty/monitors/monitors/stats_monitor.rb +187 -0
- data/lib/poolparty/monitors/monitors/time_monitor.rb +15 -0
- data/lib/poolparty/net/init.rb +10 -0
- data/lib/poolparty/net/remote_bases.rb +20 -0
- data/lib/poolparty/net/remote_instance.rb +26 -44
- data/lib/poolparty/net/remoter/cloud_control.rb +24 -0
- data/lib/poolparty/net/remoter/connections.rb +172 -0
- data/lib/poolparty/net/remoter/interactive.rb +45 -0
- data/lib/poolparty/net/remoter_base.rb +116 -111
- data/lib/poolparty/net/remoter_bases/ec2/ec2.rb +245 -0
- data/lib/poolparty/net/remoter_bases/ec2/ec2_remote_instance.rb +53 -0
- data/lib/poolparty/net/{remote_bases → remoter_bases}/ec2/ec2_response_object.rb +2 -4
- data/lib/poolparty/net/remoter_bases/vmrun/utilities/vm_disk.rb +12 -0
- data/lib/poolparty/net/remoter_bases/vmrun/utilities/vmx.rb +33 -0
- data/lib/poolparty/net/remoter_bases/vmrun/utilities/vmx_file.rb +117 -0
- data/lib/poolparty/net/remoter_bases/vmrun/vmrun.rb +158 -0
- data/lib/poolparty/net/remoter_bases/vmrun/vmrun_instance.rb +71 -0
- data/lib/poolparty/plugins/apache2/apache.rb +340 -0
- data/lib/poolparty/plugins/bind.rb +11 -0
- data/lib/poolparty/plugins/chef.rb +173 -0
- data/lib/poolparty/plugins/chef_deploy.rb +58 -0
- data/lib/poolparty/plugins/deploy_directory.rb +49 -0
- data/lib/poolparty/plugins/gem_package.rb +61 -0
- data/lib/poolparty/plugins/git.rb +41 -24
- data/lib/poolparty/plugins/line_in_file.rb +30 -0
- data/lib/poolparty/plugins/nanite.rb +41 -0
- data/lib/poolparty/plugins/rails_deploy.rb +76 -0
- data/lib/poolparty/plugins/svn.rb +56 -39
- data/lib/poolparty/poolparty/cloud.rb +137 -167
- data/lib/poolparty/poolparty/{base.rb → default.rb} +62 -25
- data/lib/poolparty/poolparty/key.rb +78 -0
- data/lib/poolparty/poolparty/loggable.rb +28 -27
- data/lib/poolparty/poolparty/neighborhoods.rb +102 -0
- data/lib/poolparty/poolparty/plugin.rb +53 -18
- data/lib/poolparty/poolparty/plugin_model.rb +20 -23
- data/lib/poolparty/poolparty/pool.rb +34 -26
- data/lib/poolparty/poolparty/poolparty_base_class.rb +190 -0
- data/lib/poolparty/poolparty/resource.rb +92 -178
- data/lib/poolparty/poolparty/script.rb +32 -20
- data/lib/poolparty/poolparty/service.rb +44 -0
- data/lib/poolparty/poolparty/template.rb +27 -0
- data/lib/poolparty/provision/boot_strapper.rb +164 -0
- data/lib/poolparty/provision/configurations/chef.rb +26 -0
- data/lib/poolparty/provision/configurations/puppet.rb +28 -0
- data/lib/poolparty/provision/dr_configure.rb +142 -0
- data/lib/poolparty/resources/cron.rb +51 -0
- data/lib/poolparty/resources/directory.rb +36 -0
- data/lib/poolparty/resources/exec.rb +47 -0
- data/lib/poolparty/resources/file.rb +73 -0
- data/lib/poolparty/resources/host.rb +37 -0
- data/lib/poolparty/resources/mount.rb +45 -0
- data/lib/poolparty/resources/package.rb +41 -0
- data/lib/poolparty/resources/remote_file.rb +52 -0
- data/lib/poolparty/resources/service.rb +41 -0
- data/lib/poolparty/resources/sshkey.rb +49 -0
- data/lib/poolparty/resources/symlink.rb +43 -0
- data/lib/poolparty/{poolparty/resources/remote_user.rb → resources/user.rb} +1 -5
- data/lib/poolparty/resources/variable.rb +34 -0
- data/lib/poolparty/resources.rb +42 -0
- data/lib/poolparty/schema.rb +79 -0
- data/lib/poolparty/templates/apache2/apache2.conf +14 -0
- data/lib/poolparty/templates/apache2/base.conf.erb +168 -0
- data/lib/poolparty/templates/apache2/browser_fixes.conf.erb +26 -0
- data/lib/poolparty/templates/apache2/debian.conf.erb +675 -0
- data/lib/poolparty/templates/apache2/default-site.conf.erb +41 -0
- data/lib/poolparty/templates/apache2/directory_indexes.conf.erb +101 -0
- data/lib/poolparty/templates/apache2/logging-syslog.conf.erb +42 -0
- data/lib/poolparty/templates/apache2/mime-extras.conf.erb +211 -0
- data/lib/poolparty/templates/apache2/mime-minimal.conf.erb +15 -0
- data/lib/poolparty/templates/apache2/mpm-worker.conf.erb +20 -0
- data/lib/poolparty/templates/apache2/mpm-worker.erb +20 -0
- data/lib/poolparty/templates/apache2/passenger.conf.erb +20 -0
- data/lib/poolparty/templates/apache2/php.ini.erb +1253 -0
- data/lib/poolparty/templates/apache2/server-status.erb +19 -0
- data/lib/poolparty/templates/erlang_cookie_maker +6 -0
- data/lib/poolparty/templates/gemrc_template +11 -0
- data/lib/poolparty/templates/ha.cf +1 -1
- data/lib/poolparty/templates/haproxy.conf +29 -27
- data/lib/poolparty/templates/haresources +2 -2
- data/lib/poolparty/templates/monitor.ru +16 -0
- data/lib/poolparty/templates/php.ini.erb +1253 -0
- data/lib/poolparty/templates/puppet/add_puppet_to_hosts +6 -0
- data/lib/poolparty/templates/puppet/puppet.conf +2 -0
- data/lib/poolparty/templates/puppet/puppetrunner +14 -0
- data/lib/poolparty/templates/puppet/site.pp +4 -0
- data/lib/poolparty/templates/puppetrunner +11 -5
- data/lib/poolparty/verification/verifier_base.rb +17 -0
- data/lib/poolparty/verification/verifiers/http_match.rb +43 -0
- data/lib/poolparty/verification/verifiers/http_status.rb +59 -0
- data/lib/poolparty/verification/verifiers/ping.rb +34 -0
- data/lib/poolparty/verification/verify.rb +76 -0
- data/lib/poolparty.rb +76 -22
- data/lib/poolpartycl.rb +66 -1
- data/script/destroy +1 -1
- data/script/generate +1 -1
- data/spec/bin/bin_spec_helper.rb +7 -0
- data/spec/bin/fixtures/bin_cloud_for_test.rb +13 -0
- data/spec/bin/server-list-active_spec.rb +24 -0
- data/spec/poolparty/aska/aska_spec.rb +5 -5
- data/spec/poolparty/base_packages/haproxy_spec.rb +2 -8
- data/spec/poolparty/base_packages/heartbeat_spec.rb +3 -26
- data/spec/poolparty/bin/console_spec.rb +11 -29
- data/spec/poolparty/core/array_spec.rb +20 -3
- data/spec/poolparty/core/hash_spec.rb +30 -28
- data/spec/poolparty/core/object_spec.rb +2 -3
- data/spec/poolparty/core/ordered_hash_spec.rb +48 -0
- data/spec/poolparty/core/string_spec.rb +1 -27
- data/spec/poolparty/dependencies_spec.rb +11 -0
- data/spec/poolparty/dependency_resolver/chef_resolver_spec.rb +107 -0
- data/spec/poolparty/dependency_resolver/dependency_resolver_cloud_extensions_spec.rb +122 -0
- data/spec/poolparty/dependency_resolver/dependency_resolver_spec.rb +16 -0
- data/spec/poolparty/dependency_resolver/puppet_resolver_spec.rb +121 -0
- data/spec/poolparty/extra/deployments_spec.rb +9 -5
- data/spec/poolparty/fixtures/clouds.json +128 -0
- data/spec/poolparty/fixtures/test_template.erb +1 -0
- data/spec/poolparty/helpers/binary_spec.rb +1 -1
- data/spec/poolparty/helpers/hash_printer_spec.rb +34 -0
- data/spec/poolparty/helpers/optioner_spec.rb +1 -1
- data/spec/poolparty/id_rsa +27 -0
- data/spec/poolparty/modules/cloud_resourcer_spec.rb +26 -111
- data/spec/poolparty/modules/definable_resource.rb +1 -1
- data/spec/poolparty/modules/file_writer_spec.rb +10 -4
- data/spec/poolparty/modules/searchable_paths_spec.rb +76 -0
- data/spec/poolparty/monitors/base_monitor_spec.rb +112 -111
- data/spec/poolparty/monitors/monitors/cpu_monitor_spec.rb +18 -16
- data/spec/poolparty/monitors/monitors/memory_monitor_spec.rb +48 -47
- data/spec/poolparty/net/remote_instance_spec.rb +9 -73
- data/spec/poolparty/net/remote_spec.rb +287 -310
- data/spec/poolparty/net/remoter_base_spec.rb +3 -56
- data/spec/poolparty/net/remoter_bases/ec2_mocks_and_stubs.rb +24 -0
- data/spec/poolparty/net/remoter_bases/ec2_remote_instance_spec.rb +114 -0
- data/spec/poolparty/net/{remote_bases → remoter_bases}/ec2_spec.rb +51 -53
- data/spec/poolparty/net/remoter_spec.rb +96 -86
- data/spec/poolparty/plugins/chef_spec.rb +7 -0
- data/spec/poolparty/plugins/deploydirectory_spec.rb +51 -52
- data/spec/poolparty/plugins/git_spec.rb +16 -20
- data/spec/poolparty/plugins/line_spec.rb +14 -8
- data/spec/poolparty/poolparty/cloud_spec.rb +85 -183
- data/spec/poolparty/poolparty/configurers/files/ruby_basic.rb +3 -4
- data/spec/poolparty/poolparty/configurers/ruby_spec.rb +7 -23
- data/spec/poolparty/poolparty/{base_spec.rb → default_spec.rb} +44 -41
- data/spec/poolparty/poolparty/example_spec.rb +43 -11
- data/spec/poolparty/poolparty/key_spec.rb +42 -0
- data/spec/poolparty/poolparty/neighborhoods_spec.rb +65 -0
- data/spec/poolparty/poolparty/plugin_model_spec.rb +14 -24
- data/spec/poolparty/poolparty/plugin_spec.rb +25 -96
- data/spec/poolparty/poolparty/pool_spec.rb +3 -1
- data/spec/poolparty/poolparty/resource_spec.rb +70 -270
- data/spec/poolparty/poolparty/script_spec.rb +30 -53
- data/spec/poolparty/poolparty/service_spec.rb +5 -0
- data/spec/poolparty/poolparty/template_spec.rb +26 -0
- data/spec/poolparty/poolparty/test_plugins/webserver.rb +8 -25
- data/spec/poolparty/poolparty_base_class_spec.rb +84 -0
- data/spec/poolparty/poolparty_spec.rb +7 -4
- data/spec/poolparty/resources/cron_spec.rb +44 -0
- data/spec/poolparty/resources/directory_spec.rb +40 -0
- data/spec/poolparty/resources/exec_spec.rb +37 -0
- data/spec/poolparty/resources/file_spec.rb +64 -0
- data/spec/poolparty/resources/gem_spec.rb +7 -0
- data/spec/poolparty/resources/host_spec.rb +35 -0
- data/spec/poolparty/resources/package_spec.rb +26 -0
- data/spec/poolparty/resources/service_spec.rb +29 -0
- data/spec/poolparty/resources/sshkey_spec.rb +40 -0
- data/spec/poolparty/resources/symlink_spec.rb +29 -0
- data/spec/poolparty/resources/user_spec.rb +48 -0
- data/spec/poolparty/resources/variable_spec.rb +26 -0
- data/spec/poolparty/schema_spec.rb +53 -0
- data/spec/poolparty/spec_helper.rb +107 -23
- data/spec/poolparty/test_spec_helper.rb +13 -0
- data/tasks/development.rake +85 -69
- data/tasks/poolparty.rake +54 -0
- data/tasks/server.rake +41 -39
- data/tasks/spec.rake +35 -1
- data/test/fixtures/test_template.erb +1 -0
- data/test/poolparty/core/array_test.rb +21 -0
- data/test/poolparty/core/hash_test.rb +34 -0
- data/test/poolparty/core/string_test.rb +29 -0
- data/test/poolparty/dependency_resolver/puppet_resolver_test.rb +90 -0
- data/test/poolparty/modules/callbacks_test.rb +40 -0
- data/test/poolparty/modules/cloud_dsl_test.rb +60 -0
- data/test/poolparty/net/remoter_bases/vmrun/vmrun_test.rb +54 -0
- data/test/poolparty/net/remoter_test.rb +14 -0
- data/test/poolparty/poolparty/neighborhood_test.rb +23 -0
- data/test/poolparty/poolparty/poolparty_base_class_test.rb +84 -0
- data/test/poolparty/poolparty/template_test.rb +31 -0
- data/test/poolparty/provision/boot_strapper_test.rb +6 -0
- data/test/poolparty/provision/dr_configure_test.rb +6 -0
- data/test/poolparty/verification/verify_test.rb +49 -0
- data/test/test_helper.rb +8 -2
- data/test/test_poolparty.rb +6 -5
- data/vendor/chef/apache2/README.rdoc +59 -0
- data/vendor/chef/apache2/attributes/apache.rb +72 -0
- data/vendor/chef/apache2/definitions/apache_module.rb +36 -0
- data/vendor/chef/apache2/definitions/apache_site.rb +36 -0
- data/vendor/chef/apache2/definitions/web_app.rb +45 -0
- data/vendor/chef/apache2/files/default/apache2_module_conf_generate.pl +41 -0
- data/vendor/chef/apache2/recipes/default.rb +132 -0
- data/vendor/chef/apache2/recipes/mod_alias.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_auth_basic.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_auth_digest.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_authn_file.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_authnz_ldap.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_authz_default.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_authz_groupfile.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_authz_host.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_authz_user.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_autoindex.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_cgi.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_dav.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_dav_svn.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_deflate.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_dir.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_env.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_expires.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_fcgid.rb +35 -0
- data/vendor/chef/apache2/recipes/mod_headers.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_ldap.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_log_config.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_mime.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_negotiation.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_php5.rb +27 -0
- data/vendor/chef/apache2/recipes/mod_proxy.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_proxy_http.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_python.rb +22 -0
- data/vendor/chef/apache2/recipes/mod_rewrite.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_setenvif.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_ssl.rb +20 -0
- data/vendor/chef/apache2/recipes/mod_status.rb +20 -0
- data/vendor/chef/apache2/templates/default/a2dismod.erb +22 -0
- data/vendor/chef/apache2/templates/default/a2dissite.erb +29 -0
- data/vendor/chef/apache2/templates/default/a2enmod.erb +37 -0
- data/vendor/chef/apache2/templates/default/a2ensite.erb +38 -0
- data/vendor/chef/apache2/templates/default/apache2.conf.erb +630 -0
- data/vendor/chef/apache2/templates/default/default-site.erb +45 -0
- data/vendor/chef/apache2/templates/default/port_apache.erb +2 -0
- data/vendor/chef/apache2/templates/default/ports.conf.erb +6 -0
- data/vendor/chef/apache2/templates/default/web_app.conf.erb +43 -0
- data/vendor/chef/chef-deploy/LICENSE +201 -0
- data/vendor/chef/chef-deploy/README.rdoc +24 -0
- data/vendor/chef/chef-deploy/Rakefile +57 -0
- data/vendor/chef/chef-deploy/TODO +4 -0
- data/vendor/chef/chef-deploy/lib/chef-deploy/cached_deploy.rb +230 -0
- data/vendor/chef/chef-deploy/lib/chef-deploy/git.rb +132 -0
- data/vendor/chef/chef-deploy/lib/chef-deploy/subversion.rb +98 -0
- data/vendor/chef/chef-deploy/lib/chef-deploy.rb +183 -0
- data/vendor/gems/butterfly/History.txt +4 -0
- data/vendor/gems/butterfly/PostInstall.txt +2 -0
- data/vendor/gems/butterfly/README.rdoc +48 -0
- data/vendor/gems/butterfly/Rakefile +62 -0
- data/vendor/gems/butterfly/VERSION.yml +4 -0
- data/vendor/gems/butterfly/bin/flutter +4 -0
- data/vendor/gems/butterfly/butterfly.gemspec +37 -0
- data/vendor/gems/butterfly/examples/config.ru +15 -0
- data/vendor/gems/butterfly/examples/my_app.rb +12 -0
- data/vendor/gems/butterfly/lib/butterfly.rb +14 -0
- data/vendor/gems/butterfly/lib/handler.rb +48 -0
- data/vendor/gems/butterfly/lib/request.rb +29 -0
- data/vendor/gems/butterfly/lib/response.rb +49 -0
- data/vendor/gems/butterfly/script/console +10 -0
- data/vendor/gems/butterfly/script/destroy +14 -0
- data/vendor/gems/butterfly/script/generate +14 -0
- data/vendor/gems/butterfly/test/test_adapter_base.rb +23 -0
- data/vendor/gems/butterfly/test/test_butterfly_request.rb +46 -0
- data/vendor/gems/butterfly/test/test_butterfly_response.rb +43 -0
- data/vendor/gems/butterfly/test/test_butterfly_server.rb +16 -0
- data/vendor/gems/butterfly/test/test_default.rb +12 -0
- data/vendor/gems/butterfly/test/test_helper.rb +6 -0
- data/vendor/gems/dslify/History.txt +4 -0
- data/vendor/gems/dslify/Manifest.txt +25 -0
- data/vendor/gems/dslify/PostInstall.txt +5 -0
- data/vendor/gems/dslify/README.txt +60 -0
- data/vendor/gems/dslify/Rakefile +56 -0
- data/{config → vendor/gems/dslify/config}/hoe.rb +12 -55
- data/vendor/gems/dslify/config/requirements.rb +15 -0
- data/vendor/gems/dslify/dslify.gemspec +40 -0
- data/vendor/gems/dslify/lib/dslify/dslify.rb +76 -0
- data/vendor/gems/dslify/lib/dslify/version.rb +10 -0
- data/vendor/gems/dslify/lib/dslify.rb +7 -0
- data/vendor/gems/dslify/script/console +10 -0
- data/vendor/gems/dslify/script/destroy +14 -0
- data/vendor/gems/dslify/script/generate +14 -0
- data/{script → vendor/gems/dslify/script}/txt2html +4 -4
- data/{setup.rb → vendor/gems/dslify/setup.rb} +3 -3
- data/{tasks → vendor/gems/dslify/tasks}/deployment.rake +4 -18
- data/vendor/gems/dslify/tasks/environment.rake +7 -0
- data/{tasks → vendor/gems/dslify/tasks}/website.rake +0 -0
- data/vendor/gems/dslify/test/test_dslify.rb +138 -0
- data/vendor/gems/dslify/website/index.html +86 -0
- data/vendor/gems/dslify/website/index.txt +83 -0
- data/{website → vendor/gems/dslify/website}/javascripts/rounded_corners_lite.inc.js +0 -0
- data/{website → vendor/gems/dslify/website}/stylesheets/screen.css +18 -27
- data/{website → vendor/gems/dslify/website}/template.html.erb +1 -2
- data/vendor/gems/parenting/History.txt +4 -0
- data/vendor/gems/parenting/Manifest.txt +14 -0
- data/vendor/gems/parenting/PostInstall.txt +2 -0
- data/vendor/gems/parenting/README.rdoc +47 -0
- data/vendor/gems/parenting/Rakefile +28 -0
- data/vendor/gems/parenting/lib/parenting/parenting.rb +61 -0
- data/vendor/gems/parenting/lib/parenting.rb +10 -0
- data/vendor/gems/parenting/parenting.gemspec +39 -0
- data/vendor/gems/parenting/script/console +10 -0
- data/vendor/gems/parenting/script/destroy +14 -0
- data/vendor/gems/parenting/script/generate +14 -0
- data/vendor/gems/parenting/test/file_to_eval.rb +9 -0
- data/vendor/gems/parenting/test/test_helper.rb +5 -0
- data/vendor/gems/parenting/test/test_parenting.rb +117 -0
- data/vendor/gems/suitcase/LICENSE +20 -0
- data/vendor/gems/suitcase/README.rdoc +31 -0
- data/vendor/gems/suitcase/Rakefile +57 -0
- data/vendor/gems/suitcase/VERSION.yml +4 -0
- data/vendor/gems/suitcase/lib/suitcase/unzipper.rb +15 -0
- data/vendor/gems/suitcase/lib/suitcase/zipper.rb +119 -0
- data/vendor/gems/suitcase/lib/suitcase.rb +5 -0
- data/vendor/gems/suitcase/suitcase.gemspec +32 -0
- data/vendor/gems/suitcase/test/suitcase_test.rb +102 -0
- data/vendor/gems/suitcase/test/test_dir/box.rb +1 -0
- data/vendor/gems/suitcase/test/test_dir/test.txt +1 -0
- data/vendor/gems/suitcase/test/test_helper.rb +12 -0
- metadata +370 -343
- data/Capfile +0 -1
- data/Manifest.txt +0 -414
- data/bin/cloud-add-keypair +0 -28
- data/bin/cloud-ensure-provisioning +0 -39
- data/bin/cloud-maintain +0 -30
- data/bin/cloud-refresh +0 -17
- data/bin/cloud-run +0 -18
- data/bin/cloud-stats +0 -17
- data/bin/messenger-get-current-nodes +0 -14
- data/bin/pool +0 -31
- data/bin/pool-describe +0 -8
- data/bin/pool-generate +0 -18
- data/bin/pool-init +0 -28
- data/bin/pool-list +0 -30
- data/bin/pool-start +0 -26
- data/bin/server-build-messenger +0 -27
- data/bin/server-clean-cert-for +0 -15
- data/bin/server-list-responding +0 -24
- data/bin/server-start-client +0 -29
- data/bin/server-start-master +0 -26
- data/bin/server-start-node +0 -32
- data/bin/server-stop-client +0 -3
- data/bin/server-stop-master +0 -3
- data/bin/server-stop-node +0 -3
- data/bin/server-update-hosts +0 -49
- data/lib/erlang/messenger/Emakefile +0 -1
- data/lib/erlang/messenger/Makefile +0 -15
- data/lib/erlang/messenger/README +0 -5
- data/lib/erlang/messenger/Rakefile +0 -72
- data/lib/erlang/messenger/control +0 -11
- data/lib/erlang/messenger/ebin/client.app +0 -19
- data/lib/erlang/messenger/ebin/client_app.beam +0 -0
- data/lib/erlang/messenger/ebin/client_server.beam +0 -0
- data/lib/erlang/messenger/ebin/erl_crash.dump +0 -10326
- data/lib/erlang/messenger/ebin/master.app +0 -19
- data/lib/erlang/messenger/ebin/master_app.beam +0 -0
- data/lib/erlang/messenger/ebin/node.app +0 -19
- data/lib/erlang/messenger/ebin/node_app.beam +0 -0
- data/lib/erlang/messenger/ebin/packager.app +0 -19
- data/lib/erlang/messenger/ebin/pm_client.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_client_old.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_client_rel-0.1.rel +0 -1
- data/lib/erlang/messenger/ebin/pm_client_supervisor.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_cluster.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_event_manager.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_master.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_master_event_handler.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_master_rel-0.1.rel +0 -1
- data/lib/erlang/messenger/ebin/pm_master_supervisor.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_node.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_node_rel-0.1.rel +0 -1
- data/lib/erlang/messenger/ebin/pm_node_supervisor.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_packager.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_spawner.beam +0 -0
- data/lib/erlang/messenger/ebin/pm_strings.beam +0 -0
- data/lib/erlang/messenger/ebin/utils.beam +0 -0
- data/lib/erlang/messenger/include/defines.hrl +0 -27
- data/lib/erlang/messenger/lib/eunit/AUTHORS +0 -2
- data/lib/erlang/messenger/lib/eunit/CHANGELOG +0 -14
- data/lib/erlang/messenger/lib/eunit/COPYING +0 -504
- data/lib/erlang/messenger/lib/eunit/Makefile +0 -28
- data/lib/erlang/messenger/lib/eunit/NOTES +0 -276
- data/lib/erlang/messenger/lib/eunit/README +0 -3
- data/lib/erlang/messenger/lib/eunit/doc/edoc-info +0 -3
- data/lib/erlang/messenger/lib/eunit/doc/erlang.png +0 -0
- data/lib/erlang/messenger/lib/eunit/doc/eunit.html +0 -172
- data/lib/erlang/messenger/lib/eunit/doc/index.html +0 -17
- data/lib/erlang/messenger/lib/eunit/doc/modules-frame.html +0 -12
- data/lib/erlang/messenger/lib/eunit/doc/overview-summary.html +0 -984
- data/lib/erlang/messenger/lib/eunit/doc/overview.edoc +0 -980
- data/lib/erlang/messenger/lib/eunit/doc/packages-frame.html +0 -11
- data/lib/erlang/messenger/lib/eunit/doc/stylesheet.css +0 -55
- data/lib/erlang/messenger/lib/eunit/ebin/autoload.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/code_monitor.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit.app +0 -21
- data/lib/erlang/messenger/lib/eunit/ebin/eunit.appup +0 -1
- data/lib/erlang/messenger/lib/eunit/ebin/eunit.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_autoexport.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_data.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_lib.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_proc.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_serial.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_server.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_striptests.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_test.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_tests.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/eunit_tty.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/ebin/file_monitor.beam +0 -0
- data/lib/erlang/messenger/lib/eunit/examples/eunit_examples.erl +0 -339
- data/lib/erlang/messenger/lib/eunit/examples/fib.erl +0 -19
- data/lib/erlang/messenger/lib/eunit/examples/tests.txt +0 -1
- data/lib/erlang/messenger/lib/eunit/include/eunit.hrl +0 -313
- data/lib/erlang/messenger/lib/eunit/src/Makefile +0 -46
- data/lib/erlang/messenger/lib/eunit/src/autoload.erl +0 -388
- data/lib/erlang/messenger/lib/eunit/src/code_monitor.erl +0 -243
- data/lib/erlang/messenger/lib/eunit/src/eunit.app.src +0 -21
- data/lib/erlang/messenger/lib/eunit/src/eunit.appup.src +0 -1
- data/lib/erlang/messenger/lib/eunit/src/eunit.erl +0 -196
- data/lib/erlang/messenger/lib/eunit/src/eunit_autoexport.erl +0 -102
- data/lib/erlang/messenger/lib/eunit/src/eunit_data.erl +0 -798
- data/lib/erlang/messenger/lib/eunit/src/eunit_internal.hrl +0 -48
- data/lib/erlang/messenger/lib/eunit/src/eunit_lib.erl +0 -682
- data/lib/erlang/messenger/lib/eunit/src/eunit_proc.erl +0 -552
- data/lib/erlang/messenger/lib/eunit/src/eunit_serial.erl +0 -157
- data/lib/erlang/messenger/lib/eunit/src/eunit_server.erl +0 -340
- data/lib/erlang/messenger/lib/eunit/src/eunit_striptests.erl +0 -64
- data/lib/erlang/messenger/lib/eunit/src/eunit_test.erl +0 -334
- data/lib/erlang/messenger/lib/eunit/src/eunit_tests.erl +0 -45
- data/lib/erlang/messenger/lib/eunit/src/eunit_tty.erl +0 -272
- data/lib/erlang/messenger/lib/eunit/src/file_monitor.erl +0 -409
- data/lib/erlang/messenger/lib/eunit/sys.config +0 -9
- data/lib/erlang/messenger/lib/eunit/vsn.mk +0 -1
- data/lib/erlang/messenger/pm_client_rel-0.1.boot +0 -0
- data/lib/erlang/messenger/pm_client_rel-0.1.script +0 -238
- data/lib/erlang/messenger/pm_master_rel-0.1.boot +0 -0
- data/lib/erlang/messenger/pm_master_rel-0.1.script +0 -239
- data/lib/erlang/messenger/pm_node_rel-0.1.boot +0 -0
- data/lib/erlang/messenger/pm_node_rel-0.1.script +0 -237
- data/lib/erlang/messenger/src/client_app.erl +0 -39
- data/lib/erlang/messenger/src/client_server.erl +0 -60
- data/lib/erlang/messenger/src/master_app.erl +0 -39
- data/lib/erlang/messenger/src/node_app.erl +0 -39
- data/lib/erlang/messenger/src/pm_client.erl +0 -49
- data/lib/erlang/messenger/src/pm_client_supervisor.erl +0 -38
- data/lib/erlang/messenger/src/pm_cluster.erl +0 -61
- data/lib/erlang/messenger/src/pm_event_manager.erl +0 -27
- data/lib/erlang/messenger/src/pm_master.erl +0 -215
- data/lib/erlang/messenger/src/pm_master_event_handler.erl +0 -72
- data/lib/erlang/messenger/src/pm_master_supervisor.erl +0 -39
- data/lib/erlang/messenger/src/pm_node.erl +0 -200
- data/lib/erlang/messenger/src/pm_node_supervisor.erl +0 -38
- data/lib/erlang/messenger/src/pm_packager.erl +0 -76
- data/lib/erlang/messenger/src/pm_spawner.erl +0 -213
- data/lib/erlang/messenger/src/pm_strings.erl +0 -11
- data/lib/erlang/messenger/src/utils.erl +0 -73
- data/lib/erlang/messenger/useful_snippets +0 -17
- data/lib/poolparty/capistrano.rb +0 -18
- data/lib/poolparty/config/postlaunchmessage.txt +0 -5
- data/lib/poolparty/dependency_resolutions/base.rb +0 -12
- data/lib/poolparty/modules/configurable.rb +0 -36
- data/lib/poolparty/modules/method_missing_sugar.rb +0 -58
- data/lib/poolparty/monitors/monitors/cpu_monitor.rb +0 -15
- data/lib/poolparty/monitors/monitors/web_monitor.rb +0 -18
- data/lib/poolparty/net/messenger.rb +0 -72
- data/lib/poolparty/net/remote.rb +0 -38
- data/lib/poolparty/net/remote_bases/ec2.rb +0 -190
- data/lib/poolparty/net/remoter.rb +0 -343
- data/lib/poolparty/plugins/deploydirectory.rb +0 -71
- data/lib/poolparty/plugins/line.rb +0 -77
- data/lib/poolparty/plugins/rsyncmirror.rb +0 -26
- data/lib/poolparty/poolparty/custom_resource.rb +0 -45
- data/lib/poolparty/poolparty/resources/class_package.rb +0 -105
- data/lib/poolparty/poolparty/resources/conditional.rb +0 -67
- data/lib/poolparty/poolparty/resources/cron.rb +0 -14
- data/lib/poolparty/poolparty/resources/custom_service.rb +0 -30
- data/lib/poolparty/poolparty/resources/directory.rb +0 -26
- data/lib/poolparty/poolparty/resources/exec.rb +0 -28
- data/lib/poolparty/poolparty/resources/file.rb +0 -23
- data/lib/poolparty/poolparty/resources/gem_package.rb +0 -52
- data/lib/poolparty/poolparty/resources/host.rb +0 -14
- data/lib/poolparty/poolparty/resources/mount.rb +0 -22
- data/lib/poolparty/poolparty/resources/package.rb +0 -24
- data/lib/poolparty/poolparty/resources/remote_file.rb +0 -26
- data/lib/poolparty/poolparty/resources/service.rb +0 -21
- data/lib/poolparty/poolparty/resources/sshkey.rb +0 -23
- data/lib/poolparty/poolparty/resources/symlink.rb +0 -25
- data/lib/poolparty/poolparty/resources/variable.rb +0 -32
- data/lib/poolparty/provisioners/capistrano/capistrano.rb +0 -127
- data/lib/poolparty/provisioners/capistrano/capistrano_configurer.rb +0 -58
- data/lib/poolparty/provisioners/capistrano/recipies/base.rb +0 -104
- data/lib/poolparty/provisioners/capistrano/recipies/master.rb +0 -121
- data/lib/poolparty/provisioners/capistrano/recipies/slave.rb +0 -12
- data/lib/poolparty/provisioners/provisioner_base.rb +0 -204
- data/lib/poolparty/spec/core/string.rb +0 -16
- data/lib/poolparty/spec/matchers/a_spec_extensions_base.rb +0 -26
- data/lib/poolparty/spec/matchers/have_cron.rb +0 -28
- data/lib/poolparty/spec/matchers/have_deploydirectory.rb +0 -15
- data/lib/poolparty/spec/matchers/have_directory.rb +0 -31
- data/lib/poolparty/spec/matchers/have_exec.rb +0 -28
- data/lib/poolparty/spec/matchers/have_file.rb +0 -28
- data/lib/poolparty/spec/matchers/have_gempackage.rb +0 -28
- data/lib/poolparty/spec/matchers/have_git.rb +0 -28
- data/lib/poolparty/spec/matchers/have_host.rb +0 -28
- data/lib/poolparty/spec/matchers/have_mount.rb +0 -28
- data/lib/poolparty/spec/matchers/have_package.rb +0 -28
- data/lib/poolparty/spec/matchers/have_remotefile.rb +0 -28
- data/lib/poolparty/spec/matchers/have_rsyncmirror.rb +0 -28
- data/lib/poolparty/spec/matchers/have_service.rb +0 -28
- data/lib/poolparty/spec/matchers/have_sshkey.rb +0 -28
- data/lib/poolparty/spec/matchers/have_symlink.rb +0 -28
- data/lib/poolparty/spec/matchers/have_variable.rb +0 -32
- data/lib/poolparty/spec/spec/dynamic_matchers.rb +0 -63
- data/lib/poolparty/spec/spec/ensure_matchers_exist.rb +0 -7
- data/lib/poolparty/spec/templates/have_base.rb +0 -28
- data/lib/poolparty/templates/puppet.conf +0 -26
- data/lib/poolparty/templates/puppetcleaner +0 -12
- data/lib/poolparty/templates/puppetrerun +0 -22
- data/lib/poolparty/version.rb +0 -9
- data/lib/poolpartyspec.rb +0 -34
- data/log/pool.log +0 -0
- data/poolparty.gemspec +0 -580
- data/spec/poolparty/dependency_resolutions/base_spec.rb +0 -11
- data/spec/poolparty/modules/configurable_spec.rb +0 -29
- data/spec/poolparty/net/log/pool.log +0 -0
- data/spec/poolparty/net/messenger_spec.rb +0 -16
- data/spec/poolparty/plugins/svn_spec.rb +0 -16
- data/spec/poolparty/poolparty/custom_resource_spec.rb +0 -120
- data/spec/poolparty/poolparty/resources/class_package_spec.rb +0 -120
- data/spec/poolparty/poolparty/resources/conditional_spec.rb +0 -77
- data/spec/poolparty/poolparty/resources/cron_spec.rb +0 -50
- data/spec/poolparty/poolparty/resources/directory_spec.rb +0 -40
- data/spec/poolparty/poolparty/resources/exec_spec.rb +0 -37
- data/spec/poolparty/poolparty/resources/file_spec.rb +0 -40
- data/spec/poolparty/poolparty/resources/gem_spec.rb +0 -46
- data/spec/poolparty/poolparty/resources/host_spec.rb +0 -28
- data/spec/poolparty/poolparty/resources/package_spec.rb +0 -44
- data/spec/poolparty/poolparty/resources/remote_file_spec.rb +0 -40
- data/spec/poolparty/poolparty/resources/service_spec.rb +0 -45
- data/spec/poolparty/poolparty/resources/sshkey_spec.rb +0 -48
- data/spec/poolparty/poolparty/resources/symlink_spec.rb +0 -22
- data/spec/poolparty/poolparty/resources/user_spec.rb +0 -38
- data/spec/poolparty/poolparty/resources/variable_spec.rb +0 -24
- data/spec/poolparty/provisioners/capistrano/capistrano_spec.rb +0 -27
- data/spec/poolparty/provisioners/provisioner_base_spec.rb +0 -120
- data/spec/poolparty/spec/core/string_spec.rb +0 -57
- data/website/index.html +0 -107
- data/website/index.txt +0 -95
- data/website/stylesheets/code.css +0 -29
@@ -1,552 +0,0 @@
|
|
1
|
-
%% This library is free software; you can redistribute it and/or modify
|
2
|
-
%% it under the terms of the GNU Lesser General Public License as
|
3
|
-
%% published by the Free Software Foundation; either version 2 of the
|
4
|
-
%% License, or (at your option) any later version.
|
5
|
-
%%
|
6
|
-
%% This library is distributed in the hope that it will be useful, but
|
7
|
-
%% WITHOUT ANY WARRANTY; without even the implied warranty of
|
8
|
-
%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
9
|
-
%% Lesser General Public License for more details.
|
10
|
-
%%
|
11
|
-
%% You should have received a copy of the GNU Lesser General Public
|
12
|
-
%% License along with this library; if not, write to the Free Software
|
13
|
-
%% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
14
|
-
%% USA
|
15
|
-
%%
|
16
|
-
%% $Id: eunit_proc.erl 256 2008-09-29 17:42:21Z rcarlsson $
|
17
|
-
%%
|
18
|
-
%% @author Richard Carlsson <richardc@it.uu.se>
|
19
|
-
%% @copyright 2006 Richard Carlsson
|
20
|
-
%% @private
|
21
|
-
%% @see eunit
|
22
|
-
%% @doc Test runner process tree functions
|
23
|
-
|
24
|
-
-module(eunit_proc).
|
25
|
-
|
26
|
-
-include("eunit.hrl").
|
27
|
-
-include("eunit_internal.hrl").
|
28
|
-
|
29
|
-
-export([start/4]).
|
30
|
-
|
31
|
-
|
32
|
-
-record(procstate, {ref, id, super, insulator, parent, order}).
|
33
|
-
|
34
|
-
|
35
|
-
%% Spawns test process and returns the process Pid; sends {done,
|
36
|
-
%% Reference, Pid} to caller when finished. See the function
|
37
|
-
%% wait_for_task/2 for details about the need for the reference.
|
38
|
-
%%
|
39
|
-
%% The `Super' process receives a stream of status messages; see
|
40
|
-
%% status_message/3 for details.
|
41
|
-
|
42
|
-
start(Tests, Order, Super, Reference)
|
43
|
-
when is_pid(Super), is_reference(Reference) ->
|
44
|
-
St = #procstate{ref = Reference,
|
45
|
-
id = [],
|
46
|
-
super = Super,
|
47
|
-
order = Order},
|
48
|
-
spawn_group(local, #group{tests = Tests}, St).
|
49
|
-
|
50
|
-
|
51
|
-
%% Status messages sent to the supervisor process. (A supervisor does
|
52
|
-
%% not have to act on these messages - it can e.g. just log them, or
|
53
|
-
%% even discard them.) Each status message has the following form:
|
54
|
-
%%
|
55
|
-
%% {status, Id, Info}
|
56
|
-
%%
|
57
|
-
%% where Id identifies the item that the message pertains to, and the
|
58
|
-
%% Info part can be one of:
|
59
|
-
%%
|
60
|
-
%% {progress, 'begin', test | group}
|
61
|
-
%% indicates that the item has been entered, and what type it is
|
62
|
-
%%
|
63
|
-
%% {progress, 'end', {Status, Time::integer(), Output::io_list()}}
|
64
|
-
%% Status = 'ok' | {error, Exception} | {skipped, Cause}
|
65
|
-
%%
|
66
|
-
%% where Time is measured in milliseconds and Output is the data
|
67
|
-
%% written to the standard output stream during the test; if
|
68
|
-
%% Status is {skipped, Cause}, then Cause is a term thrown from
|
69
|
-
%% eunit_test:run_testfun/1
|
70
|
-
%%
|
71
|
-
%% {cancel, Descriptor}
|
72
|
-
%% where Descriptor can be:
|
73
|
-
%% timeout a timeout occurred
|
74
|
-
%% {blame, Id} forced to terminate because of item `Id'
|
75
|
-
%% {abort, Cause} the test failed to execute
|
76
|
-
%% {exit, Reason} the test process terminated unexpectedly
|
77
|
-
%% {startup, Reason} failed to start a remote test process
|
78
|
-
%%
|
79
|
-
%% where Cause is a term thrown from eunit_data:enter_context/4 or
|
80
|
-
%% from eunit_data:iter_next/2, and Reason is an exit term from a
|
81
|
-
%% crashed process
|
82
|
-
%%
|
83
|
-
%% Note that due to concurrent (and possibly distributed) execution,
|
84
|
-
%% there are *no* strict ordering guarantees on the status messages,
|
85
|
-
%% with one exception: a 'begin' message will always arrive before its
|
86
|
-
%% corresponding 'end' message.
|
87
|
-
|
88
|
-
status_message(Id, Info, St) ->
|
89
|
-
St#procstate.super ! {status, Id, Info}.
|
90
|
-
|
91
|
-
|
92
|
-
%% @TODO implement synchronized mode for insulator/child execution
|
93
|
-
|
94
|
-
%% Ideas for synchronized mode:
|
95
|
-
%%
|
96
|
-
%% * At each "program point", i.e., before entering a test, entering a
|
97
|
-
%% group, or leaving a group, the child will synchronize with the
|
98
|
-
%% insulator to make sure it is ok to proceed.
|
99
|
-
%%
|
100
|
-
%% * The insulator can receive controlling messages from higher up in
|
101
|
-
%% the hierarchy, telling it to pause, resume, single-step, repeat, etc.
|
102
|
-
%%
|
103
|
-
%% * Synchronization on entering/leaving groups is necessary in order to
|
104
|
-
%% get control over things such as subprocess creation/termination and
|
105
|
-
%% setup/cleanup, making it possible to, e.g., repeat all the tests
|
106
|
-
%% within a particular subprocess without terminating and restarting it,
|
107
|
-
%% or repeating tests without repeating the setup/cleanup.
|
108
|
-
%%
|
109
|
-
%% * Some tests that depend on state will not be possible to repeat, but
|
110
|
-
%% require a fresh context setup. There is nothing that can be done
|
111
|
-
%% about this, and the many tests that are repeatable should not be
|
112
|
-
%% punished because of it. The user must decide which level to restart.
|
113
|
-
%%
|
114
|
-
%% * Question: How propagate control messages down the hierarchy
|
115
|
-
%% (preferably only to the correct insulator process)? An insulator does
|
116
|
-
%% not currenctly know whether its child process has spawned subtasks.
|
117
|
-
%% (The "supervisor" process does not know the Pids of the controlling
|
118
|
-
%% insulator processes in the tree, and it probably should not be
|
119
|
-
%% responsible for this anyway.)
|
120
|
-
|
121
|
-
|
122
|
-
%% ---------------------------------------------------------------------
|
123
|
-
%% Process tree primitives
|
124
|
-
|
125
|
-
%% A "task" consists of an insulator process and a child process which
|
126
|
-
%% handles the actual work. When the child terminates, the insulator
|
127
|
-
%% process sends {done, Reference, self()} to the process which started
|
128
|
-
%% the task (the "parent"). The child process is given a State record
|
129
|
-
%% which contains the process id:s of the parent, the insulator, and the
|
130
|
-
%% supervisor.
|
131
|
-
|
132
|
-
%% @spec (Type, (#procstate{}) -> () -> term(), #procstate{}) -> pid()
|
133
|
-
%% Type = local | {remote, Node::atom()}
|
134
|
-
|
135
|
-
start_task(Type, Fun, St0) ->
|
136
|
-
St = St0#procstate{parent = self()},
|
137
|
-
%% (note: the link here is mainly to propagate signals *downwards*,
|
138
|
-
%% so that the insulator can detect if the process that started the
|
139
|
-
%% task dies before the task is done)
|
140
|
-
F = fun () -> insulator_process(Type, Fun, St) end,
|
141
|
-
case Type of
|
142
|
-
local ->
|
143
|
-
%% we assume (at least for now) that local spawns can never
|
144
|
-
%% fail in such a way that the process does not start, so a
|
145
|
-
%% new local insulator does not need to synchronize here
|
146
|
-
spawn_link(F);
|
147
|
-
{remote, Node} ->
|
148
|
-
Pid = spawn_link(Node, F),
|
149
|
-
%% See below for the need for the {ok, Reference, Pid}
|
150
|
-
%% message.
|
151
|
-
Reference = St#procstate.ref,
|
152
|
-
Monitor = erlang:monitor(process, Pid),
|
153
|
-
%% (the DOWN message is guaranteed to arrive after any
|
154
|
-
%% messages sent by the process itself)
|
155
|
-
receive
|
156
|
-
{ok, Reference, Pid} ->
|
157
|
-
Pid;
|
158
|
-
{'DOWN', Monitor, process, Pid, Reason} ->
|
159
|
-
%% send messages as if the insulator process was
|
160
|
-
%% started, but terminated on its own accord
|
161
|
-
Msg = {startup, Reason},
|
162
|
-
status_message(St#procstate.id, {cancel, Msg}, St),
|
163
|
-
self() ! {done, Reference, Pid}
|
164
|
-
end,
|
165
|
-
erlang:demonitor(Monitor, [flush]),
|
166
|
-
Pid
|
167
|
-
end.
|
168
|
-
|
169
|
-
%% Relatively simple, and hopefully failure-proof insulator process
|
170
|
-
%% (This is cleaner than temporarily setting up the caller to trap
|
171
|
-
%% signals, and does not affect the caller's mailbox or other state.)
|
172
|
-
%%
|
173
|
-
%% We assume that nobody does a 'kill' on an insulator process - if that
|
174
|
-
%% should happen, the test framework will hang since the insulator will
|
175
|
-
%% never send a reply; see below for more.
|
176
|
-
%%
|
177
|
-
%% Note that even if the insulator process itself never fails, it is
|
178
|
-
%% still possible that it does not start properly, if it is spawned
|
179
|
-
%% remotely (e.g., if the remote node is down). Therefore, remote
|
180
|
-
%% insulators must always immediately send an {ok, Reference, self()}
|
181
|
-
%% message to the parent as soon as it is spawned.
|
182
|
-
|
183
|
-
%% @spec (Type, Fun::() -> term(), St::#procstate{}) -> ok
|
184
|
-
%% Type = local | {remote, Node::atom()}
|
185
|
-
|
186
|
-
insulator_process(Type, Fun, St0) ->
|
187
|
-
process_flag(trap_exit, true),
|
188
|
-
Parent = St0#procstate.parent,
|
189
|
-
if Type == local -> ok;
|
190
|
-
true -> Parent ! {ok, St0#procstate.ref, self()}
|
191
|
-
end,
|
192
|
-
St = St0#procstate{insulator = self()},
|
193
|
-
Child = spawn_link(fun () -> child_process(Fun(St), St) end),
|
194
|
-
insulator_wait(Child, Parent, [], St).
|
195
|
-
|
196
|
-
%% Normally, child processes exit with the reason 'normal' even if the
|
197
|
-
%% executed tests failed (by throwing exceptions), since the tests are
|
198
|
-
%% executed within a try-block. Child processes can terminate abnormally
|
199
|
-
%% by the following reasons:
|
200
|
-
%% 1) an error in the processing of the test descriptors (a malformed
|
201
|
-
%% descriptor, failure in a setup, cleanup or initialization, a
|
202
|
-
%% missing module or function, or a failing generator function);
|
203
|
-
%% 2) an internal error in the test running framework itself;
|
204
|
-
%% 3) receiving a non-trapped error signal as a consequence of running
|
205
|
-
%% test code.
|
206
|
-
%% Those under point 1 are "expected errors", handled specially in the
|
207
|
-
%% protocol, while the other two are unexpected errors. (Since alt. 3
|
208
|
-
%% implies that the test neither reported success nor failure, it can
|
209
|
-
%% never be considered "proper" behaviour of a test.) Abnormal
|
210
|
-
%% termination is reported to the supervisor process but otherwise does
|
211
|
-
%% not affect the insulator compared to normal termination. Child
|
212
|
-
%% processes can also be killed abruptly by their insulators, in case of
|
213
|
-
%% a timeout or if a parent process dies.
|
214
|
-
%%
|
215
|
-
%% The insulator is the group leader for the child process, and gets all
|
216
|
-
%% of its standard I/O. The output is buffered and associated with the
|
217
|
-
%% currently active test or group, and is sent along with the 'end'
|
218
|
-
%% progress message when the test or group has finished.
|
219
|
-
|
220
|
-
insulator_wait(Child, Parent, Buf, St) ->
|
221
|
-
receive
|
222
|
-
{io_request, From, ReplyAs, Req} when is_pid(From) ->
|
223
|
-
Buf1 = io_request(From, ReplyAs, Req, hd(Buf)),
|
224
|
-
insulator_wait(Child, Parent, [Buf1 | tl(Buf)], St);
|
225
|
-
{progress, Child, Id, 'begin', Class} ->
|
226
|
-
status_message(Id, {progress, 'begin', Class}, St),
|
227
|
-
insulator_wait(Child, Parent, [[] | Buf], St);
|
228
|
-
{progress, Child, Id, 'end', {Status, Time}} ->
|
229
|
-
Msg = {Status, Time, lists:reverse(hd(Buf))},
|
230
|
-
status_message(Id, {progress, 'end', Msg}, St),
|
231
|
-
insulator_wait(Child, Parent, tl(Buf), St);
|
232
|
-
{cancel, Child, Id, Reason} ->
|
233
|
-
status_message(Id, {cancel, Reason}, St),
|
234
|
-
insulator_wait(Child, Parent, Buf, St);
|
235
|
-
{abort, Child, Id, Cause} ->
|
236
|
-
exit_messages(Id, {abort, Cause}, St),
|
237
|
-
%% no need to wait for the {'EXIT',Child,_} message
|
238
|
-
terminate_insulator(St);
|
239
|
-
{timeout, Child, Id} ->
|
240
|
-
exit_messages(Id, timeout, St),
|
241
|
-
kill_task(Child, St);
|
242
|
-
{'EXIT', Child, normal} ->
|
243
|
-
terminate_insulator(St);
|
244
|
-
{'EXIT', Child, Reason} ->
|
245
|
-
exit_messages(St#procstate.id, {exit, Reason}, St),
|
246
|
-
terminate_insulator(St);
|
247
|
-
{'EXIT', Parent, _} ->
|
248
|
-
%% make sure child processes are cleaned up recursively
|
249
|
-
kill_task(Child, St)
|
250
|
-
end.
|
251
|
-
|
252
|
-
kill_task(Child, St) ->
|
253
|
-
exit(Child, kill),
|
254
|
-
terminate_insulator(St).
|
255
|
-
|
256
|
-
%% Unlinking before exit avoids polluting the parent process with exit
|
257
|
-
%% signals from the insulator. The child process is already dead here.
|
258
|
-
|
259
|
-
terminate_insulator(St) ->
|
260
|
-
%% messaging/unlinking is ok even if the parent is already dead
|
261
|
-
Parent = St#procstate.parent,
|
262
|
-
Parent ! {done, St#procstate.ref, self()},
|
263
|
-
unlink(Parent),
|
264
|
-
exit(normal).
|
265
|
-
|
266
|
-
%% send cancel messages for the Id of the "causing" item, and also for
|
267
|
-
%% the Id of the insulator itself, if they are different
|
268
|
-
exit_messages(Id, Cause, St) ->
|
269
|
-
%% the message for the most specific Id is always sent first
|
270
|
-
status_message(Id, {cancel, Cause}, St),
|
271
|
-
case St#procstate.id of
|
272
|
-
Id -> ok;
|
273
|
-
Id1 -> status_message(Id1, {cancel, {blame, Id}}, St)
|
274
|
-
end.
|
275
|
-
|
276
|
-
%% Child processes send all messages via the insulator to ensure proper
|
277
|
-
%% sequencing with timeouts and exit signals.
|
278
|
-
|
279
|
-
abort_message(Cause, St) ->
|
280
|
-
St#procstate.insulator ! {abort, self(), St#procstate.id, Cause}.
|
281
|
-
|
282
|
-
cancel_message(Msg, St) ->
|
283
|
-
St#procstate.insulator ! {cancel, self(), St#procstate.id, Msg}.
|
284
|
-
|
285
|
-
progress_message(Type, Data, St) ->
|
286
|
-
St#procstate.insulator ! {progress, self(), St#procstate.id,
|
287
|
-
Type, Data}.
|
288
|
-
|
289
|
-
%% Timeout handling
|
290
|
-
|
291
|
-
set_timeout(Time, St) ->
|
292
|
-
erlang:send_after(Time, St#procstate.insulator,
|
293
|
-
{timeout, self(), St#procstate.id}).
|
294
|
-
|
295
|
-
clear_timeout(Ref) ->
|
296
|
-
erlang:cancel_timer(Ref).
|
297
|
-
|
298
|
-
with_timeout(undefined, Default, F, St) ->
|
299
|
-
with_timeout(Default, F, St);
|
300
|
-
with_timeout(Time, _Default, F, St) ->
|
301
|
-
with_timeout(Time, F, St).
|
302
|
-
|
303
|
-
with_timeout(infinity, F, _St) ->
|
304
|
-
%% don't start timers unnecessarily
|
305
|
-
{T0, _} = statistics(wall_clock),
|
306
|
-
Value = F(),
|
307
|
-
{T1, _} = statistics(wall_clock),
|
308
|
-
{Value, T1 - T0};
|
309
|
-
with_timeout(Time, F, St) when is_integer(Time), Time > 16#FFFFffff ->
|
310
|
-
with_timeout(16#FFFFffff, F, St);
|
311
|
-
with_timeout(Time, F, St) when is_integer(Time), Time < 0 ->
|
312
|
-
with_timeout(0, F, St);
|
313
|
-
with_timeout(Time, F, St) when is_integer(Time) ->
|
314
|
-
Ref = set_timeout(Time, St),
|
315
|
-
{T0, _} = statistics(wall_clock),
|
316
|
-
try F() of
|
317
|
-
Value ->
|
318
|
-
%% we could also read the timer, but this is simpler
|
319
|
-
{T1, _} = statistics(wall_clock),
|
320
|
-
{Value, T1 - T0}
|
321
|
-
after
|
322
|
-
clear_timeout(Ref)
|
323
|
-
end.
|
324
|
-
|
325
|
-
%% The normal behaviour of a child process is to trap exit signals. This
|
326
|
-
%% makes it easier to write tests that spawn off separate (linked)
|
327
|
-
%% processes and test whether they terminate as expected. The testing
|
328
|
-
%% framework is not dependent on this, however, so the test code is
|
329
|
-
%% allowed to disable signal trapping as it pleases.
|
330
|
-
%% Note that I/O is redirected to the insulator process.
|
331
|
-
|
332
|
-
%% @spec (() -> term(), #procstate{}) -> ok
|
333
|
-
|
334
|
-
child_process(Fun, St) ->
|
335
|
-
process_flag(trap_exit, true),
|
336
|
-
group_leader(St#procstate.insulator, self()),
|
337
|
-
try Fun() of
|
338
|
-
_ -> ok
|
339
|
-
catch
|
340
|
-
%% the only "normal" way for a child process to bail out is to
|
341
|
-
%% throw an {eunit_abort, Reason} exception; any other exception
|
342
|
-
%% will be reported as an unexpected termination of the test
|
343
|
-
{eunit_abort, Cause} ->
|
344
|
-
abort_message(Cause, St),
|
345
|
-
exit(aborted)
|
346
|
-
end.
|
347
|
-
|
348
|
-
%% @throws abortException()
|
349
|
-
%% @type abortException() = {abort, Cause::term()}
|
350
|
-
|
351
|
-
abort_task(Cause) ->
|
352
|
-
throw({eunit_abort, Cause}).
|
353
|
-
|
354
|
-
%% Typically, the process that executes this code is trapping signals,
|
355
|
-
%% but it might not be - it is outside of our control, since test code
|
356
|
-
%% could turn off trapping. That is why the insulator process of a task
|
357
|
-
%% must be guaranteed to always send a reply before it terminates.
|
358
|
-
%%
|
359
|
-
%% The unique reference guarantees that we don't extract any message
|
360
|
-
%% from the mailbox unless it belongs to the test framework (and not to
|
361
|
-
%% the running tests) - it is not possible to use selective receive to
|
362
|
-
%% match only messages tagged with some pid in a dynamically varying set
|
363
|
-
%% of pids. When the wait-loop terminates, no such message should remain
|
364
|
-
%% in the mailbox.
|
365
|
-
|
366
|
-
wait_for_task(Pid, St) ->
|
367
|
-
wait_for_tasks(sets:from_list([Pid]), St).
|
368
|
-
|
369
|
-
wait_for_tasks(PidSet, St) ->
|
370
|
-
case sets:size(PidSet) of
|
371
|
-
0 ->
|
372
|
-
ok;
|
373
|
-
_ ->
|
374
|
-
%% (note that when we receive this message for some task, we
|
375
|
-
%% are guaranteed that the insulator process of the task has
|
376
|
-
%% already informed the supervisor about any anomalies)
|
377
|
-
Reference = St#procstate.ref,
|
378
|
-
receive
|
379
|
-
{done, Reference, Pid} ->
|
380
|
-
%% (if Pid is not in the set, del_element has no
|
381
|
-
%% effect, so this is always safe)
|
382
|
-
Rest = sets:del_element(Pid, PidSet),
|
383
|
-
wait_for_tasks(Rest, St)
|
384
|
-
end
|
385
|
-
end.
|
386
|
-
|
387
|
-
|
388
|
-
%% ---------------------------------------------------------------------
|
389
|
-
%% Separate testing process
|
390
|
-
|
391
|
-
tests(T, St) ->
|
392
|
-
I = eunit_data:iter_init(T, St#procstate.id),
|
393
|
-
case St#procstate.order of
|
394
|
-
inorder -> tests_inorder(I, St);
|
395
|
-
inparallel -> tests_inparallel(I, 0, St);
|
396
|
-
{inparallel, N} when is_integer(N), N >= 0 ->
|
397
|
-
tests_inparallel(I, N, St)
|
398
|
-
end.
|
399
|
-
|
400
|
-
set_id(I, St) ->
|
401
|
-
St#procstate{id = eunit_data:iter_id(I)}.
|
402
|
-
|
403
|
-
tests_inorder(I, St) ->
|
404
|
-
tests_inorder(I, 0, St).
|
405
|
-
|
406
|
-
tests_inorder(I, N, St) ->
|
407
|
-
case get_next_item(I) of
|
408
|
-
{T, I1} ->
|
409
|
-
handle_item(T, set_id(I1, St)),
|
410
|
-
tests_inorder(I1, N+1, St);
|
411
|
-
none ->
|
412
|
-
N
|
413
|
-
end.
|
414
|
-
|
415
|
-
tests_inparallel(I, K0, St) ->
|
416
|
-
tests_inparallel(I, 0, St, K0, K0, sets:new()).
|
417
|
-
|
418
|
-
tests_inparallel(I, N, St, K, K0, Children) when K =< 0, K0 > 0 ->
|
419
|
-
wait_for_tasks(Children, St),
|
420
|
-
tests_inparallel(I, N, St, K0, K0, sets:new());
|
421
|
-
tests_inparallel(I, N, St, K, K0, Children) ->
|
422
|
-
case get_next_item(I) of
|
423
|
-
{T, I1} ->
|
424
|
-
Child = spawn_item(T, set_id(I1, St)),
|
425
|
-
tests_inparallel(I1, N+1, St, K - 1, K0,
|
426
|
-
sets:add_element(Child, Children));
|
427
|
-
none ->
|
428
|
-
wait_for_tasks(Children, St),
|
429
|
-
N
|
430
|
-
end.
|
431
|
-
|
432
|
-
spawn_item(T, St0) ->
|
433
|
-
Fun = fun (St) ->
|
434
|
-
fun () -> handle_item(T, St) end
|
435
|
-
end,
|
436
|
-
%% inparallel-items are always spawned locally
|
437
|
-
start_task(local, Fun, St0).
|
438
|
-
|
439
|
-
get_next_item(I) ->
|
440
|
-
eunit_data:iter_next(I, fun abort_task/1).
|
441
|
-
|
442
|
-
handle_item(T, St) ->
|
443
|
-
case T of
|
444
|
-
#test{} -> handle_test(T, St);
|
445
|
-
#group{} -> handle_group(T, St)
|
446
|
-
end.
|
447
|
-
|
448
|
-
handle_test(T, St) ->
|
449
|
-
progress_message('begin', test, St),
|
450
|
-
{Status, Time} = with_timeout(T#test.timeout, ?DEFAULT_TEST_TIMEOUT,
|
451
|
-
fun () -> run_test(T) end, St),
|
452
|
-
progress_message('end', {Status, Time}, St),
|
453
|
-
ok.
|
454
|
-
|
455
|
-
%% @spec (#test{}) -> ok | {error, eunit_lib:exception()}
|
456
|
-
%% | {skipped, eunit_test:wrapperError()}
|
457
|
-
|
458
|
-
run_test(#test{f = F}) ->
|
459
|
-
try eunit_test:run_testfun(F) of
|
460
|
-
{ok, _Value} ->
|
461
|
-
%% just throw away the return value
|
462
|
-
ok;
|
463
|
-
{error, Exception} ->
|
464
|
-
{error, Exception}
|
465
|
-
catch
|
466
|
-
throw:WrapperError -> {skipped, WrapperError}
|
467
|
-
end.
|
468
|
-
|
469
|
-
set_group_order(#group{order = undefined}, St) ->
|
470
|
-
St;
|
471
|
-
set_group_order(#group{order = Order}, St) ->
|
472
|
-
St#procstate{order = Order}.
|
473
|
-
|
474
|
-
handle_group(T, St0) ->
|
475
|
-
St = set_group_order(T, St0),
|
476
|
-
case T#group.spawn of
|
477
|
-
undefined ->
|
478
|
-
run_group(T, St);
|
479
|
-
Type ->
|
480
|
-
Child = spawn_group(Type, T, St),
|
481
|
-
wait_for_task(Child, St)
|
482
|
-
end.
|
483
|
-
|
484
|
-
spawn_group(Type, T, St0) ->
|
485
|
-
Fun = fun (St) ->
|
486
|
-
fun () -> run_group(T, St) end
|
487
|
-
end,
|
488
|
-
start_task(Type, Fun, St0).
|
489
|
-
|
490
|
-
run_group(T, St) ->
|
491
|
-
%% note that the setup/cleanup is outside the group timeout; if the
|
492
|
-
%% setup fails, we do not start any timers
|
493
|
-
Timeout = T#group.timeout,
|
494
|
-
progress_message('begin', group, St),
|
495
|
-
F = fun (T) -> enter_group(T, Timeout, St) end,
|
496
|
-
try with_context(T, F) of
|
497
|
-
{Status, Time} ->
|
498
|
-
progress_message('end', {Status, Time}, St)
|
499
|
-
catch
|
500
|
-
throw:Cause ->
|
501
|
-
cancel_message({abort, Cause}, St)
|
502
|
-
end,
|
503
|
-
ok.
|
504
|
-
|
505
|
-
enter_group(T, Timeout, St) ->
|
506
|
-
with_timeout(Timeout, ?DEFAULT_GROUP_TIMEOUT,
|
507
|
-
fun () -> tests(T, St) end, St).
|
508
|
-
|
509
|
-
with_context(#group{context = undefined, tests = T}, F) ->
|
510
|
-
F(T);
|
511
|
-
with_context(#group{context = #context{} = C, tests = I}, F) ->
|
512
|
-
eunit_data:enter_context(C, I, F).
|
513
|
-
|
514
|
-
%% Implementation of buffering I/O for the insulator process. (Note that
|
515
|
-
%% each batch of characters is just pushed on the buffer, so it needs to
|
516
|
-
%% be reversed when it is flushed.)
|
517
|
-
|
518
|
-
io_request(From, ReplyAs, Req, Buf) ->
|
519
|
-
{Reply, Buf1} = io_request(Req, Buf),
|
520
|
-
io_reply(From, ReplyAs, Reply),
|
521
|
-
Buf1.
|
522
|
-
|
523
|
-
io_reply(From, ReplyAs, Reply) ->
|
524
|
-
From ! {io_reply, ReplyAs, Reply}.
|
525
|
-
|
526
|
-
io_request({put_chars, Chars}, Buf) ->
|
527
|
-
{ok, [Chars | Buf]};
|
528
|
-
io_request({put_chars, M, F, As}, Buf) ->
|
529
|
-
try apply(M, F, As) of
|
530
|
-
Chars -> {ok, [Chars | Buf]}
|
531
|
-
catch
|
532
|
-
C:T -> {{error, {C,T,erlang:get_stacktrace()}}, Buf}
|
533
|
-
end;
|
534
|
-
io_request({get_chars, _Prompt, _N}, Buf) ->
|
535
|
-
{eof, Buf};
|
536
|
-
io_request({get_chars, _Prompt, _M, _F, _Xs}, Buf) ->
|
537
|
-
{eof, Buf};
|
538
|
-
io_request({get_line, _Prompt}, Buf) ->
|
539
|
-
{eof, Buf};
|
540
|
-
io_request({get_until, _Prompt, _M, _F, _As}, Buf) ->
|
541
|
-
{eof, Buf};
|
542
|
-
io_request({setopts, _Opts}, Buf) ->
|
543
|
-
{ok, Buf};
|
544
|
-
io_request({requests, Reqs}, Buf) ->
|
545
|
-
io_requests(Reqs, {ok, Buf});
|
546
|
-
io_request(_, Buf) ->
|
547
|
-
{{error, request}, Buf}.
|
548
|
-
|
549
|
-
io_requests([R | Rs], {ok, Buf}) ->
|
550
|
-
io_requests(Rs, io_request(R, Buf));
|
551
|
-
io_requests(_, Result) ->
|
552
|
-
Result.
|
@@ -1,157 +0,0 @@
|
|
1
|
-
%% This library is free software; you can redistribute it and/or modify
|
2
|
-
%% it under the terms of the GNU Lesser General Public License as
|
3
|
-
%% published by the Free Software Foundation; either version 2 of the
|
4
|
-
%% License, or (at your option) any later version.
|
5
|
-
%%
|
6
|
-
%% This library is distributed in the hope that it will be useful, but
|
7
|
-
%% WITHOUT ANY WARRANTY; without even the implied warranty of
|
8
|
-
%% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
9
|
-
%% Lesser General Public License for more details.
|
10
|
-
%%
|
11
|
-
%% You should have received a copy of the GNU Lesser General Public
|
12
|
-
%% License along with this library; if not, write to the Free Software
|
13
|
-
%% Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
14
|
-
%% USA
|
15
|
-
%%
|
16
|
-
%% $Id: eunit_serial.erl 249 2008-05-11 20:06:45Z rcarlsson $
|
17
|
-
%%
|
18
|
-
%% @author Richard Carlsson <richardc@it.uu.se>
|
19
|
-
%% @copyright 2006 Richard Carlsson
|
20
|
-
%% @private
|
21
|
-
%% @see eunit
|
22
|
-
%% @doc Event serializing process which works as an adapter and
|
23
|
-
%% multiplexer for "supervisor" processes
|
24
|
-
|
25
|
-
-module(eunit_serial).
|
26
|
-
|
27
|
-
-include("eunit.hrl").
|
28
|
-
-include("eunit_internal.hrl").
|
29
|
-
|
30
|
-
-export([start/1]).
|
31
|
-
|
32
|
-
%% Notes:
|
33
|
-
%% * Due to concurrency, there are no guarantees that we will receive
|
34
|
-
%% all status messages for the items within a group before we receive
|
35
|
-
%% the 'end' message of the group itself.
|
36
|
-
%%
|
37
|
-
%% * A cancelling event may arrive at any time, and may concern items we
|
38
|
-
%% are not yet expecting (if tests are executed in parallel), or may
|
39
|
-
%% concern not only the current item but possibly a group ancestor of
|
40
|
-
%% the current item (as in the case of a group timeout).
|
41
|
-
%%
|
42
|
-
%% * It is not possible to use selective receive to extract only those
|
43
|
-
%% cancelling messages that affect the current item and its parents;
|
44
|
-
%% basically, because we cannot have a dynamically computed prefix as a
|
45
|
-
%% pattern in a receive. Hence, we must extract each cancelling event as
|
46
|
-
%% it arrives and keep track of them separately.
|
47
|
-
%%
|
48
|
-
%% * Before we wait for a new item, we must check whether it (and thus
|
49
|
-
%% also all its subitems, if any) is already cancelled.
|
50
|
-
%%
|
51
|
-
%% * When a new cancelling event arrives, we must either store it for
|
52
|
-
%% future use, and/or cancel the current item and possibly one or more
|
53
|
-
%% of its parent groups.
|
54
|
-
|
55
|
-
-record(state, {listeners,
|
56
|
-
cancelled = eunit_lib:trie_new(),
|
57
|
-
messages = dict:new()}).
|
58
|
-
|
59
|
-
start(Pids) ->
|
60
|
-
spawn(fun () -> serializer(Pids) end).
|
61
|
-
|
62
|
-
serializer(Pids) ->
|
63
|
-
St = #state{listeners = sets:from_list(Pids),
|
64
|
-
cancelled = eunit_lib:trie_new(),
|
65
|
-
messages = dict:new()},
|
66
|
-
item([], none, none, St),
|
67
|
-
exit(normal).
|
68
|
-
|
69
|
-
item(Id, ParentId, N0, St0) ->
|
70
|
-
case wait(Id, 'begin', ParentId, N0, St0) of
|
71
|
-
{none, St1} ->
|
72
|
-
{true, St1};
|
73
|
-
{{cancel, Done, undefined}, St1} ->
|
74
|
-
{Done, cast({status, Id, {cancel, undefined}}, St1)};
|
75
|
-
{{cancel, Done, Msg}, St1} ->
|
76
|
-
{Done, cast(Msg, St1)};
|
77
|
-
{{ok, Msg}, St1} ->
|
78
|
-
%%?debugVal({got_begin, Id, Msg}),
|
79
|
-
cast(Msg, St1),
|
80
|
-
St2 = case Msg of
|
81
|
-
{status, _, {progress, 'begin', group}} ->
|
82
|
-
items(Id, 0, St1);
|
83
|
-
_ -> St1
|
84
|
-
end,
|
85
|
-
case wait(Id, 'end', ParentId, N0, St2) of
|
86
|
-
{{cancel, Done, undefined}, St3} ->
|
87
|
-
{Done, cast({status, Id, {cancel, undefined}}, St3)};
|
88
|
-
{{cancel, Done, Msg1}, St3} ->
|
89
|
-
{Done, cast(Msg1, St3)};
|
90
|
-
{{ok, Msg1}, St3} ->
|
91
|
-
%%?debugVal({got_end, Id, Msg1}),
|
92
|
-
{false, cast(Msg1, St3)}
|
93
|
-
end
|
94
|
-
end.
|
95
|
-
|
96
|
-
items(ParentId, N0, St) ->
|
97
|
-
N = N0 + 1,
|
98
|
-
case item(ParentId ++ [N], ParentId, N0, St) of
|
99
|
-
{false, St1} ->
|
100
|
-
items(ParentId, N, St1);
|
101
|
-
{true, St1} ->
|
102
|
-
St1
|
103
|
-
end.
|
104
|
-
|
105
|
-
cast(M, St) ->
|
106
|
-
sets:fold(fun (L, M) -> L ! M end, M, St#state.listeners),
|
107
|
-
St.
|
108
|
-
|
109
|
-
wait(Id, Type, ParentId, N0, St) ->
|
110
|
-
%%?debugVal({wait, Id, Type}),
|
111
|
-
case check_cancelled(Id, St) of
|
112
|
-
no ->
|
113
|
-
case recall(Id, St) of
|
114
|
-
undefined ->
|
115
|
-
wait_1(Id, Type, ParentId, N0, St);
|
116
|
-
Msg ->
|
117
|
-
{{ok, Msg}, forget(Id, St)}
|
118
|
-
end;
|
119
|
-
Why ->
|
120
|
-
%%?debugVal({cancelled, Why, Id, ParentId}),
|
121
|
-
Done = (Why =:= prefix),
|
122
|
-
{{cancel, Done, recall(Id, St)}, forget(Id, St)}
|
123
|
-
end.
|
124
|
-
|
125
|
-
wait_1(Id, Type, ParentId, N0, St) ->
|
126
|
-
receive
|
127
|
-
{status, Id, {progress, Type, _}}=Msg ->
|
128
|
-
%%?debugVal({Type, ParentId, Id}),
|
129
|
-
{{ok, Msg}, St};
|
130
|
-
{status,ParentId,{progress,'end',{N0,_,_}}}=Msg ->
|
131
|
-
%%?debugVal({end_group, ParentId, Id}),
|
132
|
-
{none, remember(ParentId, Msg, St)};
|
133
|
-
{status, SomeId, {cancel, _Cause}}=Msg ->
|
134
|
-
%%?debugVal({got_cancel, SomeId, ParentId, Id}),
|
135
|
-
St1 = set_cancelled(SomeId, Msg, St),
|
136
|
-
wait(Id, Type, ParentId, N0, St1)
|
137
|
-
end.
|
138
|
-
|
139
|
-
set_cancelled(Id, Msg, St0) ->
|
140
|
-
St = remember(Id, Msg, St0),
|
141
|
-
St#state{cancelled = eunit_lib:trie_store(Id, St0#state.cancelled)}.
|
142
|
-
|
143
|
-
check_cancelled(Id, St) ->
|
144
|
-
eunit_lib:trie_match(Id, St#state.cancelled).
|
145
|
-
|
146
|
-
remember(Id, Msg, St) ->
|
147
|
-
St#state{messages = dict:store(Id, Msg, St#state.messages)}.
|
148
|
-
|
149
|
-
forget(Id, St) ->
|
150
|
-
%% this is just to enable garbage collection of old messages
|
151
|
-
St#state{messages = dict:store(Id, undefined, St#state.messages)}.
|
152
|
-
|
153
|
-
recall(Id, St) ->
|
154
|
-
case dict:find(Id, St#state.messages) of
|
155
|
-
{ok, Msg} -> Msg;
|
156
|
-
error -> undefined
|
157
|
-
end.
|