rules_engine 0.1.1 → 0.1.3
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +0 -0
- data/README.textile +12 -12
- data/VERSION +1 -1
- data/lib/rules_engine.rb +4 -18
- data/lib/rules_engine/cache.rb +1 -1
- data/lib/rules_engine/discovery.rb +14 -5
- data/lib/rules_engine/process/auditor.rb +62 -0
- data/lib/rules_engine/process/auditor/db_auditor.rb +48 -0
- data/lib/rules_engine/process/runner.rb +147 -0
- data/lib/rules_engine/process/runner/db_runner.rb +78 -0
- data/lib/rules_engine/publish/publisher.rb +53 -0
- data/lib/rules_engine/publish/publisher/db_publisher.rb +93 -0
- data/lib/rules_engine/rule.rb +6 -6
- data/lib/rules_engine/rule_outcome.rb +4 -4
- data/lib/rules_engine_view.rb +14 -0
- data/lib/rules_engine_view/boxes.rb +0 -0
- data/lib/rules_engine_view/buttons.rb +0 -0
- data/lib/rules_engine_view/defer.rb +19 -3
- data/lib/rules_engine_view/form_fields.rb +0 -0
- data/lib/rules_engine_view/model_loader.rb +6 -2
- data/lib/rules_engine_view/navigate.rb +1 -3
- data/rails_generators/manifests/rule_complex.rb +30 -0
- data/rails_generators/manifests/rule_complex.yml +24 -0
- data/rails_generators/manifests/rule_simple.rb +26 -0
- data/rails_generators/manifests/rule_simple.yml +21 -0
- data/rails_generators/manifests/rules_engine.rb +244 -276
- data/rails_generators/manifests/rules_engine.yml +37 -59
- data/rails_generators/rules_engine_generator.rb +16 -32
- data/rails_generators/templates/app/controllers/re_plan_workflow_rules_controller.rb +142 -0
- data/rails_generators/templates/app/controllers/re_plan_workflows_controller.rb +139 -0
- data/rails_generators/templates/app/controllers/re_plans_controller.rb +131 -0
- data/rails_generators/templates/app/controllers/re_processes_controller.rb +15 -0
- data/rails_generators/templates/app/controllers/re_publications_controller.rb +15 -0
- data/rails_generators/templates/app/controllers/{re_pipeline_rules_controller.rb → re_workflow_rules_controller.rb} +12 -12
- data/rails_generators/templates/app/controllers/re_workflows_controller.rb +96 -0
- data/rails_generators/templates/app/helpers/rules_engine_helper.rb +42 -0
- data/rails_generators/templates/app/models/re_plan.rb +126 -0
- data/rails_generators/templates/app/models/re_plan_workflow.rb +10 -0
- data/rails_generators/templates/app/models/re_rule.rb +47 -60
- data/rails_generators/templates/app/models/re_rule_expected_outcome.rb +3 -21
- data/rails_generators/templates/app/models/re_workflow.rb +61 -0
- data/rails_generators/templates/app/rules/{complex_rule.rb → rule_complex.rb} +30 -30
- data/rails_generators/templates/app/rules/{simple_rule.rb → rule_simple.rb} +13 -14
- data/rails_generators/templates/app/views/layouts/rules_engine.html.erb +6 -9
- data/rails_generators/templates/app/views/re_plan_workflow_rules/edit.html.erb +13 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/edit.js.erb +9 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/error.html.erb +12 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/error.js.erb +7 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/help.html.erb +12 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/help.js.erb +4 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/new.html.erb +16 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/new.js.erb +10 -0
- data/rails_generators/templates/app/views/re_plan_workflow_rules/update.js.erb +19 -0
- data/rails_generators/templates/app/views/re_plan_workflows/change.html.erb +78 -0
- data/rails_generators/templates/app/views/re_plan_workflows/edit.html.erb +12 -0
- data/rails_generators/templates/app/views/re_plan_workflows/edit.js.erb +8 -0
- data/rails_generators/templates/app/views/re_plan_workflows/new.html.erb +12 -0
- data/rails_generators/templates/app/views/re_plan_workflows/new.js.erb +5 -0
- data/rails_generators/templates/app/views/re_plan_workflows/show.html.erb +70 -0
- data/rails_generators/templates/app/views/re_plan_workflows/update.js.erb +19 -0
- data/rails_generators/templates/app/views/re_plans/_change.html.erb +39 -0
- data/rails_generators/templates/app/views/re_plans/_edit.html.erb +20 -0
- data/rails_generators/templates/app/views/re_plans/_empty.html.erb +12 -0
- data/rails_generators/templates/app/views/re_plans/_index.html.erb +42 -0
- data/rails_generators/templates/app/views/re_plans/_menu.html.erb +26 -0
- data/rails_generators/templates/app/views/re_plans/_new.html.erb +18 -0
- data/rails_generators/templates/app/views/re_plans/_preview.html.erb +47 -0
- data/rails_generators/templates/app/views/re_plans/_show.html.erb +27 -0
- data/rails_generators/templates/app/views/re_plans/_workflow_change.html.erb +44 -0
- data/rails_generators/templates/app/views/re_plans/_workflow_preview.html.erb +24 -0
- data/rails_generators/templates/app/views/re_plans/_workflow_show.html.erb +32 -0
- data/rails_generators/templates/app/views/re_plans/change.html.erb +118 -0
- data/rails_generators/templates/app/views/re_plans/create.js.erb +9 -0
- data/rails_generators/templates/app/views/re_plans/edit.html.erb +11 -0
- data/rails_generators/templates/app/views/re_plans/edit.js.erb +8 -0
- data/rails_generators/templates/app/views/re_plans/index.html.erb +33 -0
- data/rails_generators/templates/app/views/re_plans/index.js.erb +18 -0
- data/rails_generators/templates/app/views/re_plans/new.html.erb +9 -0
- data/rails_generators/templates/app/views/re_plans/new.js.erb +5 -0
- data/rails_generators/templates/app/views/re_plans/preview.html.erb +6 -0
- data/rails_generators/templates/app/views/re_plans/preview.js.erb +4 -0
- data/rails_generators/templates/app/views/re_plans/re_process.html.erb +12 -0
- data/rails_generators/templates/app/views/re_plans/re_process.js.erb +4 -0
- data/rails_generators/templates/app/views/re_plans/show.html.erb +56 -0
- data/rails_generators/templates/app/views/{re_pipelines → re_plans}/template.html.erb +1 -1
- data/rails_generators/templates/app/views/re_plans/update.js.erb +15 -0
- data/rails_generators/templates/app/views/re_processes/_index_prepare.html.erb +12 -0
- data/rails_generators/templates/app/views/re_processes/_index_update.html.erb +20 -0
- data/rails_generators/templates/app/views/re_processes/_show.html.erb +30 -0
- data/rails_generators/templates/app/views/re_processes/index.html.erb +11 -0
- data/rails_generators/templates/app/views/re_processes/index.js.erb +4 -0
- data/rails_generators/templates/app/views/re_processes/show.html.erb +8 -0
- data/rails_generators/templates/app/views/re_processes/show.js.erb +4 -0
- data/rails_generators/templates/app/views/re_publications/_show_prepare.html.erb +14 -0
- data/rails_generators/templates/app/views/re_publications/_show_update.html.erb +16 -0
- data/rails_generators/templates/app/views/re_publications/show.html.erb +11 -0
- data/rails_generators/templates/app/views/re_publications/show.js.erb +4 -0
- data/rails_generators/templates/app/views/re_rule_definitions/rule_complex/_edit.html.erb +7 -0
- data/rails_generators/templates/app/views/re_rule_definitions/{complex_rule → rule_complex}/_help.html.erb +1 -1
- data/rails_generators/templates/app/views/re_rule_definitions/rule_complex/_new.html.erb +7 -0
- data/rails_generators/templates/app/views/re_rule_definitions/rule_complex/_script.html.erb +25 -0
- data/rails_generators/templates/app/views/re_rule_definitions/{complex_rule → rule_complex}/_title.html.erb +0 -0
- data/rails_generators/templates/app/views/re_rule_definitions/{complex_rule → rule_complex}/_word.html.erb +0 -0
- data/rails_generators/templates/app/views/re_rule_definitions/{complex_rule → rule_complex}/_words.html.erb +2 -2
- data/rails_generators/templates/app/views/re_rule_definitions/{complex_rule/_pipeline.html.erb → rule_complex/_workflow.html.erb} +5 -5
- data/rails_generators/templates/app/views/re_rule_definitions/rule_simple/_edit.html.erb +1 -0
- data/rails_generators/templates/app/views/re_rule_definitions/{simple_rule → rule_simple}/_form.html.erb +1 -1
- data/rails_generators/templates/app/views/re_rule_definitions/{simple_rule → rule_simple}/_help.html.erb +0 -0
- data/rails_generators/templates/app/views/re_rule_definitions/rule_simple/_new.html.erb +1 -0
- data/rails_generators/templates/app/views/re_workflow_rules/_edit.html.erb +19 -0
- data/rails_generators/templates/app/views/{re_pipeline_rules → re_workflow_rules}/_error.html.erb +0 -0
- data/rails_generators/templates/app/views/re_workflow_rules/_help.html.erb +15 -0
- data/rails_generators/templates/app/views/{re_pipeline_rules → re_workflow_rules}/_new.html.erb +6 -3
- data/rails_generators/templates/app/views/re_workflow_rules/edit.html.erb +13 -0
- data/rails_generators/templates/app/views/re_workflow_rules/edit.js.erb +9 -0
- data/rails_generators/templates/app/views/re_workflow_rules/error.html.erb +12 -0
- data/rails_generators/templates/app/views/re_workflow_rules/error.js.erb +7 -0
- data/rails_generators/templates/app/views/re_workflow_rules/help.html.erb +12 -0
- data/rails_generators/templates/app/views/re_workflow_rules/help.js.erb +4 -0
- data/rails_generators/templates/app/views/re_workflow_rules/new.html.erb +15 -0
- data/rails_generators/templates/app/views/{re_pipeline_rules → re_workflow_rules}/new.js.erb +1 -1
- data/rails_generators/templates/app/views/re_workflow_rules/update.js.erb +17 -0
- data/rails_generators/templates/app/views/re_workflows/_add_prepare.html.erb +15 -0
- data/rails_generators/templates/app/views/re_workflows/_add_update.html.erb +21 -0
- data/rails_generators/templates/app/views/re_workflows/_edit.html.erb +23 -0
- data/rails_generators/templates/app/views/re_workflows/_empty.html.erb +12 -0
- data/rails_generators/templates/app/views/re_workflows/_index.html.erb +41 -0
- data/rails_generators/templates/app/views/re_workflows/_menu.html.erb +92 -0
- data/rails_generators/templates/app/views/re_workflows/_new.html.erb +21 -0
- data/rails_generators/templates/app/views/re_workflows/_plan_prepare.html.erb +14 -0
- data/rails_generators/templates/app/views/re_workflows/_plan_update.html.erb +21 -0
- data/rails_generators/templates/app/views/re_workflows/_preview.html.erb +30 -0
- data/rails_generators/templates/app/views/re_workflows/_rule_change.html.erb +65 -0
- data/rails_generators/templates/app/views/re_workflows/_rule_empty.html.erb +13 -0
- data/rails_generators/templates/app/views/{re_pipeline_rules/_index.html.erb → re_workflows/_rule_preview.html.erb} +20 -11
- data/rails_generators/templates/app/views/re_workflows/_rule_show.html.erb +46 -0
- data/rails_generators/templates/app/views/re_workflows/_show.html.erb +24 -0
- data/rails_generators/templates/app/views/re_workflows/add.html.erb +11 -0
- data/rails_generators/templates/app/views/re_workflows/add.js.erb +6 -0
- data/rails_generators/templates/app/views/re_workflows/change.html.erb +53 -0
- data/rails_generators/templates/app/views/re_workflows/create.js.erb +9 -0
- data/rails_generators/templates/app/views/re_workflows/edit.html.erb +11 -0
- data/rails_generators/templates/app/views/re_workflows/edit.js.erb +8 -0
- data/rails_generators/templates/app/views/re_workflows/index.html.erb +34 -0
- data/rails_generators/templates/app/views/re_workflows/new.html.erb +9 -0
- data/rails_generators/templates/app/views/re_workflows/new.js.erb +5 -0
- data/rails_generators/templates/app/views/re_workflows/plan.html.erb +12 -0
- data/rails_generators/templates/app/views/re_workflows/plan.js.erb +4 -0
- data/rails_generators/templates/app/views/re_workflows/preview.html.erb +5 -0
- data/rails_generators/templates/app/views/re_workflows/preview.js.erb +4 -0
- data/rails_generators/templates/app/views/re_workflows/show.html.erb +47 -0
- data/rails_generators/templates/app/views/re_workflows/update.js.erb +17 -0
- data/rails_generators/templates/config/initializers/rules_engine.rb +9 -0
- data/rails_generators/templates/db/migrate/20100308225008_create_rules_engine.rb +113 -0
- data/rails_generators/templates/doc/README.rules_engine +113 -98
- data/rails_generators/templates/lib/tasks/rules_engine.rake +29 -10
- data/rails_generators/templates/public/javascripts/rules_engine/re_plan_change.js +85 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_plan_new.js +29 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_plan_preview.js +18 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_process_index.js +43 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_process_show.js +18 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_publication_show.js +39 -0
- data/rails_generators/templates/public/javascripts/{re_view.js → rules_engine/re_view.js} +19 -3
- data/rails_generators/templates/public/javascripts/rules_engine/re_workflow_add.js +124 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_workflow_change.js +185 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_workflow_new.js +29 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_workflow_plan.js +38 -0
- data/rails_generators/templates/public/javascripts/rules_engine/re_workflow_preview.js +18 -0
- data/rails_generators/templates/public/stylesheets/{re_view_box → rules_engine/images/re_view_box}/shadowbox.png +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_box → rules_engine/images/re_view_box}/whitebox.jpg +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/checked-off.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/checked-on.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/icon-add.png +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/icon-delete.png +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-blue-left.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-blue-right.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-gray-left.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-gray-right.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-green-left.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-green-right.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-orange-left.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-orange-right.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-red-left.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_button → rules_engine/images/re_view_button}/oval-red-right.gif +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_error → rules_engine/images/re_view_error}/re-alert-close.png +0 -0
- data/rails_generators/templates/public/stylesheets/{re_view_navigate → rules_engine/images/re_view_navigate}/breadcrumb.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/next-disabled-14.png → images/rules_engine/re_common/list-next-disabled-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/next-enabled-14.png → images/rules_engine/re_common/list-next-enabled-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/prev-disabled-14.png → images/rules_engine/re_common/list-prev-disabled-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/prev-enabled-14.png → images/rules_engine/re_common/list-prev-enabled-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/loadingAnimation.gif → images/rules_engine/re_common/loading.gif} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/alert-18.png → images/rules_engine/re_common/status-changed-18.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/alert-25.png → images/rules_engine/re_common/status-changed-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/info-18.png → images/rules_engine/re_common/status-draft-18.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/info-25.png → images/rules_engine/re_common/status-draft-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/error-14.png → images/rules_engine/re_common/status-error-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/info-14.png → images/rules_engine/re_common/status-info-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/success-18.png → images/rules_engine/re_common/status-published-18.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/success-25.png → images/rules_engine/re_common/status-published-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/success-14.png → images/rules_engine/re_common/status-success-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/current-14.png → images/rules_engine/re_common/status-valid-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/current-18.png → images/rules_engine/re_common/status-valid-18.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/draft-14.png → images/rules_engine/re_common/status-verify-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/error-18.png → images/rules_engine/re_common/status-verify-18.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_job/error-25.png → images/rules_engine/re_common/status-verify-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/alert-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/change-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/delete-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/edit-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/list-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/new-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/preview-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/publish-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/revert-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/show-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/title-plural.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_plan/title-single.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule/stop-failure-14.png → images/rules_engine/re_process/error-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_process/info-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_process/list-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule/stop-success-14.png → images/rules_engine/re_process/success-14.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_publication/show-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule_class → images/rules_engine/re_rule}/add-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/alert-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline → images/rules_engine/re_rule}/destroy-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/edit-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/error-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule_class → images/rules_engine/re_rule}/help-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/help-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/current-25.png → images/rules_engine/re_rule/icon-ad-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/move-down-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/move-down-off-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/move-up-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/move-up-off-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/new-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule/next-change-25.png → images/rules_engine/re_rule/next-down-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule/next-show-18.png → images/rules_engine/re_rule/next-right-18.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/change-25.png → images/rules_engine/re_rule/show-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/start-pipeline-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/stop-failure-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_rule → images/rules_engine/re_rule}/stop-success-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/title-plural.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_rule/title-single.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/add-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/add-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/add-off-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/alert-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/change-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/change-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/delete-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/edit-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/is-default-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/list-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/make-default-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/make-default-off-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/new-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/{re_pipeline/revert-25.png → images/rules_engine/re_workflow/plan-25.png} +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/preview-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/remove-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/show-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/show-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/title-plural.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/images/rules_engine/re_workflow/title-single.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/screen.css +1580 -0
- data/rails_generators/templates/spec/controllers/re_plans_controller_spec.rb +409 -0
- data/rails_generators/templates/spec/helpers/rules_engine_helper_spec.rb +86 -0
- data/rails_generators/templates/spec/lib/rules/rule_complex_spec.rb +331 -0
- data/rails_generators/templates/spec/lib/rules/rule_simple_spec.rb +161 -0
- data/rails_generators/templates/spec/models/re_plan_spec.rb +349 -0
- data/rails_generators/templates/spec/models/re_plan_workflow_spec.rb +6 -0
- data/rails_generators/templates/spec/models/re_rule_expected_outcome_spec.rb +7 -51
- data/rails_generators/templates/spec/models/re_rule_spec.rb +108 -152
- data/rails_generators/templates/spec/models/re_workflow_spec.rb +186 -0
- data/rails_generators/templates/spec/support/rules_engine_blueprints.rb +27 -0
- data/spec/railsenv/log/debug.log +7061 -1
- data/spec/railsenv/log/empty.txt +1 -0
- data/spec/railsenv/log/test.log +492 -1
- data/spec/rules_engine/discovery_spec.rb +40 -4
- data/spec/rules_engine/process/auditor/db_auditor_spec.rb +115 -0
- data/spec/rules_engine/process/auditor_spec.rb +111 -0
- data/spec/rules_engine/process/runner/db_runner_spec.rb +229 -0
- data/spec/rules_engine/process/runner_spec.rb +236 -0
- data/spec/rules_engine/publish/publisher/db_publisher_spec.rb +280 -0
- data/spec/rules_engine/publish/publisher_spec.rb +64 -0
- data/spec/rules_engine/rule_spec.rb +7 -11
- data/spec/rules_engine_view/defer_spec.rb +30 -0
- data/spec/rules_engine_view/model_loader_spec.rb +3 -3
- data/spec/spec_helper.rb +36 -1
- metadata +268 -292
- data/lib/rules_engine/job.rb +0 -127
- data/rails_generators/manifests/rules_engine_complex.rb +0 -30
- data/rails_generators/manifests/rules_engine_complex.yml +0 -24
- data/rails_generators/manifests/rules_engine_simple.rb +0 -26
- data/rails_generators/manifests/rules_engine_simple.yml +0 -21
- data/rails_generators/templates/app/controllers/re_jobs_controller.rb +0 -20
- data/rails_generators/templates/app/controllers/re_pipeline_jobs_controller.rb +0 -16
- data/rails_generators/templates/app/controllers/re_pipelines_controller.rb +0 -171
- data/rails_generators/templates/app/helpers/re_pipeline_helper.rb +0 -14
- data/rails_generators/templates/app/models/re_job.rb +0 -122
- data/rails_generators/templates/app/models/re_job_audit.rb +0 -18
- data/rails_generators/templates/app/models/re_pipeline.rb +0 -47
- data/rails_generators/templates/app/models/re_pipeline_activated.rb +0 -29
- data/rails_generators/templates/app/models/re_pipeline_activated_observer.rb +0 -11
- data/rails_generators/templates/app/models/re_pipeline_base.rb +0 -63
- data/rails_generators/templates/app/views/re_jobs/_empty.html.erb +0 -14
- data/rails_generators/templates/app/views/re_jobs/_index_large.html.erb +0 -79
- data/rails_generators/templates/app/views/re_jobs/_index_small.html.erb +0 -41
- data/rails_generators/templates/app/views/re_jobs/_show.html.erb +0 -38
- data/rails_generators/templates/app/views/re_jobs/index.html.erb +0 -14
- data/rails_generators/templates/app/views/re_jobs/index.js.erb +0 -12
- data/rails_generators/templates/app/views/re_jobs/show.html.erb +0 -14
- data/rails_generators/templates/app/views/re_jobs/show.js.erb +0 -4
- data/rails_generators/templates/app/views/re_pipeline_jobs/index.html.erb +0 -15
- data/rails_generators/templates/app/views/re_pipeline_jobs/index.js.erb +0 -12
- data/rails_generators/templates/app/views/re_pipeline_rules/_change.html.erb +0 -57
- data/rails_generators/templates/app/views/re_pipeline_rules/_edit.html.erb +0 -16
- data/rails_generators/templates/app/views/re_pipeline_rules/_empty.html.erb +0 -12
- data/rails_generators/templates/app/views/re_pipeline_rules/_empty.js.erb +0 -7
- data/rails_generators/templates/app/views/re_pipeline_rules/_help.html.erb +0 -13
- data/rails_generators/templates/app/views/re_pipeline_rules/_menu.html.erb +0 -37
- data/rails_generators/templates/app/views/re_pipeline_rules/_show.html.erb +0 -44
- data/rails_generators/templates/app/views/re_pipeline_rules/destroy.js.erb +0 -14
- data/rails_generators/templates/app/views/re_pipeline_rules/edit.html.erb +0 -12
- data/rails_generators/templates/app/views/re_pipeline_rules/edit.js.erb +0 -8
- data/rails_generators/templates/app/views/re_pipeline_rules/error.html.erb +0 -12
- data/rails_generators/templates/app/views/re_pipeline_rules/error.js.erb +0 -7
- data/rails_generators/templates/app/views/re_pipeline_rules/help.html.erb +0 -12
- data/rails_generators/templates/app/views/re_pipeline_rules/help.js.erb +0 -4
- data/rails_generators/templates/app/views/re_pipeline_rules/new.html.erb +0 -15
- data/rails_generators/templates/app/views/re_pipeline_rules/update.js.erb +0 -21
- data/rails_generators/templates/app/views/re_pipelines/_change.html.erb +0 -48
- data/rails_generators/templates/app/views/re_pipelines/_change_actions.html.erb +0 -34
- data/rails_generators/templates/app/views/re_pipelines/_confirm.html.erb +0 -39
- data/rails_generators/templates/app/views/re_pipelines/_edit.html.erb +0 -20
- data/rails_generators/templates/app/views/re_pipelines/_empty.html.erb +0 -13
- data/rails_generators/templates/app/views/re_pipelines/_index.html.erb +0 -64
- data/rails_generators/templates/app/views/re_pipelines/_new.html.erb +0 -18
- data/rails_generators/templates/app/views/re_pipelines/_show.html.erb +0 -36
- data/rails_generators/templates/app/views/re_pipelines/change.html.erb +0 -37
- data/rails_generators/templates/app/views/re_pipelines/create.js.erb +0 -9
- data/rails_generators/templates/app/views/re_pipelines/edit.html.erb +0 -12
- data/rails_generators/templates/app/views/re_pipelines/edit.js.erb +0 -8
- data/rails_generators/templates/app/views/re_pipelines/index.html.erb +0 -61
- data/rails_generators/templates/app/views/re_pipelines/index.js.erb +0 -18
- data/rails_generators/templates/app/views/re_pipelines/new.html.erb +0 -9
- data/rails_generators/templates/app/views/re_pipelines/new.js.erb +0 -5
- data/rails_generators/templates/app/views/re_pipelines/show.html.erb +0 -39
- data/rails_generators/templates/app/views/re_pipelines/update.js.erb +0 -14
- data/rails_generators/templates/app/views/re_rule_definitions/complex_rule/_edit.html.erb +0 -7
- data/rails_generators/templates/app/views/re_rule_definitions/complex_rule/_new.html.erb +0 -7
- data/rails_generators/templates/app/views/re_rule_definitions/complex_rule/_script.html.erb +0 -26
- data/rails_generators/templates/app/views/re_rule_definitions/simple_rule/_edit.html.erb +0 -1
- data/rails_generators/templates/app/views/re_rule_definitions/simple_rule/_new.html.erb +0 -1
- data/rails_generators/templates/db/migrate/20100308225008_create_re_pipelines.rb +0 -77
- data/rails_generators/templates/features/support/blueprint_re_pipelines.rb +0 -20
- data/rails_generators/templates/public/javascripts/re_job_index.js +0 -75
- data/rails_generators/templates/public/javascripts/re_pipeline_change.js +0 -194
- data/rails_generators/templates/public/javascripts/re_pipeline_index.js +0 -40
- data/rails_generators/templates/public/javascripts/re_pipeline_index_jobs.js +0 -10
- data/rails_generators/templates/public/javascripts/re_pipeline_new.js +0 -30
- data/rails_generators/templates/public/javascripts/re_pipeline_show_jobs.js +0 -11
- data/rails_generators/templates/public/stylesheets/re_view.css +0 -120
- data/rails_generators/templates/public/stylesheets/re_view_box.css +0 -119
- data/rails_generators/templates/public/stylesheets/re_view_box/accept.png +0 -0
- data/rails_generators/templates/public/stylesheets/re_view_box/exclamation.png +0 -0
- data/rails_generators/templates/public/stylesheets/re_view_box/shadowbox.jpg +0 -0
- data/rails_generators/templates/public/stylesheets/re_view_button.css +0 -118
- data/rails_generators/templates/public/stylesheets/re_view_error.css +0 -61
- data/rails_generators/templates/public/stylesheets/re_view_form.css +0 -121
- data/rails_generators/templates/public/stylesheets/re_view_navigate.css +0 -46
- data/rails_generators/templates/public/stylesheets/re_view_table.css +0 -137
- data/rails_generators/templates/public/stylesheets/rules_engine.css +0 -520
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/error-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/info-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/list-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/list-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/list-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/list-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/next-disabled-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/next-disabled-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/next-disabled-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/next-enabled-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/next-enabled-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/next-enabled-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/prev-disabled-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/prev-disabled-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/prev-disabled-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/prev-enabled-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/prev-enabled-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/prev-enabled-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_job/success-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/activate-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/activate-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/activate-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/activate-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/alert-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/alert-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/change-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/change-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/change-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/changed-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/changed-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/changed-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/changed-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/current-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/deactivate-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/deactivate-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/deactivate-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/deactivate-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/destroy-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/destroy-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/destroy-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/draft-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/draft-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/draft-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/edit-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/edit-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/edit-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/edit-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/list-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/list-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/list-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/list-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/list-down.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/list-right.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/new-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/new-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/new-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/new-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/revert-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/revert-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/revert-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/show-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/show-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/show-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/show-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/verify-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/verify-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/verify-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_pipeline/verify-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/destroy-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/destroy-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/destroy-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/destroy-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/edit-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/edit-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/edit-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/edit-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-down-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-down-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-down-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-down-off-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-down-off-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-down-off-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-up-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-up-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-up-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-up-off-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-up-off-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/move-up-off-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/next-change-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/next-change-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/next-change-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/next-show-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/next-show-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/next-show-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/start-pipeline-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/stop-failure-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/stop-failure-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/stop-success-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/stop-success-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/valid-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/valid-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/valid-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/valid-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/verify-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/verify-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/verify-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule/verify-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/add-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/add-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/add-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/help-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/help-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/help-48.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/list-down.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/list-right.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/new-14.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/new-18.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/new-25.png +0 -0
- data/rails_generators/templates/public/stylesheets/rules_engine/re_rule_class/new-48.png +0 -0
- data/rails_generators/templates/spec/controllers/re_jobs_controller_spec.rb +0 -50
- data/rails_generators/templates/spec/controllers/re_pipeline_jobs_controller_spec.rb +0 -37
- data/rails_generators/templates/spec/controllers/re_pipeline_rules_controller_spec.rb +0 -390
- data/rails_generators/templates/spec/controllers/re_pipelines_controller_spec.rb +0 -497
- data/rails_generators/templates/spec/helpers/re_pipeline_helper_spec.rb +0 -29
- data/rails_generators/templates/spec/lib/rules/complex_rule_spec.rb +0 -336
- data/rails_generators/templates/spec/lib/rules/simple_rule_spec.rb +0 -171
- data/rails_generators/templates/spec/models/re_job_audit_spec.rb +0 -23
- data/rails_generators/templates/spec/models/re_job_spec.rb +0 -163
- data/rails_generators/templates/spec/models/re_pipeline_activated_observer_spec.rb +0 -28
- data/rails_generators/templates/spec/models/re_pipeline_activated_spec.rb +0 -71
- data/rails_generators/templates/spec/models/re_pipeline_base_spec.rb +0 -164
- data/rails_generators/templates/spec/models/re_pipeline_spec.rb +0 -198
- data/spec/rules_engine/job_spec.rb +0 -323
@@ -2,12 +2,40 @@ require File.expand_path(File.dirname(__FILE__) + '/../spec_helper')
|
|
2
2
|
|
3
3
|
describe "RulesEngine::Discovery" do
|
4
4
|
before(:each) do
|
5
|
-
Dir.stub!(:glob).and_return(["#{RAILS_ROOT}/app/rules/mock_rule"])
|
5
|
+
Dir.stub!(:glob).and_return(["#{RAILS_ROOT}/app/rules/mock_rule.rb"])
|
6
|
+
end
|
7
|
+
|
8
|
+
describe "setting the rules path" do
|
9
|
+
it "use the path to find rules" do
|
10
|
+
RulesEngine::Discovery.rules_path = 'dummy'
|
11
|
+
Dir.should_receive(:glob).with(/^dummy\/\*\*\/\*.rb$/).and_return([])
|
12
|
+
RulesEngine::Discovery.discover!
|
13
|
+
end
|
14
|
+
|
15
|
+
it "should return the rules path when set" do
|
16
|
+
RulesEngine::Discovery.rules_path = 'dummy'
|
17
|
+
RulesEngine::Discovery.rules_path.should =='dummy'
|
18
|
+
end
|
19
|
+
|
20
|
+
it "should return the \#{RAILS_ROOT}/app/rules" do
|
21
|
+
RulesEngine::Discovery.rules_path = nil
|
22
|
+
RulesEngine::Discovery.rules_path.should == "#{RAILS_ROOT}/app/rules"
|
23
|
+
end
|
24
|
+
|
25
|
+
it "should throw an exception if not using rails" do
|
26
|
+
Rails.stub!(:root).and_return(nil)
|
27
|
+
lambda {
|
28
|
+
RulesEngine::Discovery.rules_path
|
29
|
+
}.should raise_error
|
30
|
+
end
|
31
|
+
|
6
32
|
end
|
7
33
|
|
8
|
-
|
9
|
-
|
10
|
-
|
34
|
+
describe "rules path not defined" do
|
35
|
+
it "should find all of the rules ruby files in the \#{RAILS_ROOT}/app/rules directory " do
|
36
|
+
Dir.should_receive(:glob).with(/^#{RAILS_ROOT}\/app\/rules\/\*\*\/\*.rb$/).and_return([])
|
37
|
+
RulesEngine::Discovery.discover!
|
38
|
+
end
|
11
39
|
end
|
12
40
|
|
13
41
|
it "should use the rules filename to define the rule class name" do
|
@@ -15,6 +43,14 @@ describe "RulesEngine::Discovery" do
|
|
15
43
|
RulesEngine::Discovery.rule_classes.should include(MockRule)
|
16
44
|
end
|
17
45
|
|
46
|
+
it "should undefine an existing the rule class" do
|
47
|
+
RulesEngine::Discovery.discover!
|
48
|
+
RulesEngine::Discovery.rule_class('MockRule').options.should == {:group=>"mock group"}
|
49
|
+
RulesEngine::Discovery.rule_class('MockRule').options[:name] = "test"
|
50
|
+
RulesEngine::Discovery.discover!
|
51
|
+
RulesEngine::Discovery.rule_class('MockRule').options.should == {:group=>"mock group"}
|
52
|
+
end
|
53
|
+
|
18
54
|
it "should add the rule to the rule group" do
|
19
55
|
RulesEngine::Discovery.discover!
|
20
56
|
RulesEngine::Discovery.rule_groups['mock group'].should include(MockRule)
|
@@ -0,0 +1,115 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__) + '/../../../spec_helper')
|
2
|
+
|
3
|
+
describe "RulesEngine::Process::ReProcessAudit" do
|
4
|
+
before(:each) do
|
5
|
+
RulesEngine::Process.auditor = :db_auditor
|
6
|
+
|
7
|
+
@now = Time.now
|
8
|
+
@re_process_audit_1 = RulesEngine::Process::ReProcessAudit.create(:process_id => 1001,
|
9
|
+
:created_at => @now,
|
10
|
+
:code => RulesEngine::Process::AUDIT_INFO,
|
11
|
+
:message => "message 1")
|
12
|
+
|
13
|
+
@re_process_audit_2 = RulesEngine::Process::ReProcessAudit.create(:process_id => 1001,
|
14
|
+
:created_at => @now + 1.minute,
|
15
|
+
:code => RulesEngine::Process::AUDIT_INFO,
|
16
|
+
:message => "message 2")
|
17
|
+
|
18
|
+
@re_process_audit_3 = RulesEngine::Process::ReProcessAudit.create(:process_id => 1001,
|
19
|
+
:created_at => @now + 2.minute,
|
20
|
+
:code => RulesEngine::Process::AUDIT_INFO,
|
21
|
+
:message => "message 3")
|
22
|
+
|
23
|
+
@re_process_audit_4 = RulesEngine::Process::ReProcessAudit.create(:process_id => 1002,
|
24
|
+
:created_at => @now,
|
25
|
+
:code => RulesEngine::Process::AUDIT_INFO,
|
26
|
+
:message => "message 4")
|
27
|
+
|
28
|
+
end
|
29
|
+
|
30
|
+
describe "history" do
|
31
|
+
describe "no plan code set" do
|
32
|
+
it "should get all the active proceses in start date order" do
|
33
|
+
RulesEngine::Process::ReProcessAudit.history(1001).should == [@re_process_audit_1, @re_process_audit_2, @re_process_audit_3]
|
34
|
+
end
|
35
|
+
|
36
|
+
# it "should use pagination" do
|
37
|
+
# RulesEngine::Process::ReProcessAudit.should_receive(:paginate).with(hash_including(:page => 1, :per_page => 10))
|
38
|
+
# RulesEngine::Process::ReProcessAudit.history(1001)
|
39
|
+
# end
|
40
|
+
#
|
41
|
+
# it "should use set pagination" do
|
42
|
+
# RulesEngine::Process::ReProcessAudit.should_receive(:paginate).with(hash_including(:page => 2, :per_page => 999))
|
43
|
+
# RulesEngine::Process::ReProcessAudit.history(1001, {:page => 2, :per_page => 999})
|
44
|
+
# end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
describe "RulesEngine::Process::DbAuditor" do
|
50
|
+
before(:each) do
|
51
|
+
RulesEngine::Process.auditor = :db_auditor
|
52
|
+
|
53
|
+
@now = Time.now
|
54
|
+
Time.stub!(:now).and_return(@now)
|
55
|
+
|
56
|
+
@re_process_audit = mock_model(RulesEngine::Process::ReProcessAudit)
|
57
|
+
@re_process_audit.stub!(:process_id).and_return(1001)
|
58
|
+
@re_process_audit.stub!(:created_at).and_return(@now)
|
59
|
+
@re_process_audit.stub!(:code).and_return(RulesEngine::Process::AUDIT_INFO)
|
60
|
+
@re_process_audit.stub!(:message).and_return('mock message')
|
61
|
+
|
62
|
+
page_data = [@re_process_audit, @re_process_audit]
|
63
|
+
# page_data.stub!(:next_page => "103")
|
64
|
+
# page_data.stub!(:previous_page => "101")
|
65
|
+
|
66
|
+
RulesEngine::Process::ReProcessAudit.stub!(:create).and_return(@re_process_audit)
|
67
|
+
RulesEngine::Process::ReProcessAudit.stub!(:history).and_return(page_data)
|
68
|
+
end
|
69
|
+
|
70
|
+
describe "setting the auditor" do
|
71
|
+
it "should set the auditor to the database process auditor" do
|
72
|
+
RulesEngine::Process.auditor.should be_instance_of(RulesEngine::Process::DbAuditor)
|
73
|
+
end
|
74
|
+
end
|
75
|
+
|
76
|
+
describe "auditting a message" do
|
77
|
+
it "should create a new audit message" do
|
78
|
+
RulesEngine::Process::ReProcessAudit.should_receive(:create).with(hash_including(:process_id => 2002,
|
79
|
+
:created_at => @now.utc,
|
80
|
+
:message => "audit message",
|
81
|
+
:code => RulesEngine::Process::AUDIT_FAILURE))
|
82
|
+
RulesEngine::Process.auditor.audit(2002, "audit message", RulesEngine::Process::AUDIT_FAILURE)
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
describe "getting the process audit history" do
|
87
|
+
it "should returns a hash of the process data " do
|
88
|
+
data = RulesEngine::Process.auditor.history(1001)
|
89
|
+
data.should be_instance_of(Hash)
|
90
|
+
end
|
91
|
+
|
92
|
+
it "should include an array of audits" do
|
93
|
+
data = RulesEngine::Process.auditor.history(1001)
|
94
|
+
audits = data["audits"]
|
95
|
+
audits.should be_instance_of(Array)
|
96
|
+
end
|
97
|
+
|
98
|
+
it "should include the audit information" do
|
99
|
+
data = RulesEngine::Process.auditor.history(1001)
|
100
|
+
audits = data["audits"]
|
101
|
+
|
102
|
+
audits.length.should == 2
|
103
|
+
audits[0]["process_id"].should == 1001
|
104
|
+
audits[0]["created_at"].should == @now.utc.to_s
|
105
|
+
audits[0]["code"].should == RulesEngine::Process::AUDIT_INFO
|
106
|
+
audits[0]["message"].should == "mock message"
|
107
|
+
|
108
|
+
audits[1]["process_id"].should == 1001
|
109
|
+
audits[1]["created_at"].should == @now.utc.to_s
|
110
|
+
audits[1]["code"].should == RulesEngine::Process::AUDIT_INFO
|
111
|
+
audits[1]["message"].should == "mock message"
|
112
|
+
end
|
113
|
+
end
|
114
|
+
|
115
|
+
end
|
@@ -0,0 +1,111 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__) + '/../../spec_helper')
|
2
|
+
|
3
|
+
describe "RulesEngine::Process::Runner" do
|
4
|
+
|
5
|
+
describe "setting the auditor" do
|
6
|
+
it "should set the auditor as a instance of a class" do
|
7
|
+
mock_auditor = mock('mock_auditor')
|
8
|
+
RulesEngine::Process.auditor = mock_auditor
|
9
|
+
RulesEngine::Process.auditor.should == mock_auditor
|
10
|
+
end
|
11
|
+
|
12
|
+
it "should set the auditor to the database plan auditor" do
|
13
|
+
RulesEngine::Process.auditor = :db_auditor
|
14
|
+
RulesEngine::Process.auditor.should be_instance_of(RulesEngine::Process::DbAuditor)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
describe "getting the auditor" do
|
19
|
+
it "should get the default auditor when not set" do
|
20
|
+
RulesEngine::Process.auditor = nil
|
21
|
+
RulesEngine::Process.auditor.should be_instance_of(RulesEngine::Process::Auditor)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
describe "auditing a message" do
|
26
|
+
before(:each) do
|
27
|
+
@auditor = RulesEngine::Process::Auditor.new
|
28
|
+
end
|
29
|
+
|
30
|
+
describe "rails logger defined" do
|
31
|
+
before(:each) do
|
32
|
+
# Rails = mock("Rails")
|
33
|
+
@mock_logger = mock('Logger')
|
34
|
+
@mock_logger.stub!(:error)
|
35
|
+
@mock_logger.stub!(:info)
|
36
|
+
Rails.stub(:logger).and_return(@mock_logger)
|
37
|
+
end
|
38
|
+
|
39
|
+
it "should not audit if perform_audit? false" do
|
40
|
+
@mock_logger.should_not_receive(:error)
|
41
|
+
@auditor.stub!(:perform_audit?).and_return(false)
|
42
|
+
@auditor.audit(1001, "failure", RulesEngine::Process::AUDIT_FAILURE)
|
43
|
+
end
|
44
|
+
|
45
|
+
it "should wite to the error log for error audit messaged" do
|
46
|
+
@mock_logger.should_receive(:error)
|
47
|
+
@auditor.audit(1001, "failure", RulesEngine::Process::AUDIT_FAILURE)
|
48
|
+
end
|
49
|
+
|
50
|
+
it "should wite to the info log for success audit messaged" do
|
51
|
+
@mock_logger.should_receive(:info)
|
52
|
+
@auditor.audit(1001, "failure", RulesEngine::Process::AUDIT_SUCCESS)
|
53
|
+
end
|
54
|
+
|
55
|
+
it "should wite to the info log for info audit messaged" do
|
56
|
+
@mock_logger.should_receive(:info)
|
57
|
+
@auditor.audit(1001, "failure", RulesEngine::Process::AUDIT_INFO)
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
describe "rails logger not defined" do
|
62
|
+
before(:each) do
|
63
|
+
Rails.stub(:logger).and_return(nil)
|
64
|
+
end
|
65
|
+
|
66
|
+
it "should wite to the $stderr" do
|
67
|
+
$stderr.should_receive(:puts)
|
68
|
+
@auditor.audit(1001, "failure")
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
end
|
73
|
+
|
74
|
+
describe "getting the audit history" do
|
75
|
+
it "should return a hash " do
|
76
|
+
auditor = RulesEngine::Process::Auditor.new
|
77
|
+
auditor.history(1001, {}).should be_instance_of(Hash)
|
78
|
+
end
|
79
|
+
|
80
|
+
it "should return an array of audits" do
|
81
|
+
auditor = RulesEngine::Process::Auditor.new
|
82
|
+
auditor.history(1001, {})["audits"].should be_instance_of(Array)
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
describe "perform_audit" do
|
87
|
+
before(:each) do
|
88
|
+
@auditor = RulesEngine::Process::Auditor.new
|
89
|
+
end
|
90
|
+
|
91
|
+
it "should be true if audit_level is not set " do
|
92
|
+
@auditor.audit_level = nil
|
93
|
+
@auditor.perform_audit?(RulesEngine::Process::AUDIT_INFO).should == true
|
94
|
+
end
|
95
|
+
|
96
|
+
it "should be false if audit_level is AUDIT_NONE " do
|
97
|
+
@auditor.audit_level = RulesEngine::Process::AUDIT_NONE
|
98
|
+
@auditor.perform_audit?(RulesEngine::Process::AUDIT_INFO).should == false
|
99
|
+
end
|
100
|
+
|
101
|
+
it "should be true if audit_level is AUDIT_INFO " do
|
102
|
+
@auditor.audit_level = RulesEngine::Process::AUDIT_INFO
|
103
|
+
@auditor.perform_audit?(RulesEngine::Process::AUDIT_INFO).should == true
|
104
|
+
end
|
105
|
+
|
106
|
+
it "should be false if audit_level is AUDIT_SUCCESS " do
|
107
|
+
@auditor.audit_level = RulesEngine::Process::AUDIT_SUCCESS
|
108
|
+
@auditor.perform_audit?(RulesEngine::Process::AUDIT_INFO).should == false
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end
|
@@ -0,0 +1,229 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__) + '/../../../spec_helper')
|
2
|
+
|
3
|
+
describe "RulesEngine::Process::ReProcessRun" do
|
4
|
+
before(:each) do
|
5
|
+
RulesEngine::Process.runner = :db_runner
|
6
|
+
RulesEngine::Process.auditor = nil
|
7
|
+
|
8
|
+
@now = Time.now
|
9
|
+
@re_process_run_1 = RulesEngine::Process::ReProcessRun.create(:plan_code => 'mock_code',
|
10
|
+
:process_status => RulesEngine::Process::PROCESS_STATUS_NONE,
|
11
|
+
:started_at => nil,
|
12
|
+
:finished_at => nil)
|
13
|
+
|
14
|
+
@re_process_run_2 = RulesEngine::Process::ReProcessRun.create(:plan_code => 'mock_code',
|
15
|
+
:process_status => RulesEngine::Process::PROCESS_STATUS_RUNNING,
|
16
|
+
:started_at => @now,
|
17
|
+
:finished_at => nil)
|
18
|
+
|
19
|
+
@re_process_run_3 = RulesEngine::Process::ReProcessRun.create(:plan_code => 'mock_code',
|
20
|
+
:process_status => RulesEngine::Process::PROCESS_STATUS_SUCCESS,
|
21
|
+
:started_at => @now - 1.minute,
|
22
|
+
:finished_at => @now + 1.minute)
|
23
|
+
|
24
|
+
@re_process_run_4 = RulesEngine::Process::ReProcessRun.create(:plan_code => 'mock_code',
|
25
|
+
:process_status => RulesEngine::Process::PROCESS_STATUS_FAILURE,
|
26
|
+
:started_at => @now - 2.minute,
|
27
|
+
:finished_at => @now + 2.minute)
|
28
|
+
|
29
|
+
@re_process_run_5 = RulesEngine::Process::ReProcessRun.create(:plan_code => 'invalid_dates',
|
30
|
+
:process_status => RulesEngine::Process::PROCESS_STATUS_RUNNING,
|
31
|
+
:started_at => @now - 3.minute,
|
32
|
+
:finished_at => nil)
|
33
|
+
|
34
|
+
end
|
35
|
+
|
36
|
+
describe "history" do
|
37
|
+
describe "no plan code set" do
|
38
|
+
it "should get all the active proceses in start date order" do
|
39
|
+
RulesEngine::Process::ReProcessRun.history(nil).should == [@re_process_run_2, @re_process_run_3, @re_process_run_4, @re_process_run_5]
|
40
|
+
end
|
41
|
+
|
42
|
+
it "should use pagination" do
|
43
|
+
RulesEngine::Process::ReProcessRun.should_receive(:paginate).with(hash_including(:page => 1, :per_page => 10))
|
44
|
+
RulesEngine::Process::ReProcessRun.history(nil)
|
45
|
+
end
|
46
|
+
|
47
|
+
it "should use set pagination" do
|
48
|
+
RulesEngine::Process::ReProcessRun.should_receive(:paginate).with(hash_including(:page => 2, :per_page => 999))
|
49
|
+
RulesEngine::Process::ReProcessRun.history(nil, {:page => 2, :per_page => 999})
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
describe "RulesEngine::Process::DbRunner" do
|
56
|
+
before(:each) do
|
57
|
+
RulesEngine::Process.runner = :db_runner
|
58
|
+
RulesEngine::Process.auditor = nil
|
59
|
+
|
60
|
+
@now = Time.now
|
61
|
+
@re_process_run = mock_model(RulesEngine::Process::ReProcessRun)
|
62
|
+
@re_process_run.stub!(:plan_code).and_return('mock code')
|
63
|
+
@re_process_run.stub!(:plan_version).and_return(1002)
|
64
|
+
@re_process_run.stub!(:process_status).and_return(RulesEngine::Process::PROCESS_STATUS_FAILURE)
|
65
|
+
@re_process_run.stub!(:started_at).and_return(@now)
|
66
|
+
@re_process_run.stub!(:finished_at).and_return(@now + 1.minute)
|
67
|
+
@re_process_run.stub!(:update_attributes)
|
68
|
+
|
69
|
+
page_data = [@re_process_run, @re_process_run]
|
70
|
+
page_data.stub!(:next_page => "103")
|
71
|
+
page_data.stub!(:previous_page => "101")
|
72
|
+
|
73
|
+
RulesEngine::Process::ReProcessRun.stub!(:create).and_return(@re_process_run)
|
74
|
+
RulesEngine::Process::ReProcessRun.stub!(:history).and_return(page_data)
|
75
|
+
RulesEngine::Process::ReProcessRun.stub!(:find_by_id).and_return(@re_process_run)
|
76
|
+
|
77
|
+
end
|
78
|
+
|
79
|
+
describe "setting the runner" do
|
80
|
+
it "should set the runner to the database process runner" do
|
81
|
+
RulesEngine::Process.runner.should be_instance_of(RulesEngine::Process::DbRunner)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
describe "creating a new process" do
|
86
|
+
it "should create a new process with status NONE" do
|
87
|
+
RulesEngine::Process::ReProcessRun.should_receive(:create).with(hash_including(:process_status => RulesEngine::Process::PROCESS_STATUS_NONE))
|
88
|
+
RulesEngine::Process.runner.create
|
89
|
+
end
|
90
|
+
|
91
|
+
it "should return the new id of the created run" do
|
92
|
+
@re_process_run.stub!(:id).and_return(101999)
|
93
|
+
RulesEngine::Process.runner.create.should == 101999
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
describe "running a plan" do
|
98
|
+
before(:each) do
|
99
|
+
@plan = {"code" => 'mock_plan', "version" => 1009}
|
100
|
+
end
|
101
|
+
|
102
|
+
it "should get the created process" do
|
103
|
+
RulesEngine::Process::ReProcessRun.should_receive(:find_by_id).with(1009)
|
104
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
105
|
+
end
|
106
|
+
|
107
|
+
describe "process not found" do
|
108
|
+
before(:each) do
|
109
|
+
RulesEngine::Process::ReProcessRun.stub!(:find_by_id).with(1009).and_return(nil)
|
110
|
+
end
|
111
|
+
|
112
|
+
it "should return false" do
|
113
|
+
RulesEngine::Process.runner.run(1009, @plan, {}).should == false
|
114
|
+
end
|
115
|
+
|
116
|
+
it "should audit the error" do
|
117
|
+
RulesEngine::Process.auditor.should_receive(:audit).with(1009, "Process missing", RulesEngine::Process::AUDIT_FAILURE)
|
118
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
119
|
+
end
|
120
|
+
end
|
121
|
+
|
122
|
+
describe "updateing the plan" do
|
123
|
+
it "should update the plan code" do
|
124
|
+
@re_process_run.should_receive(:update_attributes).once.with(hash_including(:plan_code => 'mock_plan'))
|
125
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
126
|
+
end
|
127
|
+
|
128
|
+
it "should update the plan version" do
|
129
|
+
@re_process_run.should_receive(:update_attributes).once.with(hash_including(:plan_version => 1009))
|
130
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
131
|
+
end
|
132
|
+
|
133
|
+
it "should update the plan as running" do
|
134
|
+
@re_process_run.should_receive(:update_attributes).once.with(hash_including(:process_status => RulesEngine::Process::PROCESS_STATUS_RUNNING))
|
135
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
it "should run the plan" do
|
140
|
+
RulesEngine::Process.runner.should_receive(:_run_plan).with(1009, @plan, {:test => "data"})
|
141
|
+
RulesEngine::Process.runner.run(1009, @plan, {:test => "data"})
|
142
|
+
end
|
143
|
+
|
144
|
+
|
145
|
+
describe "running the plan was successfull" do
|
146
|
+
before(:each) do
|
147
|
+
RulesEngine::Process.runner.should_receive(:_run_plan).and_return(true)
|
148
|
+
end
|
149
|
+
|
150
|
+
it "should update the status as finished success" do
|
151
|
+
@re_process_run.should_receive(:update_attributes).once.with(hash_including(:process_status => RulesEngine::Process::PROCESS_STATUS_SUCCESS))
|
152
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
153
|
+
end
|
154
|
+
|
155
|
+
it "should return success" do
|
156
|
+
RulesEngine::Process.runner.run(1009, @plan, {}).should == true
|
157
|
+
end
|
158
|
+
end
|
159
|
+
|
160
|
+
describe "running the plan failed" do
|
161
|
+
before(:each) do
|
162
|
+
RulesEngine::Process.runner.should_receive(:_run_plan).and_return(false)
|
163
|
+
end
|
164
|
+
|
165
|
+
it "should update the status as failed" do
|
166
|
+
@re_process_run.should_receive(:update_attributes).once.with(hash_including(:process_status => RulesEngine::Process::PROCESS_STATUS_FAILURE))
|
167
|
+
RulesEngine::Process.runner.run(1009, @plan, {})
|
168
|
+
end
|
169
|
+
|
170
|
+
it "should return failure" do
|
171
|
+
RulesEngine::Process.runner.run(1009, @plan, {}).should == false
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
175
|
+
|
176
|
+
describe "getting the process status" do
|
177
|
+
it "should get the process" do
|
178
|
+
RulesEngine::Process::ReProcessRun.should_receive(:find_by_id).with(1009)
|
179
|
+
RulesEngine::Process.runner.status(1009)
|
180
|
+
end
|
181
|
+
|
182
|
+
describe "process not found" do
|
183
|
+
it "should return status NONE" do
|
184
|
+
RulesEngine::Process::ReProcessRun.stub!(:find_by_id).and_return(nil)
|
185
|
+
RulesEngine::Process.runner.status(1009).should == RulesEngine::Process::PROCESS_STATUS_NONE
|
186
|
+
end
|
187
|
+
end
|
188
|
+
|
189
|
+
describe "process found" do
|
190
|
+
it "should return process status" do
|
191
|
+
RulesEngine::Process::ReProcessRun.stub!(:find_by_id).and_return(@re_process_run)
|
192
|
+
@re_process_run.should_receive(:process_status).and_return(1002)
|
193
|
+
RulesEngine::Process.runner.status(1009).should == 1002
|
194
|
+
end
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
198
|
+
describe "getting the process run history" do
|
199
|
+
it "should returns a hash of the process data " do
|
200
|
+
data = RulesEngine::Process.runner.history('mock_code')
|
201
|
+
data.should be_instance_of(Hash)
|
202
|
+
end
|
203
|
+
|
204
|
+
it "should include an array of publications" do
|
205
|
+
data = RulesEngine::Process.runner.history('mock_code')
|
206
|
+
versions = data["processes"]
|
207
|
+
versions.should be_instance_of(Array)
|
208
|
+
end
|
209
|
+
|
210
|
+
it "should include the publication information" do
|
211
|
+
data = RulesEngine::Process.runner.history('mock_code')
|
212
|
+
processes = data["processes"]
|
213
|
+
|
214
|
+
processes.length.should == 2
|
215
|
+
processes[0]["plan_code"].should == 'mock code'
|
216
|
+
processes[0]["plan_version"].should == 1002
|
217
|
+
processes[0]["process_status"].should == RulesEngine::Process::PROCESS_STATUS_FAILURE
|
218
|
+
processes[0]["started_at"].should == @now.utc.to_s
|
219
|
+
processes[0]["finished_at"].should == (@now + 1.minute).utc.to_s
|
220
|
+
|
221
|
+
processes[1]["plan_code"].should == 'mock code'
|
222
|
+
processes[0]["plan_version"].should == 1002
|
223
|
+
processes[1]["process_status"].should == RulesEngine::Process::PROCESS_STATUS_FAILURE
|
224
|
+
processes[1]["started_at"].should == @now.utc.to_s
|
225
|
+
processes[1]["finished_at"].should == (@now + 1.minute).utc.to_s
|
226
|
+
end
|
227
|
+
end
|
228
|
+
|
229
|
+
end
|