jstorimer-deep-test 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +6 -0
- data/CHANGELOG +47 -0
- data/README.rdoc +199 -0
- data/Rakefile +150 -0
- data/TODO +4 -0
- data/VERSION +1 -0
- data/infrastructure/dynamic_teardown.rb +22 -0
- data/infrastructure/fake_deadlock_error.rb +12 -0
- data/infrastructure/load.rb +11 -0
- data/infrastructure/test_central_command.rb +15 -0
- data/infrastructure/test_exception.rb +7 -0
- data/infrastructure/test_factory.rb +74 -0
- data/infrastructure/test_logger.rb +11 -0
- data/infrastructure/test_operator.rb +15 -0
- data/infrastructure/test_result.rb +15 -0
- data/infrastructure/thread_agent.rb +21 -0
- data/infrastructure/timewarp/Rakefile +14 -0
- data/infrastructure/timewarp/lib/timewarp.rb +21 -0
- data/infrastructure/timewarp/test/timewarp_test.rb +45 -0
- data/lib/deep_test/agent.rb +108 -0
- data/lib/deep_test/central_command.rb +165 -0
- data/lib/deep_test/cpu_info.rb +22 -0
- data/lib/deep_test/database/mysql_setup_listener.rb +112 -0
- data/lib/deep_test/database/setup_listener.rb +116 -0
- data/lib/deep_test/deadlock_detector.rb +7 -0
- data/lib/deep_test/demon.rb +25 -0
- data/lib/deep_test/distributed/beachhead.rb +104 -0
- data/lib/deep_test/distributed/dispatch_controller.rb +60 -0
- data/lib/deep_test/distributed/establish_beachhead.rb +19 -0
- data/lib/deep_test/distributed/filename_resolver.rb +40 -0
- data/lib/deep_test/distributed/landing_fleet.rb +30 -0
- data/lib/deep_test/distributed/landing_ship.rb +60 -0
- data/lib/deep_test/distributed/remote_deployment.rb +56 -0
- data/lib/deep_test/distributed/rsync.rb +50 -0
- data/lib/deep_test/distributed/shell_environment.rb +50 -0
- data/lib/deep_test/distributed/ssh_client_connection_info.rb +14 -0
- data/lib/deep_test/extensions/object_extension.rb +40 -0
- data/lib/deep_test/failure_message.rb +19 -0
- data/lib/deep_test/lib_root.rb +4 -0
- data/lib/deep_test/listener_list.rb +17 -0
- data/lib/deep_test/local_deployment.rb +46 -0
- data/lib/deep_test/logger.rb +32 -0
- data/lib/deep_test/main.rb +41 -0
- data/lib/deep_test/marshallable_exception_wrapper.rb +44 -0
- data/lib/deep_test/metrics/data.rb +34 -0
- data/lib/deep_test/metrics/measurement.rb +39 -0
- data/lib/deep_test/null_listener.rb +62 -0
- data/lib/deep_test/options.rb +113 -0
- data/lib/deep_test/proxy_io.rb +77 -0
- data/lib/deep_test/rake_tasks.rb +13 -0
- data/lib/deep_test/result_reader.rb +40 -0
- data/lib/deep_test/rspec_detector.rb +21 -0
- data/lib/deep_test/spec/extensions/example_group_methods.rb +64 -0
- data/lib/deep_test/spec/extensions/example_methods.rb +52 -0
- data/lib/deep_test/spec/extensions/options.rb +43 -0
- data/lib/deep_test/spec/extensions/spec_task.rb +21 -0
- data/lib/deep_test/spec/runner.rb +72 -0
- data/lib/deep_test/spec/work_result.rb +35 -0
- data/lib/deep_test/spec/work_unit.rb +59 -0
- data/lib/deep_test/spec.rb +17 -0
- data/lib/deep_test/test/extensions/error.rb +14 -0
- data/lib/deep_test/test/run_test_suite.rb +5 -0
- data/lib/deep_test/test/runner.rb +24 -0
- data/lib/deep_test/test/supervised_test_suite.rb +48 -0
- data/lib/deep_test/test/work_result.rb +35 -0
- data/lib/deep_test/test/work_unit.rb +40 -0
- data/lib/deep_test/test.rb +10 -0
- data/lib/deep_test/test_task.rb +47 -0
- data/lib/deep_test/ui/console.rb +74 -0
- data/lib/deep_test/ui/null.rb +17 -0
- data/lib/deep_test/warlock.rb +146 -0
- data/lib/deep_test.rb +78 -0
- data/lib/telegraph/ack_sequence.rb +14 -0
- data/lib/telegraph/logging.rb +20 -0
- data/lib/telegraph/message.rb +39 -0
- data/lib/telegraph/operator.rb +47 -0
- data/lib/telegraph/switchboard.rb +57 -0
- data/lib/telegraph/wire.rb +73 -0
- data/lib/telegraph.rb +29 -0
- data/negative_acceptance_tests/dying_spec.rb +13 -0
- data/negative_acceptance_tests/dying_test.rb +13 -0
- data/negative_acceptance_tests/failing_spec.rb +9 -0
- data/negative_acceptance_tests/failing_test.rb +9 -0
- data/negative_acceptance_tests/kill_agent_one_on_start_work.rb +16 -0
- data/negative_acceptance_tests/passing_spec.rb +10 -0
- data/negative_acceptance_tests/passing_test.rb +12 -0
- data/negative_acceptance_tests/tasks.rake +87 -0
- data/negative_acceptance_tests/tests.rb +60 -0
- data/sample_rails_project/README +182 -0
- data/sample_rails_project/Rakefile +10 -0
- data/sample_rails_project/app/controllers/application.rb +7 -0
- data/sample_rails_project/app/controllers/people_controller.rb +2 -0
- data/sample_rails_project/app/helpers/application_helper.rb +3 -0
- data/sample_rails_project/app/helpers/people_helper.rb +7 -0
- data/sample_rails_project/app/models/person.rb +2 -0
- data/sample_rails_project/config/boot.rb +45 -0
- data/sample_rails_project/config/database.yml +29 -0
- data/sample_rails_project/config/environment.rb +60 -0
- data/sample_rails_project/config/environments/development.rb +21 -0
- data/sample_rails_project/config/environments/production.rb +18 -0
- data/sample_rails_project/config/environments/test.rb +19 -0
- data/sample_rails_project/config/routes.rb +23 -0
- data/sample_rails_project/db/.gitignore +2 -0
- data/sample_rails_project/db/migrate/001_create_people.rb +11 -0
- data/sample_rails_project/db/schema.rb +11 -0
- data/sample_rails_project/deep_test.rb +34 -0
- data/sample_rails_project/doc/README_FOR_APP +2 -0
- data/sample_rails_project/lib/foreign_host_agent_simulation_listener.rb +16 -0
- data/sample_rails_project/lib/tasks/create.sql +6 -0
- data/sample_rails_project/lib/tasks/db.rake +16 -0
- data/sample_rails_project/lib/tasks/deep_test.rake +27 -0
- data/sample_rails_project/log/.gitignore +2 -0
- data/sample_rails_project/public/.htaccess +40 -0
- data/sample_rails_project/public/404.html +30 -0
- data/sample_rails_project/public/500.html +30 -0
- data/sample_rails_project/public/dispatch.cgi +10 -0
- data/sample_rails_project/public/dispatch.fcgi +24 -0
- data/sample_rails_project/public/dispatch.rb +10 -0
- data/sample_rails_project/public/favicon.ico +0 -0
- data/sample_rails_project/public/images/rails.png +0 -0
- data/sample_rails_project/public/index.html +277 -0
- data/sample_rails_project/public/javascripts/application.js +2 -0
- data/sample_rails_project/public/javascripts/controls.js +833 -0
- data/sample_rails_project/public/javascripts/dragdrop.js +942 -0
- data/sample_rails_project/public/javascripts/effects.js +1088 -0
- data/sample_rails_project/public/javascripts/prototype.js +2515 -0
- data/sample_rails_project/public/robots.txt +1 -0
- data/sample_rails_project/script/about +3 -0
- data/sample_rails_project/script/breakpointer +3 -0
- data/sample_rails_project/script/console +3 -0
- data/sample_rails_project/script/destroy +3 -0
- data/sample_rails_project/script/generate +3 -0
- data/sample_rails_project/script/performance/benchmarker +3 -0
- data/sample_rails_project/script/performance/profiler +3 -0
- data/sample_rails_project/script/plugin +3 -0
- data/sample_rails_project/script/process/inspector +3 -0
- data/sample_rails_project/script/process/reaper +3 -0
- data/sample_rails_project/script/process/spawner +3 -0
- data/sample_rails_project/script/runner +3 -0
- data/sample_rails_project/script/server +3 -0
- data/sample_rails_project/script/spec +4 -0
- data/sample_rails_project/script/spec_server +102 -0
- data/sample_rails_project/spec/controllers/people_controller_spec.rb +10 -0
- data/sample_rails_project/spec/helpers/people_helper_spec.rb +10 -0
- data/sample_rails_project/spec/rcov.opts +2 -0
- data/sample_rails_project/spec/spec.opts +6 -0
- data/sample_rails_project/spec/spec_helper.rb +43 -0
- data/sample_rails_project/stories/all.rb +4 -0
- data/sample_rails_project/stories/helper.rb +3 -0
- data/sample_rails_project/test/test_helper.rb +30 -0
- data/sample_rails_project/test/unit/database_connection_test.rb +13 -0
- data/sample_rails_project/test/unit/person_test.rb +13 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/.gitignore +7 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/History.txt +40 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/Manifest.txt +151 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/README.txt +81 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/Rakefile +37 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/UPGRADE +7 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/CHANGES +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/rspec_generator.rb +40 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/all_stories.rb +4 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/previous_failures.txt +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/rcov.opts +2 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/rspec.rake +132 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/script/autospec +3 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/script/spec +4 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/script/spec_server +116 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/spec.opts +4 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/spec_helper.rb +47 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec/templates/stories_helper.rb +3 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_controller/USAGE +33 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_controller/rspec_controller_generator.rb +49 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_controller/templates/controller_spec.rb +25 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_controller/templates/helper_spec.rb +11 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_controller/templates/view_spec.rb +12 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_default_values.rb +19 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_model/USAGE +18 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_model/rspec_model_generator.rb +35 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_model/templates/model_spec.rb +15 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/rspec_scaffold_generator.rb +154 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/controller_spec.rb +173 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/edit_erb_spec.rb +26 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/helper_spec.rb +11 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/index_erb_spec.rb +27 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/new_erb_spec.rb +26 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/routing_spec.rb +59 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/generators/rspec_scaffold/templates/show_erb_spec.rb +23 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/init.rb +9 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/autotest/discover.rb +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/autotest/rails_rspec.rb +76 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/assigns_hash_proxy.rb +43 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/controller_example_group.rb +279 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/cookies_proxy.rb +25 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/functional_example_group.rb +84 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/helper_example_group.rb +164 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/model_example_group.rb +14 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/rails_example_group.rb +33 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/render_observer.rb +90 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example/view_example_group.rb +178 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/example.rb +47 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/action_controller/base.rb +14 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/action_controller/rescue.rb +21 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/action_controller/test_response.rb +11 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/action_view/base.rb +31 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/active_record/base.rb +30 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/object.rb +5 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/spec/example/configuration.rb +71 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions/spec/matchers/have.rb +21 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/extensions.rb +12 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/interop/testcase.rb +14 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/matchers/assert_select.rb +131 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/matchers/have_text.rb +57 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/matchers/include_text.rb +54 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/matchers/redirect_to.rb +113 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/matchers/render_template.rb +90 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/matchers.rb +30 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/mocks.rb +132 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/story_adapter.rb +79 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails/version.rb +15 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/lib/spec/rails.rb +15 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/autotest/mappings_spec.rb +36 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/assigns_hash_proxy_spec.rb +60 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/configuration_spec.rb +83 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/controller_isolation_spec.rb +62 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/controller_spec_spec.rb +260 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/cookies_proxy_spec.rb +74 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/example_group_factory_spec.rb +112 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/helper_spec_spec.rb +161 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/model_spec_spec.rb +18 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/shared_behaviour_spec.rb +16 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/test_unit_assertion_accessibility_spec.rb +33 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/example/view_spec_spec.rb +268 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/extensions/action_controller_rescue_action_spec.rb +54 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/extensions/action_view_base_spec.rb +48 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/extensions/active_record_spec.rb +14 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/interop/testcase_spec.rb +66 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/assert_select_spec.rb +806 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/description_generation_spec.rb +37 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/errors_on_spec.rb +13 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/have_text_spec.rb +62 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/include_text_spec.rb +64 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/redirect_to_spec.rb +209 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/matchers/render_template_spec.rb +176 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/mocks/ar_classes.rb +10 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/mocks/mock_model_spec.rb +90 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/mocks/stub_model_spec.rb +79 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/sample_modified_fixture.rb +8 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/sample_spec.rb +8 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/spec_server_spec.rb +96 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails/spec_spec.rb +11 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/rails_suite.rb +7 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec/spec_helper.rb +57 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/controllers/action_view_base_spec_controller.rb +2 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/controllers/controller_spec_controller.rb +95 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/controllers/redirect_spec_controller.rb +59 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/controllers/render_spec_controller.rb +30 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/controllers/rjs_spec_controller.rb +58 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/helpers/explicit_helper.rb +38 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/helpers/more_explicit_helper.rb +5 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/helpers/plugin_application_helper.rb +6 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/helpers/view_spec_helper.rb +13 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/controller_spec/_partial.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/controller_spec/action_setting_flash_after_session_reset.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/controller_spec/action_setting_flash_before_session_reset.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/controller_spec/action_setting_the_assigns_hash.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/controller_spec/action_with_errors_in_template.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/controller_spec/action_with_template.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/layouts/application.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/layouts/simple.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/objects/_object.html.erb +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/render_spec/_a_partial.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/render_spec/action_with_alternate_layout.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/render_spec/some_action.js.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/render_spec/some_action.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/render_spec/some_action.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/_replacement_partial.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/hide_div.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/hide_page_element.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/insert_html.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/replace.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/replace_html.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/replace_html_with_partial.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/visual_effect.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/rjs_spec/visual_toggle_effect.rjs +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/tag_spec/no_tags.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/tag_spec/single_div_with_no_attributes.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/tag_spec/single_div_with_one_attribute.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/_partial.rhtml +2 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/_partial_used_twice.rhtml +0 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/_partial_with_local_variable.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/_partial_with_sub_partial.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/_spacer.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/accessor.rhtml +5 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/block_helper.rhtml +3 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/entry_form.rhtml +2 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/explicit_helper.rhtml +2 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/foo/show.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/implicit_helper.rhtml +2 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/multiple_helpers.rhtml +3 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/template_with_partial.rhtml +5 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/template_with_partial_using_collection.rhtml +3 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/spec_resources/views/view_spec/template_with_partial_with_array.rhtml +1 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/stories/all.rb +10 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/stories/configuration/stories.rb +5 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/stories/helper.rb +6 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/stories/steps/people.rb +8 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/stories/transactions_should_rollback +15 -0
- data/sample_rails_project/vendor/plugins/rspec_on_rails/stories/transactions_should_rollback.rb +25 -0
- data/sample_rails_project/vendor/rails/actionmailer/CHANGELOG +297 -0
- data/sample_rails_project/vendor/rails/actionmailer/MIT-LICENSE +21 -0
- data/sample_rails_project/vendor/rails/actionmailer/README +145 -0
- data/sample_rails_project/vendor/rails/actionmailer/Rakefile +95 -0
- data/sample_rails_project/vendor/rails/actionmailer/install.rb +30 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/adv_attr_accessor.rb +30 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/base.rb +582 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/helpers.rb +111 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/mail_helper.rb +19 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/part.rb +113 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/part_container.rb +51 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/quoting.rb +59 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/utils.rb +8 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/text/format.rb +1466 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/address.rb +242 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/attachments.rb +39 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/base64.rb +71 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/config.rb +69 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/encode.rb +467 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/facade.rb +552 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/header.rb +914 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/info.rb +35 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/loader.rb +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/mail.rb +447 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/mailbox.rb +433 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/mbox.rb +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/net.rb +280 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/obsolete.rb +135 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/parser.rb +1522 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/port.rb +377 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/quoting.rb +131 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/scanner.rb +41 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/scanner_r.rb +263 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/stringio.rb +277 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/tmail.rb +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail/utils.rb +238 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail.rb +3 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer/version.rb +9 -0
- data/sample_rails_project/vendor/rails/actionmailer/lib/action_mailer.rb +50 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/abstract_unit.rb +30 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/first_mailer/share.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/helper_mailer/use_helper.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/helper_mailer/use_helper_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/helper_mailer/use_mail_helper.rhtml +5 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/helper_mailer/use_test_helper.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/helpers/test_helper.rb +5 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/path.with.dots/funky_path_mailer/multipart_with_template_path_with_dots.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/path.with.dots/multipart_with_template_path_with_dots.rhtml +0 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email +14 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email10 +20 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email11 +34 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email12 +32 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email13 +29 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email2 +114 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email3 +70 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email4 +59 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email5 +19 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email6 +20 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email7 +66 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email8 +47 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email9 +28 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email_quoted_with_0d0a +14 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/raw_email_with_partially_quoted_subject +14 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/second_mailer/share.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/templates/signed_up.rhtml +3 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/test_mailer/implicitly_multipart_example.ignored.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/test_mailer/implicitly_multipart_example.text.html.rhtml +10 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/test_mailer/implicitly_multipart_example.text.plain.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/test_mailer/implicitly_multipart_example.text.yaml.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/test_mailer/signed_up.rhtml +3 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/fixtures/test_mailer/signed_up_with_url.rhtml +3 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/mail_helper_test.rb +91 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/mail_render_test.rb +79 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/mail_service_test.rb +816 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/quoting_test.rb +57 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/tmail_test.rb +13 -0
- data/sample_rails_project/vendor/rails/actionmailer/test/url_test.rb +68 -0
- data/sample_rails_project/vendor/rails/actionpack/CHANGELOG +3138 -0
- data/sample_rails_project/vendor/rails/actionpack/MIT-LICENSE +21 -0
- data/sample_rails_project/vendor/rails/actionpack/README +469 -0
- data/sample_rails_project/vendor/rails/actionpack/RUNNING_UNIT_TESTS +25 -0
- data/sample_rails_project/vendor/rails/actionpack/Rakefile +154 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/.htaccess +24 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/address_book/index.rhtml +33 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/address_book/layout.rhtml +8 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/address_book_controller.cgi +9 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/address_book_controller.fcgi +6 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/address_book_controller.rb +52 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/address_book_controller.rbx +4 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/benchmark.rb +52 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/benchmark_with_ar.fcgi +89 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/blog_controller.cgi +53 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/debate/index.rhtml +14 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/debate/new_topic.rhtml +22 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/debate/topic.rhtml +32 -0
- data/sample_rails_project/vendor/rails/actionpack/examples/debate_controller.cgi +57 -0
- data/sample_rails_project/vendor/rails/actionpack/install.rb +30 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/deprecated_assertions.rb +228 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/dom_assertions.rb +25 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/model_assertions.rb +12 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/response_assertions.rb +140 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/routing_assertions.rb +98 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/selector_assertions.rb +571 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions/tag_assertions.rb +117 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/assertions.rb +82 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/base.rb +1231 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/benchmarking.rb +89 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/caching.rb +616 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cgi_ext/cgi_ext.rb +36 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cgi_ext/cgi_methods.rb +211 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cgi_ext/cookie_performance_fix.rb +125 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cgi_ext/raw_post_data_fix.rb +95 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cgi_ext/session_performance_fix.rb +30 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cgi_process.rb +231 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/components.rb +182 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/cookies.rb +78 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/deprecated_dependencies.rb +65 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/deprecated_redirects.rb +17 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/deprecated_request_methods.rb +34 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/filters.rb +667 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/flash.rb +182 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/helpers.rb +131 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/integration.rb +552 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/layout.rb +313 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/macros/auto_complete.rb +53 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/macros/in_place_editing.rb +33 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/mime_responds.rb +181 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/mime_type.rb +200 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/pagination.rb +402 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/request.rb +265 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/rescue.rb +142 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/resources.rb +405 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/response.rb +35 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/routing.rb +1340 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/scaffolding.rb +189 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/session/active_record_store.rb +335 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/session/drb_server.rb +32 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/session/drb_store.rb +35 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/session/mem_cache_store.rb +105 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/session_management.rb +142 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/status_codes.rb +88 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/streaming.rb +138 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/_request_and_response.rhtml +44 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/_trace.rhtml +26 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/diagnostics.rhtml +11 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/layout.rhtml +29 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/missing_template.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/routing_error.rhtml +10 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/template_error.rhtml +21 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/rescues/unknown_action.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/scaffolds/edit.rhtml +7 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/scaffolds/layout.rhtml +69 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/scaffolds/list.rhtml +27 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/scaffolds/new.rhtml +6 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/templates/scaffolds/show.rhtml +9 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/test_process.rb +504 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/url_rewriter.rb +108 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/vendor/html-scanner/html/document.rb +65 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/vendor/html-scanner/html/node.rb +530 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/vendor/html-scanner/html/selector.rb +823 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/vendor/html-scanner/html/tokenizer.rb +105 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/vendor/html-scanner/html/version.rb +11 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/vendor/xml_node.rb +97 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller/verification.rb +107 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_controller.rb +83 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_pack/version.rb +9 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_pack.rb +24 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/base.rb +538 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/compiled_templates.rb +70 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/active_record_helper.rb +237 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/asset_tag_helper.rb +218 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/benchmark_helper.rb +24 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/cache_helper.rb +10 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/capture_helper.rb +128 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/date_helper.rb +429 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/debug_helper.rb +17 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/deprecated_helper.rb +34 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/form_helper.rb +446 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/form_options_helper.rb +363 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/form_tag_helper.rb +176 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/java_script_macros_helper.rb +233 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/javascript_helper.rb +193 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/javascripts/controls.js +833 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/javascripts/dragdrop.js +942 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/javascripts/effects.js +1088 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/javascripts/prototype.js +2515 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/number_helper.rb +155 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/pagination_helper.rb +86 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/prototype_helper.rb +876 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/scriptaculous_helper.rb +140 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/tag_helper.rb +103 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/text_helper.rb +406 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/helpers/url_helper.rb +406 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/partials.rb +128 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view/template_error.rb +110 -0
- data/sample_rails_project/vendor/rails/actionpack/lib/action_view.rb +32 -0
- data/sample_rails_project/vendor/rails/actionpack/test/abstract_unit.rb +16 -0
- data/sample_rails_project/vendor/rails/actionpack/test/active_record_unit.rb +116 -0
- data/sample_rails_project/vendor/rails/actionpack/test/activerecord/active_record_assertions_test.rb +92 -0
- data/sample_rails_project/vendor/rails/actionpack/test/activerecord/active_record_store_test.rb +142 -0
- data/sample_rails_project/vendor/rails/actionpack/test/activerecord/pagination_test.rb +156 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/action_pack_assertions_test.rb +610 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/addresses_render_test.rb +45 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/assert_select_test.rb +576 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/base_test.rb +136 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/benchmark_test.rb +33 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/caching_test.rb +228 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/capture_test.rb +82 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/cgi_test.rb +440 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/components_test.rb +151 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/content_type_test.rb +139 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/controller_fixtures/app/controllers/admin/user_controller.rb +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/controller_fixtures/app/controllers/user_controller.rb +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/controller_fixtures/vendor/plugins/bad_plugin/lib/plugin_controller.rb +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/cookie_test.rb +88 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/custom_handler_test.rb +41 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/deprecated_instance_variables_test.rb +48 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/deprecation/deprecated_base_methods_test.rb +60 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/fake_controllers.rb +16 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/filter_params_test.rb +42 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/filters_test.rb +695 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/flash_test.rb +102 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/fragment_store_setting_test.rb +45 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/helper_test.rb +187 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/integration_test.rb +154 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/layout_test.rb +187 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/mime_responds_test.rb +351 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/mime_type_test.rb +33 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/new_render_test.rb +750 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/raw_post_test.rb +68 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/redirect_test.rb +156 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/render_test.rb +293 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/request_test.rb +317 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/resources_test.rb +482 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/routing_test.rb +1801 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/selector_test.rb +628 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/send_file_test.rb +117 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/session_management_test.rb +156 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/test_test.rb +495 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/url_rewriter_test.rb +115 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/verification_test.rb +227 -0
- data/sample_rails_project/vendor/rails/actionpack/test/controller/webservice_test.rb +248 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/addresses/list.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/companies.yml +24 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/company.rb +9 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/content_type/render_default_content_types_for_respond_to.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/content_type/render_default_for_rhtml.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/content_type/render_default_for_rjs.rjs +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/content_type/render_default_for_rxml.rxml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/db_definitions/sqlite.sql +42 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_cookies_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_cookies_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_flash_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_flash_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_headers_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_headers_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_params_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_params_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_request_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_request_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_response_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_response_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_session_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/deprecated_instance_variables/_session_method.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/developer.rb +7 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/developers.yml +21 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/developers_projects.yml +13 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/fun/games/hello_world.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/helpers/abc_helper.rb +5 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/helpers/fun/games_helper.rb +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/helpers/fun/pdf_helper.rb +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layout_tests/layouts/controller_name_space/nested.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layout_tests/layouts/item.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layout_tests/layouts/layout_test.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layout_tests/layouts/third_party_template_library.mab +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layout_tests/views/hello.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layouts/builder.rxml +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layouts/standard.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layouts/talk_from_action.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/layouts/yield.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/multipart/binary_file +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/multipart/large_text_file +10 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/multipart/mixed_files +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/multipart/mona_lisa.jpg +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/multipart/single_parameter +5 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/multipart/text_file +10 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/project.rb +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/projects.yml +7 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/public/images/rails.png +0 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/public/javascripts/application.js +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/replies.yml +13 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/reply.rb +5 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/all_types_with_layout.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/all_types_with_layout.rjs +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/layouts/standard.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/using_defaults.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/using_defaults.rjs +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/using_defaults.rxml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/using_defaults_with_type_list.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/using_defaults_with_type_list.rjs +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/respond_to/using_defaults_with_type_list.rxml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/scope/test/modgreet.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/_customer.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/_customer_greeting.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/_hash_object.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/_hello.rxml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/_partial_only.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/_person.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/action_talk_to_layout.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/block_content_for.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/capturing.rhtml +4 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/content_for.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/delete_with_js.rjs +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/dot.directory/render_file_with_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/enum_rjs_test.rjs +6 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/erb_content_for.rhtml +2 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/greeting.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/hello.rxml +4 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/hello_world.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/hello_world.rxml +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/hello_world_container.rxml +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/hello_world_with_layout_false.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/hello_xml_world.rxml +11 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/list.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/non_erb_block_content_for.rxml +4 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/potential_conflicts.rhtml +4 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/render_file_with_ivar.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/render_file_with_locals.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/render_to_string_test.rhtml +1 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/test/update_element_with_capture.rhtml +9 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/topic.rb +3 -0
- data/sample_rails_project/vendor/rails/actionpack/test/fixtures/topics.yml +22 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/active_record_helper_test.rb +204 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/asset_tag_helper_test.rb +232 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/benchmark_helper_test.rb +72 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/compiled_templates_test.rb +135 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/date_helper_test.rb +1322 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/deprecated_helper_test.rb +36 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/deprecated_instance_variables_test.rb +43 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/form_helper_test.rb +499 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/form_options_helper_test.rb +489 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/form_tag_helper_test.rb +172 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/java_script_macros_helper_test.rb +109 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/javascript_helper_test.rb +67 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/number_helper_test.rb +92 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/prototype_helper_test.rb +466 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/scriptaculous_helper_test.rb +90 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/tag_helper_test.rb +69 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/text_helper_test.rb +349 -0
- data/sample_rails_project/vendor/rails/actionpack/test/template/url_helper_test.rb +366 -0
- data/sample_rails_project/vendor/rails/actionpack/test/testing_sandbox.rb +11 -0
- data/sample_rails_project/vendor/rails/actionwebservice/CHANGELOG +279 -0
- data/sample_rails_project/vendor/rails/actionwebservice/MIT-LICENSE +21 -0
- data/sample_rails_project/vendor/rails/actionwebservice/README +364 -0
- data/sample_rails_project/vendor/rails/actionwebservice/Rakefile +171 -0
- data/sample_rails_project/vendor/rails/actionwebservice/TODO +32 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/README +143 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/autoloading/google_search_api.rb +50 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/autoloading/google_search_controller.rb +57 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/delegated/google_search_service.rb +108 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/delegated/search_controller.rb +7 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/direct/google_search_api.rb +50 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/googlesearch/direct/search_controller.rb +58 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/metaWeblog/README +17 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/metaWeblog/apis/blogger_api.rb +60 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/metaWeblog/apis/blogger_service.rb +34 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/metaWeblog/apis/meta_weblog_api.rb +67 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/metaWeblog/apis/meta_weblog_service.rb +48 -0
- data/sample_rails_project/vendor/rails/actionwebservice/examples/metaWeblog/controllers/xmlrpc_controller.rb +16 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/api.rb +249 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/base.rb +42 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/casting.rb +136 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/client/base.rb +28 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/client/soap_client.rb +113 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/client/xmlrpc_client.rb +58 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/client.rb +3 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/container/action_controller_container.rb +93 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/container/delegated_container.rb +86 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/container/direct_container.rb +69 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/container.rb +3 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/dispatcher/abstract.rb +203 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/dispatcher/action_controller_dispatcher.rb +376 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/dispatcher.rb +2 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/invocation.rb +202 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/protocol/abstract.rb +112 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/protocol/discovery.rb +37 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/protocol/soap_protocol/marshaler.rb +241 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/protocol/soap_protocol.rb +176 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/protocol/xmlrpc_protocol.rb +110 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/protocol.rb +4 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/scaffolding.rb +283 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/struct.rb +68 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/support/class_inheritable_options.rb +26 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/support/signature_types.rb +222 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/templates/scaffolds/layout.rhtml +65 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/templates/scaffolds/methods.rhtml +6 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/templates/scaffolds/parameters.rhtml +29 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/templates/scaffolds/result.rhtml +30 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/test_invoke.rb +110 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service/version.rb +9 -0
- data/sample_rails_project/vendor/rails/actionwebservice/lib/action_web_service.rb +66 -0
- data/sample_rails_project/vendor/rails/actionwebservice/setup.rb +1379 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/abstract_client.rb +183 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/abstract_dispatcher.rb +505 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/abstract_unit.rb +45 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/api_test.rb +102 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/apis/auto_load_api.rb +3 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/apis/broken_auto_load_api.rb +2 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/base_test.rb +42 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/casting_test.rb +86 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/client_soap_test.rb +152 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/client_xmlrpc_test.rb +151 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/container_test.rb +73 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/dispatcher_action_controller_soap_test.rb +137 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/dispatcher_action_controller_xmlrpc_test.rb +59 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/fixtures/db_definitions/mysql.sql +7 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/fixtures/users.yml +10 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/gencov +3 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/invocation_test.rb +185 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/run +6 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/scaffolded_controller_test.rb +146 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/struct_test.rb +52 -0
- data/sample_rails_project/vendor/rails/actionwebservice/test/test_invoke_test.rb +112 -0
- data/sample_rails_project/vendor/rails/activerecord/CHANGELOG +3043 -0
- data/sample_rails_project/vendor/rails/activerecord/README +360 -0
- data/sample_rails_project/vendor/rails/activerecord/RUNNING_UNIT_TESTS +64 -0
- data/sample_rails_project/vendor/rails/activerecord/Rakefile +226 -0
- data/sample_rails_project/vendor/rails/activerecord/examples/associations.png +0 -0
- data/sample_rails_project/vendor/rails/activerecord/examples/associations.rb +87 -0
- data/sample_rails_project/vendor/rails/activerecord/examples/shared_setup.rb +15 -0
- data/sample_rails_project/vendor/rails/activerecord/examples/validation.rb +85 -0
- data/sample_rails_project/vendor/rails/activerecord/install.rb +30 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/acts/list.rb +244 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/acts/nested_set.rb +211 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/acts/tree.rb +89 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/aggregations.rb +191 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/association_collection.rb +190 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/association_proxy.rb +158 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/belongs_to_association.rb +56 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/belongs_to_polymorphic_association.rb +50 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb +169 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/has_many_association.rb +210 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/has_many_through_association.rb +247 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations/has_one_association.rb +80 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/associations.rb +1627 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/attribute_methods.rb +75 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/base.rb +2164 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/calculations.rb +270 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/callbacks.rb +367 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/connection_specification.rb +279 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/database_statements.rb +130 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb +58 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/schema_definitions.rb +343 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb +303 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb +161 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/db2_adapter.rb +228 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/firebird_adapter.rb +728 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/frontbase_adapter.rb +861 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb +414 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/openbase_adapter.rb +350 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/oracle_adapter.rb +689 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb +584 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb +407 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/sqlserver_adapter.rb +591 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/connection_adapters/sybase_adapter.rb +662 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/deprecated_associations.rb +104 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/deprecated_finders.rb +44 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/fixtures.rb +628 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/locking/optimistic.rb +106 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/locking/pessimistic.rb +77 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/migration.rb +394 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/observer.rb +178 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/query_cache.rb +64 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/reflection.rb +222 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/schema.rb +58 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/schema_dumper.rb +149 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/timestamp.rb +51 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/transactions.rb +136 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/validations.rb +843 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/vendor/db2.rb +362 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/vendor/mysql.rb +1214 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/vendor/simple.rb +693 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/version.rb +9 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/wrappers/yaml_wrapper.rb +15 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/wrappings.rb +58 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record/xml_serialization.rb +308 -0
- data/sample_rails_project/vendor/rails/activerecord/lib/active_record.rb +85 -0
- data/sample_rails_project/vendor/rails/activerecord/test/aaa_create_tables_test.rb +59 -0
- data/sample_rails_project/vendor/rails/activerecord/test/abstract_unit.rb +77 -0
- data/sample_rails_project/vendor/rails/activerecord/test/active_schema_test_mysql.rb +31 -0
- data/sample_rails_project/vendor/rails/activerecord/test/adapter_test.rb +87 -0
- data/sample_rails_project/vendor/rails/activerecord/test/adapter_test_sqlserver.rb +81 -0
- data/sample_rails_project/vendor/rails/activerecord/test/aggregations_test.rb +95 -0
- data/sample_rails_project/vendor/rails/activerecord/test/all.sh +8 -0
- data/sample_rails_project/vendor/rails/activerecord/test/ar_schema_test.rb +33 -0
- data/sample_rails_project/vendor/rails/activerecord/test/association_inheritance_reload.rb +14 -0
- data/sample_rails_project/vendor/rails/activerecord/test/associations/callbacks_test.rb +126 -0
- data/sample_rails_project/vendor/rails/activerecord/test/associations/cascaded_eager_loading_test.rb +138 -0
- data/sample_rails_project/vendor/rails/activerecord/test/associations/eager_test.rb +393 -0
- data/sample_rails_project/vendor/rails/activerecord/test/associations/extension_test.rb +42 -0
- data/sample_rails_project/vendor/rails/activerecord/test/associations/join_model_test.rb +497 -0
- data/sample_rails_project/vendor/rails/activerecord/test/associations_test.rb +1809 -0
- data/sample_rails_project/vendor/rails/activerecord/test/attribute_methods_test.rb +49 -0
- data/sample_rails_project/vendor/rails/activerecord/test/base_test.rb +1586 -0
- data/sample_rails_project/vendor/rails/activerecord/test/binary_test.rb +37 -0
- data/sample_rails_project/vendor/rails/activerecord/test/calculations_test.rb +219 -0
- data/sample_rails_project/vendor/rails/activerecord/test/callbacks_test.rb +377 -0
- data/sample_rails_project/vendor/rails/activerecord/test/class_inheritable_attributes_test.rb +32 -0
- data/sample_rails_project/vendor/rails/activerecord/test/column_alias_test.rb +17 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connection_test_firebird.rb +8 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_db2/connection.rb +25 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_firebird/connection.rb +26 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_frontbase/connection.rb +27 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_mysql/connection.rb +24 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_openbase/connection.rb +21 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_oracle/connection.rb +27 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_postgresql/connection.rb +23 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_sqlite/connection.rb +34 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_sqlite3/connection.rb +34 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_sqlite3/in_memory_connection.rb +18 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_sqlserver/connection.rb +23 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_sqlserver_odbc/connection.rb +25 -0
- data/sample_rails_project/vendor/rails/activerecord/test/connections/native_sybase/connection.rb +23 -0
- data/sample_rails_project/vendor/rails/activerecord/test/copy_table_sqlite.rb +64 -0
- data/sample_rails_project/vendor/rails/activerecord/test/datatype_test_postgresql.rb +52 -0
- data/sample_rails_project/vendor/rails/activerecord/test/default_test_firebird.rb +16 -0
- data/sample_rails_project/vendor/rails/activerecord/test/defaults_test.rb +60 -0
- data/sample_rails_project/vendor/rails/activerecord/test/deprecated_associations_test.rb +396 -0
- data/sample_rails_project/vendor/rails/activerecord/test/deprecated_finder_test.rb +151 -0
- data/sample_rails_project/vendor/rails/activerecord/test/empty_date_time_test.rb +25 -0
- data/sample_rails_project/vendor/rails/activerecord/test/finder_test.rb +504 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/accounts.yml +28 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/author.rb +99 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/author_favorites.yml +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/authors.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/auto_id.rb +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/bad_fixtures/attr_with_numeric_first_char +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/bad_fixtures/attr_with_spaces +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/bad_fixtures/blank_line +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/bad_fixtures/duplicate_attributes +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/bad_fixtures/missing_value +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/binary.rb +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categories/special_categories.yml +9 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categories/subsubdir/arbitrary_filename.yml +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categories.yml +14 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categories_ordered.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categories_posts.yml +23 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categorization.rb +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/categorizations.yml +17 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/category.rb +20 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/column_name.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/comment.rb +23 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/comments.yml +59 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/companies.yml +55 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/company.rb +107 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/company_in_module.rb +59 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/computer.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/computers.yml +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/course.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/courses.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/customer.rb +55 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/customers.yml +17 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/db2.drop.sql +32 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/db2.sql +231 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/db22.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/db22.sql +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/firebird.drop.sql +63 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/firebird.sql +304 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/firebird2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/firebird2.sql +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/frontbase.drop.sql +32 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/frontbase.sql +268 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/frontbase2.drop.sql +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/frontbase2.sql +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/mysql.drop.sql +32 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/mysql.sql +234 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/mysql2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/mysql2.sql +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/openbase.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/openbase.sql +302 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/openbase2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/openbase2.sql +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/oracle.drop.sql +65 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/oracle.sql +325 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/oracle2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/oracle2.sql +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/postgresql.drop.sql +37 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/postgresql.sql +263 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/postgresql2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/postgresql2.sql +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/schema.rb +60 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlite.drop.sql +32 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlite.sql +215 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlite2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlite2.sql +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlserver.drop.sql +34 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlserver.sql +243 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlserver2.drop.sql +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sqlserver2.sql +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sybase.drop.sql +34 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sybase.sql +218 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sybase2.drop.sql +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/db_definitions/sybase2.sql +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/default.rb +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/developer.rb +52 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/developers.yml +21 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/developers_projects/david_action_controller +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/developers_projects/david_active_record +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/developers_projects/jamis_active_record +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/developers_projects.yml +17 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/edge.rb +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/edges.yml +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/entrant.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/entrants.yml +14 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/fk_test_has_fk.yml +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/fk_test_has_pk.yml +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/flowers.jpg +0 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/funny_jokes.yml +10 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/joke.rb +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/keyboard.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/legacy_thing.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/legacy_things.yml +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations/1_people_have_last_names.rb +9 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations/2_we_need_reminders.rb +12 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations/3_innocent_jointable.rb +12 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_decimal/1_give_me_big_numbers.rb +15 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_duplicate/1_people_have_last_names.rb +9 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_duplicate/2_we_need_reminders.rb +12 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_duplicate/3_foo.rb +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_duplicate/3_innocent_jointable.rb +12 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_missing_versions/1000_people_have_middle_names.rb +9 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_missing_versions/1_people_have_last_names.rb +9 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_missing_versions/3_we_need_reminders.rb +12 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/migrations_with_missing_versions/4_innocent_jointable.rb +12 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/mixed_case_monkey.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/mixed_case_monkeys.yml +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/mixin.rb +63 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/mixins.yml +127 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/movie.rb +5 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/movies.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/naked/csv/accounts.csv +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/naked/yml/accounts.yml +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/naked/yml/companies.yml +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/naked/yml/courses.yml +1 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/order.rb +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/people.yml +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/person.rb +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/post.rb +58 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/posts.yml +48 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/project.rb +27 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/projects.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/reader.rb +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/readers.yml +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/reply.rb +37 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/subject.rb +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/subscriber.rb +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/subscribers/first +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/subscribers/second +2 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/tag.rb +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/tagging.rb +6 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/taggings.yml +18 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/tags.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/task.rb +3 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/tasks.yml +7 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/topic.rb +25 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/topics.yml +22 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/vertex.rb +9 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures/vertices.yml +4 -0
- data/sample_rails_project/vendor/rails/activerecord/test/fixtures_test.rb +401 -0
- data/sample_rails_project/vendor/rails/activerecord/test/inheritance_test.rb +205 -0
- data/sample_rails_project/vendor/rails/activerecord/test/lifecycle_test.rb +137 -0
- data/sample_rails_project/vendor/rails/activerecord/test/locking_test.rb +190 -0
- data/sample_rails_project/vendor/rails/activerecord/test/method_scoping_test.rb +416 -0
- data/sample_rails_project/vendor/rails/activerecord/test/migration_test.rb +768 -0
- data/sample_rails_project/vendor/rails/activerecord/test/migration_test_firebird.rb +124 -0
- data/sample_rails_project/vendor/rails/activerecord/test/mixin_nested_set_test.rb +196 -0
- data/sample_rails_project/vendor/rails/activerecord/test/mixin_test.rb +550 -0
- data/sample_rails_project/vendor/rails/activerecord/test/modules_test.rb +34 -0
- data/sample_rails_project/vendor/rails/activerecord/test/multiple_db_test.rb +60 -0
- data/sample_rails_project/vendor/rails/activerecord/test/pk_test.rb +104 -0
- data/sample_rails_project/vendor/rails/activerecord/test/readonly_test.rb +107 -0
- data/sample_rails_project/vendor/rails/activerecord/test/reflection_test.rb +159 -0
- data/sample_rails_project/vendor/rails/activerecord/test/schema_authorization_test_postgresql.rb +75 -0
- data/sample_rails_project/vendor/rails/activerecord/test/schema_dumper_test.rb +96 -0
- data/sample_rails_project/vendor/rails/activerecord/test/schema_test_postgresql.rb +64 -0
- data/sample_rails_project/vendor/rails/activerecord/test/synonym_test_oracle.rb +17 -0
- data/sample_rails_project/vendor/rails/activerecord/test/table_name_test_sqlserver.rb +23 -0
- data/sample_rails_project/vendor/rails/activerecord/test/threaded_connections_test.rb +48 -0
- data/sample_rails_project/vendor/rails/activerecord/test/transactions_test.rb +230 -0
- data/sample_rails_project/vendor/rails/activerecord/test/unconnected_test.rb +32 -0
- data/sample_rails_project/vendor/rails/activerecord/test/validations_test.rb +1097 -0
- data/sample_rails_project/vendor/rails/activerecord/test/xml_serialization_test.rb +125 -0
- data/sample_rails_project/vendor/rails/activesupport/CHANGELOG +703 -0
- data/sample_rails_project/vendor/rails/activesupport/README +43 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/binding_of_caller.rb +84 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/breakpoint.rb +528 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/caching_tools.rb +62 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/clean_logger.rb +38 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/array/conversions.rb +72 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/array/grouping.rb +55 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/array.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/bigdecimal/formatting.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/bigdecimal.rb +3 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/blank.rb +50 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/cgi/escape_skipping_slashes.rb +14 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/cgi.rb +5 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb +48 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/class/inheritable_attributes.rb +140 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/class/removal.rb +24 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/class.rb +3 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/date/conversions.rb +39 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/date.rb +6 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/enumerable.rb +62 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/exception.rb +33 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/hash/conversions.rb +155 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/hash/diff.rb +11 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/hash/indifferent_access.rb +88 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/hash/keys.rb +53 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/hash/reverse_merge.rb +25 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/hash.rb +13 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/integer/even_odd.rb +24 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/integer/inflections.rb +21 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/integer.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/kernel/agnostics.rb +11 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/kernel/daemonizing.rb +15 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/kernel/reporting.rb +51 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/kernel/requires.rb +24 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/kernel.rb +4 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/load_error.rb +38 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/logger.rb +16 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/aliasing.rb +58 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/attr_internal.rb +31 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/attribute_accessors.rb +48 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/delegation.rb +41 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/inclusion.rb +11 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/introspection.rb +21 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module/loading.rb +13 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/module.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/name_error.rb +17 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/numeric/bytes.rb +44 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/numeric/time.rb +72 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/numeric.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/object/extending.rb +47 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/object/misc.rb +34 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/object.rb +2 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/pathname/clean_within.rb +14 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/pathname.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/proc.rb +12 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/range/conversions.rb +21 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/range.rb +5 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string/access.rb +58 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string/conversions.rb +19 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string/inflections.rb +153 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string/iterators.rb +17 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string/starts_ends_with.rb +20 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string/unicode.rb +42 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/string.rb +15 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/symbol.rb +12 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/time/calculations.rb +191 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/time/conversions.rb +33 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext/time.rb +17 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/core_ext.rb +1 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/dependencies.rb +539 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/deprecation.rb +202 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/inflections.rb +52 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/inflector.rb +275 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/json/encoders/core.rb +68 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/json/encoders.rb +25 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/json.rb +48 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/multibyte/chars.rb +129 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/multibyte/generators/generate_tables.rb +149 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/multibyte/handlers/passthru_handler.rb +9 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb +454 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/multibyte/handlers/utf8_handler_proc.rb +43 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/multibyte.rb +7 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/option_merger.rb +25 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/ordered_options.rb +44 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/reloadable.rb +60 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/values/time_zone.rb +180 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/values/unicode_tables.dat +0 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/builder/blankslate.rb +63 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/builder/xchar.rb +112 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/builder/xmlbase.rb +145 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/builder/xmlevents.rb +63 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/builder/xmlmarkup.rb +327 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/builder.rb +13 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/vendor/xml_simple.rb +1021 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/version.rb +9 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support/whiny_nil.rb +38 -0
- data/sample_rails_project/vendor/rails/activesupport/lib/active_support.rb +44 -0
- data/sample_rails_project/vendor/rails/railties/CHANGELOG +1366 -0
- data/sample_rails_project/vendor/rails/railties/MIT-LICENSE +20 -0
- data/sample_rails_project/vendor/rails/railties/README +182 -0
- data/sample_rails_project/vendor/rails/railties/Rakefile +334 -0
- data/sample_rails_project/vendor/rails/railties/bin/about +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/breakpointer +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/console +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/destroy +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/generate +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/performance/benchmarker +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/performance/profiler +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/plugin +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/process/inspector +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/process/reaper +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/process/spawner +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/rails +19 -0
- data/sample_rails_project/vendor/rails/railties/bin/runner +3 -0
- data/sample_rails_project/vendor/rails/railties/bin/server +3 -0
- data/sample_rails_project/vendor/rails/railties/builtin/rails_info/rails/info.rb +123 -0
- data/sample_rails_project/vendor/rails/railties/builtin/rails_info/rails/info_controller.rb +9 -0
- data/sample_rails_project/vendor/rails/railties/builtin/rails_info/rails/info_helper.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/builtin/rails_info/rails_info_controller.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/configs/apache.conf +40 -0
- data/sample_rails_project/vendor/rails/railties/configs/databases/frontbase.yml +28 -0
- data/sample_rails_project/vendor/rails/railties/configs/databases/mysql.yml +48 -0
- data/sample_rails_project/vendor/rails/railties/configs/databases/oracle.yml +39 -0
- data/sample_rails_project/vendor/rails/railties/configs/databases/postgresql.yml +44 -0
- data/sample_rails_project/vendor/rails/railties/configs/databases/sqlite2.yml +16 -0
- data/sample_rails_project/vendor/rails/railties/configs/databases/sqlite3.yml +19 -0
- data/sample_rails_project/vendor/rails/railties/configs/empty.log +0 -0
- data/sample_rails_project/vendor/rails/railties/configs/lighttpd.conf +54 -0
- data/sample_rails_project/vendor/rails/railties/configs/routes.rb +23 -0
- data/sample_rails_project/vendor/rails/railties/dispatches/dispatch.fcgi +24 -0
- data/sample_rails_project/vendor/rails/railties/dispatches/dispatch.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/dispatches/gateway.cgi +97 -0
- data/sample_rails_project/vendor/rails/railties/doc/README_FOR_APP +2 -0
- data/sample_rails_project/vendor/rails/railties/environments/boot.rb +45 -0
- data/sample_rails_project/vendor/rails/railties/environments/development.rb +21 -0
- data/sample_rails_project/vendor/rails/railties/environments/environment.rb +60 -0
- data/sample_rails_project/vendor/rails/railties/environments/production.rb +18 -0
- data/sample_rails_project/vendor/rails/railties/environments/test.rb +19 -0
- data/sample_rails_project/vendor/rails/railties/fresh_rakefile +10 -0
- data/sample_rails_project/vendor/rails/railties/helpers/application.rb +7 -0
- data/sample_rails_project/vendor/rails/railties/helpers/application_helper.rb +3 -0
- data/sample_rails_project/vendor/rails/railties/helpers/test_helper.rb +28 -0
- data/sample_rails_project/vendor/rails/railties/html/404.html +30 -0
- data/sample_rails_project/vendor/rails/railties/html/500.html +30 -0
- data/sample_rails_project/vendor/rails/railties/html/favicon.ico +0 -0
- data/sample_rails_project/vendor/rails/railties/html/images/rails.png +0 -0
- data/sample_rails_project/vendor/rails/railties/html/index.html +277 -0
- data/sample_rails_project/vendor/rails/railties/html/javascripts/application.js +2 -0
- data/sample_rails_project/vendor/rails/railties/html/javascripts/controls.js +833 -0
- data/sample_rails_project/vendor/rails/railties/html/javascripts/dragdrop.js +942 -0
- data/sample_rails_project/vendor/rails/railties/html/javascripts/effects.js +1088 -0
- data/sample_rails_project/vendor/rails/railties/html/javascripts/prototype.js +2515 -0
- data/sample_rails_project/vendor/rails/railties/html/robots.txt +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/binding_of_caller.rb +85 -0
- data/sample_rails_project/vendor/rails/railties/lib/breakpoint.rb +553 -0
- data/sample_rails_project/vendor/rails/railties/lib/breakpoint_client.rb +196 -0
- data/sample_rails_project/vendor/rails/railties/lib/code_statistics.rb +107 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/about.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/breakpointer.rb +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/console.rb +25 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/destroy.rb +6 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/generate.rb +6 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/ncgi/listener +86 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/ncgi/tracker +69 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/performance/benchmarker.rb +24 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/performance/profiler.rb +50 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/plugin.rb +918 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/process/inspector.rb +68 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/process/reaper.rb +149 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/process/spawner.rb +209 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/process/spinner.rb +57 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/runner.rb +48 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/server.rb +39 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/servers/base.rb +19 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/servers/lighttpd.rb +94 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/servers/mongrel.rb +65 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/servers/webrick.rb +59 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands/update.rb +4 -0
- data/sample_rails_project/vendor/rails/railties/lib/commands.rb +17 -0
- data/sample_rails_project/vendor/rails/railties/lib/console_app.rb +27 -0
- data/sample_rails_project/vendor/rails/railties/lib/console_sandbox.rb +6 -0
- data/sample_rails_project/vendor/rails/railties/lib/console_with_helpers.rb +23 -0
- data/sample_rails_project/vendor/rails/railties/lib/dispatcher.rb +173 -0
- data/sample_rails_project/vendor/rails/railties/lib/fcgi_handler.rb +225 -0
- data/sample_rails_project/vendor/rails/railties/lib/initializer.rb +702 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails/version.rb +9 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/base.rb +261 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/commands.rb +581 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generated_attribute.rb +42 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/applications/app/USAGE +16 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/applications/app/app_generator.rb +160 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/controller/USAGE +30 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/controller/controller_generator.rb +37 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/controller/templates/controller.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/controller/templates/functional_test.rb +18 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/controller/templates/helper.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/controller/templates/view.rhtml +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/integration_test/USAGE +14 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/integration_test/integration_test_generator.rb +16 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/integration_test/templates/integration_test.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/mailer/USAGE +18 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/mailer/mailer_generator.rb +34 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/mailer/templates/fixture.rhtml +3 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/mailer/templates/mailer.rb +13 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/mailer/templates/unit_test.rb +37 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/mailer/templates/view.rhtml +3 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/migration/USAGE +14 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/migration/migration_generator.rb +7 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/migration/templates/migration.rb +7 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/model/USAGE +26 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/model/model_generator.rb +38 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/model/templates/fixtures.yml +11 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/model/templates/migration.rb +13 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/model/templates/model.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/model/templates/unit_test.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/observer/USAGE +15 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/observer/observer_generator.rb +16 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/observer/templates/observer.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/observer/templates/unit_test.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/USAGE +35 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/plugin_generator.rb +38 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/README +4 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/Rakefile +22 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/USAGE +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/generator.rb +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/init.rb +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/install.rb +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/plugin.rb +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/tasks.rake +4 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/uninstall.rb +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/unit_test.rb +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/resource_generator.rb +76 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/USAGE +18 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/controller.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/fixtures.yml +11 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/functional_test.rb +20 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/helper.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/migration.rb +13 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/model.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/resource/templates/unit_test.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/USAGE +32 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/scaffold_generator.rb +193 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/controller.rb +58 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/form.rhtml +3 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/form_scaffolding.rhtml +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/functional_test.rb +102 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/helper.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/layout.rhtml +17 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/style.css +74 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/view_edit.rhtml +9 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/view_list.rhtml +27 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/view_new.rhtml +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/view_show.rhtml +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/USAGE +29 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/scaffold_resource_generator.rb +92 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/controller.rb +79 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/fixtures.yml +11 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/functional_test.rb +57 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/helper.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/layout.rhtml +17 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/migration.rb +13 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/model.rb +2 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/style.css +74 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/unit_test.rb +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/view_edit.rhtml +19 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/view_index.rhtml +24 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/view_new.rhtml +18 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/scaffold_resource/templates/view_show.rhtml +10 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/session_migration/USAGE +15 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/session_migration/session_migration_generator.rb +18 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/session_migration/templates/migration.rb +16 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/web_service/USAGE +28 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/web_service/templates/api_definition.rb +5 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/web_service/templates/controller.rb +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/web_service/templates/functional_test.rb +19 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/generators/components/web_service/web_service_generator.rb +29 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/lookup.rb +209 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/manifest.rb +53 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/options.rb +143 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/scripts/destroy.rb +7 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/scripts/generate.rb +7 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/scripts/update.rb +12 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/scripts.rb +83 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/simple_logger.rb +46 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator/spec.rb +44 -0
- data/sample_rails_project/vendor/rails/railties/lib/rails_generator.rb +43 -0
- data/sample_rails_project/vendor/rails/railties/lib/railties_path.rb +1 -0
- data/sample_rails_project/vendor/rails/railties/lib/ruby_version_check.rb +17 -0
- data/sample_rails_project/vendor/rails/railties/lib/rubyprof_ext.rb +35 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/databases.rake +187 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/documentation.rake +82 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/framework.rake +112 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/log.rake +9 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/misc.rake +4 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/pre_namespace_aliases.rake +53 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/rails.rb +8 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/statistics.rake +18 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/testing.rake +120 -0
- data/sample_rails_project/vendor/rails/railties/lib/tasks/tmp.rake +37 -0
- data/sample_rails_project/vendor/rails/railties/lib/test_help.rb +19 -0
- data/sample_rails_project/vendor/rails/railties/lib/webrick_server.rb +166 -0
- data/spec/deep_test/options_spec.rb +204 -0
- data/spec/deep_test/spec/extensions/example_group_methods_spec.rb +48 -0
- data/spec/deep_test/spec/extensions/example_methods_spec.rb +62 -0
- data/spec/deep_test/spec/extensions/options_spec.rb +23 -0
- data/spec/deep_test/spec/extensions/reporter_spec.rb +28 -0
- data/spec/deep_test/spec/extensions/spec_task_spec.rb +34 -0
- data/spec/deep_test/spec/runner_spec.rb +133 -0
- data/spec/deep_test/spec/work_result_spec.rb +14 -0
- data/spec/deep_test/spec/work_unit_spec.rb +78 -0
- data/spec/spec.opts +1 -0
- data/spec/spec_helper.rb +67 -0
- data/test/deep_test/agent_test.rb +175 -0
- data/test/deep_test/central_command_test.rb +147 -0
- data/test/deep_test/cpu_info_test.rb +33 -0
- data/test/deep_test/database/mysql_setup_listener_test.rb +18 -0
- data/test/deep_test/demon_test.rb +23 -0
- data/test/deep_test/distributed/beachhead_test.rb +67 -0
- data/test/deep_test/distributed/dispatch_controller_test.rb +162 -0
- data/test/deep_test/distributed/filename_resolver_test.rb +56 -0
- data/test/deep_test/distributed/landing_fleet_test.rb +55 -0
- data/test/deep_test/distributed/landing_ship_test.rb +48 -0
- data/test/deep_test/distributed/remote_deployment_test.rb +134 -0
- data/test/deep_test/distributed/rsync_test.rb +47 -0
- data/test/deep_test/distributed/shell_environment_fixtures/set_bar_to_foo +1 -0
- data/test/deep_test/distributed/shell_environment_fixtures/set_foo_to_bar +1 -0
- data/test/deep_test/distributed/shell_environment_fixtures/set_foo_to_baz +1 -0
- data/test/deep_test/distributed/shell_environment_test.rb +108 -0
- data/test/deep_test/distributed/ssh_client_connection_info_test.rb +34 -0
- data/test/deep_test/extensions/object_extension_test.rb +37 -0
- data/test/deep_test/listener_list_test.rb +22 -0
- data/test/deep_test/local_deployment_test.rb +19 -0
- data/test/deep_test/logger_test.rb +38 -0
- data/test/deep_test/main_test.rb +12 -0
- data/test/deep_test/marshallable_exception_wrapper_test.rb +46 -0
- data/test/deep_test/metrics/data_test.rb +22 -0
- data/test/deep_test/metrics/measurement_test.rb +18 -0
- data/test/deep_test/proxy_io_test.rb +104 -0
- data/test/deep_test/result_reader_test.rb +128 -0
- data/test/deep_test/test/extensions/error_test.rb +42 -0
- data/test/deep_test/test/runner_test.rb +11 -0
- data/test/deep_test/test/supervised_test_suite_test.rb +107 -0
- data/test/deep_test/test/work_result_test.rb +85 -0
- data/test/deep_test/test/work_unit_test.rb +63 -0
- data/test/deep_test/test_task_test.rb +15 -0
- data/test/deep_test/ui/console_test.rb +13 -0
- data/test/deep_test/warlock_test.rb +40 -0
- data/test/test_helper.rb +30 -0
- data/test/test_task_test.rb +75 -0
- metadata +1447 -0
@@ -0,0 +1,1627 @@
|
|
1
|
+
require 'active_record/associations/association_proxy'
|
2
|
+
require 'active_record/associations/association_collection'
|
3
|
+
require 'active_record/associations/belongs_to_association'
|
4
|
+
require 'active_record/associations/belongs_to_polymorphic_association'
|
5
|
+
require 'active_record/associations/has_one_association'
|
6
|
+
require 'active_record/associations/has_many_association'
|
7
|
+
require 'active_record/associations/has_many_through_association'
|
8
|
+
require 'active_record/associations/has_and_belongs_to_many_association'
|
9
|
+
require 'active_record/deprecated_associations'
|
10
|
+
|
11
|
+
module ActiveRecord
|
12
|
+
class HasManyThroughAssociationNotFoundError < ActiveRecordError #:nodoc:
|
13
|
+
def initialize(owner_class_name, reflection)
|
14
|
+
super("Could not find the association #{reflection.options[:through].inspect} in model #{owner_class_name}")
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
class HasManyThroughAssociationPolymorphicError < ActiveRecordError #:nodoc:
|
19
|
+
def initialize(owner_class_name, reflection, source_reflection)
|
20
|
+
super("Cannot have a has_many :through association '#{owner_class_name}##{reflection.name}' on the polymorphic object '#{source_reflection.class_name}##{source_reflection.name}'.")
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
class HasManyThroughAssociationPointlessSourceTypeError < ActiveRecordError #:nodoc:
|
25
|
+
def initialize(owner_class_name, reflection, source_reflection)
|
26
|
+
super("Cannot have a has_many :through association '#{owner_class_name}##{reflection.name}' with a :source_type option if the '#{reflection.through_reflection.class_name}##{source_reflection.name}' is not polymorphic. Try removing :source_type on your association.")
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
class HasManyThroughSourceAssociationNotFoundError < ActiveRecordError #:nodoc:
|
31
|
+
def initialize(reflection)
|
32
|
+
through_reflection = reflection.through_reflection
|
33
|
+
source_reflection_names = reflection.source_reflection_names
|
34
|
+
source_associations = reflection.through_reflection.klass.reflect_on_all_associations.collect { |a| a.name.inspect }
|
35
|
+
super("Could not find the source association(s) #{source_reflection_names.collect(&:inspect).to_sentence :connector => 'or'} in model #{through_reflection.klass}. Try 'has_many #{reflection.name.inspect}, :through => #{through_reflection.name.inspect}, :source => <name>'. Is it one of #{source_associations.to_sentence :connector => 'or'}?")
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
class HasManyThroughSourceAssociationMacroError < ActiveRecordError #:nodoc:
|
40
|
+
def initialize(reflection)
|
41
|
+
through_reflection = reflection.through_reflection
|
42
|
+
source_reflection = reflection.source_reflection
|
43
|
+
super("Invalid source reflection macro :#{source_reflection.macro}#{" :through" if source_reflection.options[:through]} for has_many #{reflection.name.inspect}, :through => #{through_reflection.name.inspect}. Use :source to specify the source reflection.")
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
class HasManyThroughCantAssociateNewRecords < ActiveRecordError #:nodoc:
|
48
|
+
def initialize(owner, reflection)
|
49
|
+
super("Cannot associate new records through '#{owner.class.name}##{reflection.name}' on '#{reflection.source_reflection.class_name rescue nil}##{reflection.source_reflection.name rescue nil}'. Both records must have an id in order to create the has_many :through record associating them.")
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
class EagerLoadPolymorphicError < ActiveRecordError #:nodoc:
|
54
|
+
def initialize(reflection)
|
55
|
+
super("Can not eagerly load the polymorphic association #{reflection.name.inspect}")
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
class ReadOnlyAssociation < ActiveRecordError #:nodoc:
|
60
|
+
def initialize(reflection)
|
61
|
+
super("Can not add to a has_many :through association. Try adding to #{reflection.through_reflection.name.inspect}.")
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
module Associations # :nodoc:
|
66
|
+
def self.included(base)
|
67
|
+
base.extend(ClassMethods)
|
68
|
+
end
|
69
|
+
|
70
|
+
# Clears out the association cache
|
71
|
+
def clear_association_cache #:nodoc:
|
72
|
+
self.class.reflect_on_all_associations.to_a.each do |assoc|
|
73
|
+
instance_variable_set "@#{assoc.name}", nil
|
74
|
+
end unless self.new_record?
|
75
|
+
end
|
76
|
+
|
77
|
+
# Associations are a set of macro-like class methods for tying objects together through foreign keys. They express relationships like
|
78
|
+
# "Project has one Project Manager" or "Project belongs to a Portfolio". Each macro adds a number of methods to the class which are
|
79
|
+
# specialized according to the collection or association symbol and the options hash. It works much the same way as Ruby's own attr*
|
80
|
+
# methods. Example:
|
81
|
+
#
|
82
|
+
# class Project < ActiveRecord::Base
|
83
|
+
# belongs_to :portfolio
|
84
|
+
# has_one :project_manager
|
85
|
+
# has_many :milestones
|
86
|
+
# has_and_belongs_to_many :categories
|
87
|
+
# end
|
88
|
+
#
|
89
|
+
# The project class now has the following methods (and more) to ease the traversal and manipulation of its relationships:
|
90
|
+
# * <tt>Project#portfolio, Project#portfolio=(portfolio), Project#portfolio.nil?</tt>
|
91
|
+
# * <tt>Project#project_manager, Project#project_manager=(project_manager), Project#project_manager.nil?,</tt>
|
92
|
+
# * <tt>Project#milestones.empty?, Project#milestones.size, Project#milestones, Project#milestones<<(milestone),</tt>
|
93
|
+
# <tt>Project#milestones.delete(milestone), Project#milestones.find(milestone_id), Project#milestones.find(:all, options),</tt>
|
94
|
+
# <tt>Project#milestones.build, Project#milestones.create</tt>
|
95
|
+
# * <tt>Project#categories.empty?, Project#categories.size, Project#categories, Project#categories<<(category1),</tt>
|
96
|
+
# <tt>Project#categories.delete(category1)</tt>
|
97
|
+
#
|
98
|
+
# == Example
|
99
|
+
#
|
100
|
+
# link:files/examples/associations.png
|
101
|
+
#
|
102
|
+
# == Is it belongs_to or has_one?
|
103
|
+
#
|
104
|
+
# Both express a 1-1 relationship, the difference is mostly where to place the foreign key, which goes on the table for the class
|
105
|
+
# saying belongs_to. Example:
|
106
|
+
#
|
107
|
+
# class User < ActiveRecord::Base
|
108
|
+
# # I reference an account.
|
109
|
+
# belongs_to :account
|
110
|
+
# end
|
111
|
+
#
|
112
|
+
# class Account < ActiveRecord::Base
|
113
|
+
# # One user references me.
|
114
|
+
# has_one :user
|
115
|
+
# end
|
116
|
+
#
|
117
|
+
# The tables for these classes could look something like:
|
118
|
+
#
|
119
|
+
# CREATE TABLE users (
|
120
|
+
# id int(11) NOT NULL auto_increment,
|
121
|
+
# account_id int(11) default NULL,
|
122
|
+
# name varchar default NULL,
|
123
|
+
# PRIMARY KEY (id)
|
124
|
+
# )
|
125
|
+
#
|
126
|
+
# CREATE TABLE accounts (
|
127
|
+
# id int(11) NOT NULL auto_increment,
|
128
|
+
# name varchar default NULL,
|
129
|
+
# PRIMARY KEY (id)
|
130
|
+
# )
|
131
|
+
#
|
132
|
+
# == Unsaved objects and associations
|
133
|
+
#
|
134
|
+
# You can manipulate objects and associations before they are saved to the database, but there is some special behaviour you should be
|
135
|
+
# aware of, mostly involving the saving of associated objects.
|
136
|
+
#
|
137
|
+
# === One-to-one associations
|
138
|
+
#
|
139
|
+
# * Assigning an object to a has_one association automatically saves that object and the object being replaced (if there is one), in
|
140
|
+
# order to update their primary keys - except if the parent object is unsaved (new_record? == true).
|
141
|
+
# * If either of these saves fail (due to one of the objects being invalid) the assignment statement returns false and the assignment
|
142
|
+
# is cancelled.
|
143
|
+
# * If you wish to assign an object to a has_one association without saving it, use the #association.build method (documented below).
|
144
|
+
# * Assigning an object to a belongs_to association does not save the object, since the foreign key field belongs on the parent. It does
|
145
|
+
# not save the parent either.
|
146
|
+
#
|
147
|
+
# === Collections
|
148
|
+
#
|
149
|
+
# * Adding an object to a collection (has_many or has_and_belongs_to_many) automatically saves that object, except if the parent object
|
150
|
+
# (the owner of the collection) is not yet stored in the database.
|
151
|
+
# * If saving any of the objects being added to a collection (via #push or similar) fails, then #push returns false.
|
152
|
+
# * You can add an object to a collection without automatically saving it by using the #collection.build method (documented below).
|
153
|
+
# * All unsaved (new_record? == true) members of the collection are automatically saved when the parent is saved.
|
154
|
+
#
|
155
|
+
# === Association callbacks
|
156
|
+
#
|
157
|
+
# Similiar to the normal callbacks that hook into the lifecycle of an Active Record object, you can also define callbacks that get
|
158
|
+
# trigged when you add an object to or removing an object from a association collection. Example:
|
159
|
+
#
|
160
|
+
# class Project
|
161
|
+
# has_and_belongs_to_many :developers, :after_add => :evaluate_velocity
|
162
|
+
#
|
163
|
+
# def evaluate_velocity(developer)
|
164
|
+
# ...
|
165
|
+
# end
|
166
|
+
# end
|
167
|
+
#
|
168
|
+
# It's possible to stack callbacks by passing them as an array. Example:
|
169
|
+
#
|
170
|
+
# class Project
|
171
|
+
# has_and_belongs_to_many :developers, :after_add => [:evaluate_velocity, Proc.new { |p, d| p.shipping_date = Time.now}]
|
172
|
+
# end
|
173
|
+
#
|
174
|
+
# Possible callbacks are: before_add, after_add, before_remove and after_remove.
|
175
|
+
#
|
176
|
+
# Should any of the before_add callbacks throw an exception, the object does not get added to the collection. Same with
|
177
|
+
# the before_remove callbacks, if an exception is thrown the object doesn't get removed.
|
178
|
+
#
|
179
|
+
# === Association extensions
|
180
|
+
#
|
181
|
+
# The proxy objects that controls the access to associations can be extended through anonymous modules. This is especially
|
182
|
+
# beneficial for adding new finders, creators, and other factory-type methods that are only used as part of this association.
|
183
|
+
# Example:
|
184
|
+
#
|
185
|
+
# class Account < ActiveRecord::Base
|
186
|
+
# has_many :people do
|
187
|
+
# def find_or_create_by_name(name)
|
188
|
+
# first_name, last_name = name.split(" ", 2)
|
189
|
+
# find_or_create_by_first_name_and_last_name(first_name, last_name)
|
190
|
+
# end
|
191
|
+
# end
|
192
|
+
# end
|
193
|
+
#
|
194
|
+
# person = Account.find(:first).people.find_or_create_by_name("David Heinemeier Hansson")
|
195
|
+
# person.first_name # => "David"
|
196
|
+
# person.last_name # => "Heinemeier Hansson"
|
197
|
+
#
|
198
|
+
# If you need to share the same extensions between many associations, you can use a named extension module. Example:
|
199
|
+
#
|
200
|
+
# module FindOrCreateByNameExtension
|
201
|
+
# def find_or_create_by_name(name)
|
202
|
+
# first_name, last_name = name.split(" ", 2)
|
203
|
+
# find_or_create_by_first_name_and_last_name(first_name, last_name)
|
204
|
+
# end
|
205
|
+
# end
|
206
|
+
#
|
207
|
+
# class Account < ActiveRecord::Base
|
208
|
+
# has_many :people, :extend => FindOrCreateByNameExtension
|
209
|
+
# end
|
210
|
+
#
|
211
|
+
# class Company < ActiveRecord::Base
|
212
|
+
# has_many :people, :extend => FindOrCreateByNameExtension
|
213
|
+
# end
|
214
|
+
#
|
215
|
+
# If you need to use multiple named extension modules, you can specify an array of modules with the :extend option.
|
216
|
+
# In the case of name conflicts between methods in the modules, methods in modules later in the array supercede
|
217
|
+
# those earlier in the array. Example:
|
218
|
+
#
|
219
|
+
# class Account < ActiveRecord::Base
|
220
|
+
# has_many :people, :extend => [FindOrCreateByNameExtension, FindRecentExtension]
|
221
|
+
# end
|
222
|
+
#
|
223
|
+
# Some extensions can only be made to work with knowledge of the association proxy's internals.
|
224
|
+
# Extensions can access relevant state using accessors on the association proxy:
|
225
|
+
#
|
226
|
+
# * +proxy_owner+ - Returns the object the association is part of.
|
227
|
+
# * +proxy_reflection+ - Returns the reflection object that describes the association.
|
228
|
+
# * +proxy_target+ - Returns the associated object for belongs_to and has_one, or the collection of associated objects for has_many and has_and_belongs_to_many.
|
229
|
+
#
|
230
|
+
# === Association Join Models
|
231
|
+
#
|
232
|
+
# Has Many associations can be configured with the :through option to use an explicit join model to retrieve the data. This
|
233
|
+
# operates similarly to a <tt>has_and_belongs_to_many</tt> association. The advantage is that you're able to add validations,
|
234
|
+
# callbacks, and extra attributes on the join model. Consider the following schema:
|
235
|
+
#
|
236
|
+
# class Author < ActiveRecord::Base
|
237
|
+
# has_many :authorships
|
238
|
+
# has_many :books, :through => :authorships
|
239
|
+
# end
|
240
|
+
#
|
241
|
+
# class Authorship < ActiveRecord::Base
|
242
|
+
# belongs_to :author
|
243
|
+
# belongs_to :book
|
244
|
+
# end
|
245
|
+
#
|
246
|
+
# @author = Author.find :first
|
247
|
+
# @author.authorships.collect { |a| a.book } # selects all books that the author's authorships belong to.
|
248
|
+
# @author.books # selects all books by using the Authorship join model
|
249
|
+
#
|
250
|
+
# You can also go through a has_many association on the join model:
|
251
|
+
#
|
252
|
+
# class Firm < ActiveRecord::Base
|
253
|
+
# has_many :clients
|
254
|
+
# has_many :invoices, :through => :clients
|
255
|
+
# end
|
256
|
+
#
|
257
|
+
# class Client < ActiveRecord::Base
|
258
|
+
# belongs_to :firm
|
259
|
+
# has_many :invoices
|
260
|
+
# end
|
261
|
+
#
|
262
|
+
# class Invoice < ActiveRecord::Base
|
263
|
+
# belongs_to :client
|
264
|
+
# end
|
265
|
+
#
|
266
|
+
# @firm = Firm.find :first
|
267
|
+
# @firm.clients.collect { |c| c.invoices }.flatten # select all invoices for all clients of the firm
|
268
|
+
# @firm.invoices # selects all invoices by going through the Client join model.
|
269
|
+
#
|
270
|
+
# === Polymorphic Associations
|
271
|
+
#
|
272
|
+
# Polymorphic associations on models are not restricted on what types of models they can be associated with. Rather, they
|
273
|
+
# specify an interface that a has_many association must adhere to.
|
274
|
+
#
|
275
|
+
# class Asset < ActiveRecord::Base
|
276
|
+
# belongs_to :attachable, :polymorphic => true
|
277
|
+
# end
|
278
|
+
#
|
279
|
+
# class Post < ActiveRecord::Base
|
280
|
+
# has_many :assets, :as => :attachable # The <tt>:as</tt> option specifies the polymorphic interface to use.
|
281
|
+
# end
|
282
|
+
#
|
283
|
+
# @asset.attachable = @post
|
284
|
+
#
|
285
|
+
# This works by using a type column in addition to a foreign key to specify the associated record. In the Asset example, you'd need
|
286
|
+
# an attachable_id integer column and an attachable_type string column.
|
287
|
+
#
|
288
|
+
# Using polymorphic associations in combination with single table inheritance (STI) is a little tricky. In order
|
289
|
+
# for the associations to work as expected, ensure that you store the base model for the STI models in the
|
290
|
+
# type column of the polymorphic association. To continue with the asset example above, suppose there are guest posts
|
291
|
+
# and member posts that use the posts table for STI. So there will be an additional 'type' column in the posts table.
|
292
|
+
#
|
293
|
+
# class Asset < ActiveRecord::Base
|
294
|
+
# belongs_to :attachable, :polymorphic => true
|
295
|
+
#
|
296
|
+
# def attachable_type=(sType)
|
297
|
+
# super(sType.to_s.classify.constantize.base_class.to_s)
|
298
|
+
# end
|
299
|
+
# end
|
300
|
+
#
|
301
|
+
# class Post < ActiveRecord::Base
|
302
|
+
# # because we store "Post" in attachable_type now :dependent => :destroy will work
|
303
|
+
# has_many :assets, :as => :attachable, :dependent => :destroy
|
304
|
+
# end
|
305
|
+
#
|
306
|
+
# class GuestPost < ActiveRecord::Base
|
307
|
+
# end
|
308
|
+
#
|
309
|
+
# class MemberPost < ActiveRecord::Base
|
310
|
+
# end
|
311
|
+
#
|
312
|
+
# == Caching
|
313
|
+
#
|
314
|
+
# All of the methods are built on a simple caching principle that will keep the result of the last query around unless specifically
|
315
|
+
# instructed not to. The cache is even shared across methods to make it even cheaper to use the macro-added methods without
|
316
|
+
# worrying too much about performance at the first go. Example:
|
317
|
+
#
|
318
|
+
# project.milestones # fetches milestones from the database
|
319
|
+
# project.milestones.size # uses the milestone cache
|
320
|
+
# project.milestones.empty? # uses the milestone cache
|
321
|
+
# project.milestones(true).size # fetches milestones from the database
|
322
|
+
# project.milestones # uses the milestone cache
|
323
|
+
#
|
324
|
+
# == Eager loading of associations
|
325
|
+
#
|
326
|
+
# Eager loading is a way to find objects of a certain class and a number of named associations along with it in a single SQL call. This is
|
327
|
+
# one of the easiest ways of to prevent the dreaded 1+N problem in which fetching 100 posts that each needs to display their author
|
328
|
+
# triggers 101 database queries. Through the use of eager loading, the 101 queries can be reduced to 1. Example:
|
329
|
+
#
|
330
|
+
# class Post < ActiveRecord::Base
|
331
|
+
# belongs_to :author
|
332
|
+
# has_many :comments
|
333
|
+
# end
|
334
|
+
#
|
335
|
+
# Consider the following loop using the class above:
|
336
|
+
#
|
337
|
+
# for post in Post.find(:all)
|
338
|
+
# puts "Post: " + post.title
|
339
|
+
# puts "Written by: " + post.author.name
|
340
|
+
# puts "Last comment on: " + post.comments.first.created_on
|
341
|
+
# end
|
342
|
+
#
|
343
|
+
# To iterate over these one hundred posts, we'll generate 201 database queries. Let's first just optimize it for retrieving the author:
|
344
|
+
#
|
345
|
+
# for post in Post.find(:all, :include => :author)
|
346
|
+
#
|
347
|
+
# This references the name of the belongs_to association that also used the :author symbol, so the find will now weave in a join something
|
348
|
+
# like this: LEFT OUTER JOIN authors ON authors.id = posts.author_id. Doing so will cut down the number of queries from 201 to 101.
|
349
|
+
#
|
350
|
+
# We can improve upon the situation further by referencing both associations in the finder with:
|
351
|
+
#
|
352
|
+
# for post in Post.find(:all, :include => [ :author, :comments ])
|
353
|
+
#
|
354
|
+
# That'll add another join along the lines of: LEFT OUTER JOIN comments ON comments.post_id = posts.id. And we'll be down to 1 query.
|
355
|
+
# But that shouldn't fool you to think that you can pull out huge amounts of data with no performance penalty just because you've reduced
|
356
|
+
# the number of queries. The database still needs to send all the data to Active Record and it still needs to be processed. So it's no
|
357
|
+
# catch-all for performance problems, but it's a great way to cut down on the number of queries in a situation as the one described above.
|
358
|
+
#
|
359
|
+
# Since the eager loading pulls from multiple tables, you'll have to disambiguate any column references in both conditions and orders. So
|
360
|
+
# :order => "posts.id DESC" will work while :order => "id DESC" will not. Because eager loading generates the SELECT statement too, the
|
361
|
+
# :select option is ignored.
|
362
|
+
#
|
363
|
+
# You can use eager loading on multiple associations from the same table, but you cannot use those associations in orders and conditions
|
364
|
+
# as there is currently not any way to disambiguate them. Eager loading will not pull additional attributes on join tables, so "rich
|
365
|
+
# associations" with has_and_belongs_to_many are not a good fit for eager loading.
|
366
|
+
#
|
367
|
+
# When eager loaded, conditions are interpolated in the context of the model class, not the model instance. Conditions are lazily interpolated
|
368
|
+
# before the actual model exists.
|
369
|
+
#
|
370
|
+
# == Table Aliasing
|
371
|
+
#
|
372
|
+
# ActiveRecord uses table aliasing in the case that a table is referenced multiple times in a join. If a table is referenced only once,
|
373
|
+
# the standard table name is used. The second time, the table is aliased as #{reflection_name}_#{parent_table_name}. Indexes are appended
|
374
|
+
# for any more successive uses of the table name.
|
375
|
+
#
|
376
|
+
# Post.find :all, :include => :comments
|
377
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN comments ON ...
|
378
|
+
# Post.find :all, :include => :special_comments # STI
|
379
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN comments ON ... AND comments.type = 'SpecialComment'
|
380
|
+
# Post.find :all, :include => [:comments, :special_comments] # special_comments is the reflection name, posts is the parent table name
|
381
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN comments ON ... LEFT OUTER JOIN comments special_comments_posts
|
382
|
+
#
|
383
|
+
# Acts as tree example:
|
384
|
+
#
|
385
|
+
# TreeMixin.find :all, :include => :children
|
386
|
+
# # => SELECT ... FROM mixins LEFT OUTER JOIN mixins childrens_mixins ...
|
387
|
+
# TreeMixin.find :all, :include => {:children => :parent} # using cascading eager includes
|
388
|
+
# # => SELECT ... FROM mixins LEFT OUTER JOIN mixins childrens_mixins ...
|
389
|
+
# LEFT OUTER JOIN parents_mixins ...
|
390
|
+
# TreeMixin.find :all, :include => {:children => {:parent => :children}}
|
391
|
+
# # => SELECT ... FROM mixins LEFT OUTER JOIN mixins childrens_mixins ...
|
392
|
+
# LEFT OUTER JOIN parents_mixins ...
|
393
|
+
# LEFT OUTER JOIN mixins childrens_mixins_2
|
394
|
+
#
|
395
|
+
# Has and Belongs to Many join tables use the same idea, but add a _join suffix:
|
396
|
+
#
|
397
|
+
# Post.find :all, :include => :categories
|
398
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN categories_posts ... LEFT OUTER JOIN categories ...
|
399
|
+
# Post.find :all, :include => {:categories => :posts}
|
400
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN categories_posts ... LEFT OUTER JOIN categories ...
|
401
|
+
# LEFT OUTER JOIN categories_posts posts_categories_join LEFT OUTER JOIN posts posts_categories
|
402
|
+
# Post.find :all, :include => {:categories => {:posts => :categories}}
|
403
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN categories_posts ... LEFT OUTER JOIN categories ...
|
404
|
+
# LEFT OUTER JOIN categories_posts posts_categories_join LEFT OUTER JOIN posts posts_categories
|
405
|
+
# LEFT OUTER JOIN categories_posts categories_posts_join LEFT OUTER JOIN categories categories_posts
|
406
|
+
#
|
407
|
+
# If you wish to specify your own custom joins using a :joins option, those table names will take precedence over the eager associations..
|
408
|
+
#
|
409
|
+
# Post.find :all, :include => :comments, :joins => "inner join comments ..."
|
410
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN comments_posts ON ... INNER JOIN comments ...
|
411
|
+
# Post.find :all, :include => [:comments, :special_comments], :joins => "inner join comments ..."
|
412
|
+
# # => SELECT ... FROM posts LEFT OUTER JOIN comments comments_posts ON ...
|
413
|
+
# LEFT OUTER JOIN comments special_comments_posts ...
|
414
|
+
# INNER JOIN comments ...
|
415
|
+
#
|
416
|
+
# Table aliases are automatically truncated according to the maximum length of table identifiers according to the specific database.
|
417
|
+
#
|
418
|
+
# == Modules
|
419
|
+
#
|
420
|
+
# By default, associations will look for objects within the current module scope. Consider:
|
421
|
+
#
|
422
|
+
# module MyApplication
|
423
|
+
# module Business
|
424
|
+
# class Firm < ActiveRecord::Base
|
425
|
+
# has_many :clients
|
426
|
+
# end
|
427
|
+
#
|
428
|
+
# class Company < ActiveRecord::Base; end
|
429
|
+
# end
|
430
|
+
# end
|
431
|
+
#
|
432
|
+
# When Firm#clients is called, it'll in turn call <tt>MyApplication::Business::Company.find(firm.id)</tt>. If you want to associate
|
433
|
+
# with a class in another module scope this can be done by specifying the complete class name, such as:
|
434
|
+
#
|
435
|
+
# module MyApplication
|
436
|
+
# module Business
|
437
|
+
# class Firm < ActiveRecord::Base; end
|
438
|
+
# end
|
439
|
+
#
|
440
|
+
# module Billing
|
441
|
+
# class Account < ActiveRecord::Base
|
442
|
+
# belongs_to :firm, :class_name => "MyApplication::Business::Firm"
|
443
|
+
# end
|
444
|
+
# end
|
445
|
+
# end
|
446
|
+
#
|
447
|
+
# == Type safety with ActiveRecord::AssociationTypeMismatch
|
448
|
+
#
|
449
|
+
# If you attempt to assign an object to an association that doesn't match the inferred or specified <tt>:class_name</tt>, you'll
|
450
|
+
# get a ActiveRecord::AssociationTypeMismatch.
|
451
|
+
#
|
452
|
+
# == Options
|
453
|
+
#
|
454
|
+
# All of the association macros can be specialized through options which makes more complex cases than the simple and guessable ones
|
455
|
+
# possible.
|
456
|
+
module ClassMethods
|
457
|
+
# Adds the following methods for retrieval and query of collections of associated objects.
|
458
|
+
# +collection+ is replaced with the symbol passed as the first argument, so
|
459
|
+
# <tt>has_many :clients</tt> would add among others <tt>clients.empty?</tt>.
|
460
|
+
# * <tt>collection(force_reload = false)</tt> - returns an array of all the associated objects.
|
461
|
+
# An empty array is returned if none are found.
|
462
|
+
# * <tt>collection<<(object, ...)</tt> - adds one or more objects to the collection by setting their foreign keys to the collection's primary key.
|
463
|
+
# * <tt>collection.delete(object, ...)</tt> - removes one or more objects from the collection by setting their foreign keys to NULL.
|
464
|
+
# This will also destroy the objects if they're declared as belongs_to and dependent on this model.
|
465
|
+
# * <tt>collection=objects</tt> - replaces the collections content by deleting and adding objects as appropriate.
|
466
|
+
# * <tt>collection_singular_ids</tt> - returns an array of the associated objects ids
|
467
|
+
# * <tt>collection_singular_ids=ids</tt> - replace the collection by the objects identified by the primary keys in +ids+
|
468
|
+
# * <tt>collection.clear</tt> - removes every object from the collection. This destroys the associated objects if they
|
469
|
+
# are <tt>:dependent</tt>, deletes them directly from the database if they are <tt>:dependent => :delete_all</tt>,
|
470
|
+
# and sets their foreign keys to NULL otherwise.
|
471
|
+
# * <tt>collection.empty?</tt> - returns true if there are no associated objects.
|
472
|
+
# * <tt>collection.size</tt> - returns the number of associated objects.
|
473
|
+
# * <tt>collection.find</tt> - finds an associated object according to the same rules as Base.find.
|
474
|
+
# * <tt>collection.build(attributes = {})</tt> - returns a new object of the collection type that has been instantiated
|
475
|
+
# with +attributes+ and linked to this object through a foreign key but has not yet been saved. *Note:* This only works if an
|
476
|
+
# associated object already exists, not if it's nil!
|
477
|
+
# * <tt>collection.create(attributes = {})</tt> - returns a new object of the collection type that has been instantiated
|
478
|
+
# with +attributes+ and linked to this object through a foreign key and that has already been saved (if it passed the validation).
|
479
|
+
# *Note:* This only works if an associated object already exists, not if it's nil!
|
480
|
+
#
|
481
|
+
# Example: A Firm class declares <tt>has_many :clients</tt>, which will add:
|
482
|
+
# * <tt>Firm#clients</tt> (similar to <tt>Clients.find :all, :conditions => "firm_id = #{id}"</tt>)
|
483
|
+
# * <tt>Firm#clients<<</tt>
|
484
|
+
# * <tt>Firm#clients.delete</tt>
|
485
|
+
# * <tt>Firm#clients=</tt>
|
486
|
+
# * <tt>Firm#client_ids</tt>
|
487
|
+
# * <tt>Firm#client_ids=</tt>
|
488
|
+
# * <tt>Firm#clients.clear</tt>
|
489
|
+
# * <tt>Firm#clients.empty?</tt> (similar to <tt>firm.clients.size == 0</tt>)
|
490
|
+
# * <tt>Firm#clients.size</tt> (similar to <tt>Client.count "firm_id = #{id}"</tt>)
|
491
|
+
# * <tt>Firm#clients.find</tt> (similar to <tt>Client.find(id, :conditions => "firm_id = #{id}")</tt>)
|
492
|
+
# * <tt>Firm#clients.build</tt> (similar to <tt>Client.new("firm_id" => id)</tt>)
|
493
|
+
# * <tt>Firm#clients.create</tt> (similar to <tt>c = Client.new("firm_id" => id); c.save; c</tt>)
|
494
|
+
# The declaration can also include an options hash to specialize the behavior of the association.
|
495
|
+
#
|
496
|
+
# Options are:
|
497
|
+
# * <tt>:class_name</tt> - specify the class name of the association. Use it only if that name can't be inferred
|
498
|
+
# from the association name. So <tt>has_many :products</tt> will by default be linked to the +Product+ class, but
|
499
|
+
# if the real class name is +SpecialProduct+, you'll have to specify it with this option.
|
500
|
+
# * <tt>:conditions</tt> - specify the conditions that the associated objects must meet in order to be included as a "WHERE"
|
501
|
+
# sql fragment, such as "price > 5 AND name LIKE 'B%'".
|
502
|
+
# * <tt>:order</tt> - specify the order in which the associated objects are returned as a "ORDER BY" sql fragment,
|
503
|
+
# such as "last_name, first_name DESC"
|
504
|
+
# * <tt>:group</tt> - specify the attribute by which the associated objects are returned as a "GROUP BY" sql fragment,
|
505
|
+
# such as "category"
|
506
|
+
# * <tt>:foreign_key</tt> - specify the foreign key used for the association. By default this is guessed to be the name
|
507
|
+
# of this class in lower-case and "_id" suffixed. So a +Person+ class that makes a has_many association will use "person_id"
|
508
|
+
# as the default foreign_key.
|
509
|
+
# * <tt>:dependent</tt> - if set to :destroy all the associated objects are destroyed
|
510
|
+
# alongside this object by calling their destroy method. If set to :delete_all all associated
|
511
|
+
# objects are deleted *without* calling their destroy method. If set to :nullify all associated
|
512
|
+
# objects' foreign keys are set to NULL *without* calling their save callbacks.
|
513
|
+
# NOTE: :dependent => true is deprecated and has been replaced with :dependent => :destroy.
|
514
|
+
# May not be set if :exclusively_dependent is also set.
|
515
|
+
# * <tt>:exclusively_dependent</tt> - Deprecated; equivalent to :dependent => :delete_all. If set to true all
|
516
|
+
# the associated object are deleted in one SQL statement without having their
|
517
|
+
# before_destroy callback run. This should only be used on associations that depend solely on this class and don't need to do any
|
518
|
+
# clean-up in before_destroy. The upside is that it's much faster, especially if there's a counter_cache involved.
|
519
|
+
# May not be set if :dependent is also set.
|
520
|
+
# * <tt>:finder_sql</tt> - specify a complete SQL statement to fetch the association. This is a good way to go for complex
|
521
|
+
# associations that depend on multiple tables. Note: When this option is used, +find_in_collection+ is _not_ added.
|
522
|
+
# * <tt>:counter_sql</tt> - specify a complete SQL statement to fetch the size of the association. If +:finder_sql+ is
|
523
|
+
# specified but +:counter_sql+, +:counter_sql+ will be generated by replacing SELECT ... FROM with SELECT COUNT(*) FROM.
|
524
|
+
# * <tt>:extend</tt> - specify a named module for extending the proxy, see "Association extensions".
|
525
|
+
# * <tt>:include</tt> - specify second-order associations that should be eager loaded when the collection is loaded.
|
526
|
+
# * <tt>:group</tt>: An attribute name by which the result should be grouped. Uses the GROUP BY SQL-clause.
|
527
|
+
# * <tt>:limit</tt>: An integer determining the limit on the number of rows that should be returned.
|
528
|
+
# * <tt>:offset</tt>: An integer determining the offset from where the rows should be fetched. So at 5, it would skip the first 4 rows.
|
529
|
+
# * <tt>:select</tt>: By default, this is * as in SELECT * FROM, but can be changed if you for example want to do a join, but not
|
530
|
+
# include the joined columns.
|
531
|
+
# * <tt>:as</tt>: Specifies a polymorphic interface (See #belongs_to).
|
532
|
+
# * <tt>:through</tt>: Specifies a Join Model to perform the query through. Options for <tt>:class_name</tt> and <tt>:foreign_key</tt>
|
533
|
+
# are ignored, as the association uses the source reflection. You can only use a <tt>:through</tt> query through a <tt>belongs_to</tt>
|
534
|
+
# or <tt>has_many</tt> association.
|
535
|
+
# * <tt>:source</tt>: Specifies the source association name used by <tt>has_many :through</tt> queries. Only use it if the name cannot be
|
536
|
+
# inferred from the association. <tt>has_many :subscribers, :through => :subscriptions</tt> will look for either +:subscribers+ or
|
537
|
+
# +:subscriber+ on +Subscription+, unless a +:source+ is given.
|
538
|
+
# * <tt>:source_type</tt>: Specifies type of the source association used by <tt>has_many :through</tt> queries where the source association
|
539
|
+
# is a polymorphic belongs_to.
|
540
|
+
# * <tt>:uniq</tt> - if set to true, duplicates will be omitted from the collection. Useful in conjunction with :through.
|
541
|
+
#
|
542
|
+
# Option examples:
|
543
|
+
# has_many :comments, :order => "posted_on"
|
544
|
+
# has_many :comments, :include => :author
|
545
|
+
# has_many :people, :class_name => "Person", :conditions => "deleted = 0", :order => "name"
|
546
|
+
# has_many :tracks, :order => "position", :dependent => :destroy
|
547
|
+
# has_many :comments, :dependent => :nullify
|
548
|
+
# has_many :tags, :as => :taggable
|
549
|
+
# has_many :subscribers, :through => :subscriptions, :source => :user
|
550
|
+
# has_many :subscribers, :class_name => "Person", :finder_sql =>
|
551
|
+
# 'SELECT DISTINCT people.* ' +
|
552
|
+
# 'FROM people p, post_subscriptions ps ' +
|
553
|
+
# 'WHERE ps.post_id = #{id} AND ps.person_id = p.id ' +
|
554
|
+
# 'ORDER BY p.first_name'
|
555
|
+
def has_many(association_id, options = {}, &extension)
|
556
|
+
reflection = create_has_many_reflection(association_id, options, &extension)
|
557
|
+
|
558
|
+
configure_dependency_for_has_many(reflection)
|
559
|
+
|
560
|
+
if options[:through]
|
561
|
+
collection_reader_method(reflection, HasManyThroughAssociation)
|
562
|
+
else
|
563
|
+
add_multiple_associated_save_callbacks(reflection.name)
|
564
|
+
add_association_callbacks(reflection.name, reflection.options)
|
565
|
+
collection_accessor_methods(reflection, HasManyAssociation)
|
566
|
+
end
|
567
|
+
|
568
|
+
add_deprecated_api_for_has_many(reflection.name)
|
569
|
+
end
|
570
|
+
|
571
|
+
# Adds the following methods for retrieval and query of a single associated object.
|
572
|
+
# +association+ is replaced with the symbol passed as the first argument, so
|
573
|
+
# <tt>has_one :manager</tt> would add among others <tt>manager.nil?</tt>.
|
574
|
+
# * <tt>association(force_reload = false)</tt> - returns the associated object. Nil is returned if none is found.
|
575
|
+
# * <tt>association=(associate)</tt> - assigns the associate object, extracts the primary key, sets it as the foreign key,
|
576
|
+
# and saves the associate object.
|
577
|
+
# * <tt>association.nil?</tt> - returns true if there is no associated object.
|
578
|
+
# * <tt>build_association(attributes = {})</tt> - returns a new object of the associated type that has been instantiated
|
579
|
+
# with +attributes+ and linked to this object through a foreign key but has not yet been saved. Note: This ONLY works if
|
580
|
+
# an association already exists. It will NOT work if the association is nil.
|
581
|
+
# * <tt>create_association(attributes = {})</tt> - returns a new object of the associated type that has been instantiated
|
582
|
+
# with +attributes+ and linked to this object through a foreign key and that has already been saved (if it passed the validation).
|
583
|
+
#
|
584
|
+
# Example: An Account class declares <tt>has_one :beneficiary</tt>, which will add:
|
585
|
+
# * <tt>Account#beneficiary</tt> (similar to <tt>Beneficiary.find(:first, :conditions => "account_id = #{id}")</tt>)
|
586
|
+
# * <tt>Account#beneficiary=(beneficiary)</tt> (similar to <tt>beneficiary.account_id = account.id; beneficiary.save</tt>)
|
587
|
+
# * <tt>Account#beneficiary.nil?</tt>
|
588
|
+
# * <tt>Account#build_beneficiary</tt> (similar to <tt>Beneficiary.new("account_id" => id)</tt>)
|
589
|
+
# * <tt>Account#create_beneficiary</tt> (similar to <tt>b = Beneficiary.new("account_id" => id); b.save; b</tt>)
|
590
|
+
#
|
591
|
+
# The declaration can also include an options hash to specialize the behavior of the association.
|
592
|
+
#
|
593
|
+
# Options are:
|
594
|
+
# * <tt>:class_name</tt> - specify the class name of the association. Use it only if that name can't be inferred
|
595
|
+
# from the association name. So <tt>has_one :manager</tt> will by default be linked to the +Manager+ class, but
|
596
|
+
# if the real class name is +Person+, you'll have to specify it with this option.
|
597
|
+
# * <tt>:conditions</tt> - specify the conditions that the associated object must meet in order to be included as a "WHERE"
|
598
|
+
# sql fragment, such as "rank = 5".
|
599
|
+
# * <tt>:order</tt> - specify the order from which the associated object will be picked at the top. Specified as
|
600
|
+
# an "ORDER BY" sql fragment, such as "last_name, first_name DESC"
|
601
|
+
# * <tt>:dependent</tt> - if set to :destroy (or true) the associated object is destroyed when this object is. If set to
|
602
|
+
# :delete the associated object is deleted *without* calling its destroy method. If set to :nullify the associated
|
603
|
+
# object's foreign key is set to NULL. Also, association is assigned.
|
604
|
+
# * <tt>:foreign_key</tt> - specify the foreign key used for the association. By default this is guessed to be the name
|
605
|
+
# of this class in lower-case and "_id" suffixed. So a +Person+ class that makes a has_one association will use "person_id"
|
606
|
+
# as the default foreign_key.
|
607
|
+
# * <tt>:include</tt> - specify second-order associations that should be eager loaded when this object is loaded.
|
608
|
+
# * <tt>:as</tt>: Specifies a polymorphic interface (See #belongs_to).
|
609
|
+
#
|
610
|
+
# Option examples:
|
611
|
+
# has_one :credit_card, :dependent => :destroy # destroys the associated credit card
|
612
|
+
# has_one :credit_card, :dependent => :nullify # updates the associated records foriegn key value to null rather than destroying it
|
613
|
+
# has_one :last_comment, :class_name => "Comment", :order => "posted_on"
|
614
|
+
# has_one :project_manager, :class_name => "Person", :conditions => "role = 'project_manager'"
|
615
|
+
# has_one :attachment, :as => :attachable
|
616
|
+
def has_one(association_id, options = {})
|
617
|
+
reflection = create_has_one_reflection(association_id, options)
|
618
|
+
|
619
|
+
module_eval do
|
620
|
+
after_save <<-EOF
|
621
|
+
association = instance_variable_get("@#{reflection.name}")
|
622
|
+
if !association.nil? && (new_record? || association.new_record? || association["#{reflection.primary_key_name}"] != id)
|
623
|
+
association["#{reflection.primary_key_name}"] = id
|
624
|
+
association.save(true)
|
625
|
+
end
|
626
|
+
EOF
|
627
|
+
end
|
628
|
+
|
629
|
+
association_accessor_methods(reflection, HasOneAssociation)
|
630
|
+
association_constructor_method(:build, reflection, HasOneAssociation)
|
631
|
+
association_constructor_method(:create, reflection, HasOneAssociation)
|
632
|
+
|
633
|
+
configure_dependency_for_has_one(reflection)
|
634
|
+
|
635
|
+
# deprecated api
|
636
|
+
deprecated_has_association_method(reflection.name)
|
637
|
+
deprecated_association_comparison_method(reflection.name, reflection.class_name)
|
638
|
+
end
|
639
|
+
|
640
|
+
# Adds the following methods for retrieval and query for a single associated object that this object holds an id to.
|
641
|
+
# +association+ is replaced with the symbol passed as the first argument, so
|
642
|
+
# <tt>belongs_to :author</tt> would add among others <tt>author.nil?</tt>.
|
643
|
+
# * <tt>association(force_reload = false)</tt> - returns the associated object. Nil is returned if none is found.
|
644
|
+
# * <tt>association=(associate)</tt> - assigns the associate object, extracts the primary key, and sets it as the foreign key.
|
645
|
+
# * <tt>association.nil?</tt> - returns true if there is no associated object.
|
646
|
+
# * <tt>build_association(attributes = {})</tt> - returns a new object of the associated type that has been instantiated
|
647
|
+
# with +attributes+ and linked to this object through a foreign key but has not yet been saved.
|
648
|
+
# * <tt>create_association(attributes = {})</tt> - returns a new object of the associated type that has been instantiated
|
649
|
+
# with +attributes+ and linked to this object through a foreign key and that has already been saved (if it passed the validation).
|
650
|
+
#
|
651
|
+
# Example: A Post class declares <tt>belongs_to :author</tt>, which will add:
|
652
|
+
# * <tt>Post#author</tt> (similar to <tt>Author.find(author_id)</tt>)
|
653
|
+
# * <tt>Post#author=(author)</tt> (similar to <tt>post.author_id = author.id</tt>)
|
654
|
+
# * <tt>Post#author?</tt> (similar to <tt>post.author == some_author</tt>)
|
655
|
+
# * <tt>Post#author.nil?</tt>
|
656
|
+
# * <tt>Post#build_author</tt> (similar to <tt>post.author = Author.new</tt>)
|
657
|
+
# * <tt>Post#create_author</tt> (similar to <tt>post.author = Author.new; post.author.save; post.author</tt>)
|
658
|
+
# The declaration can also include an options hash to specialize the behavior of the association.
|
659
|
+
#
|
660
|
+
# Options are:
|
661
|
+
# * <tt>:class_name</tt> - specify the class name of the association. Use it only if that name can't be inferred
|
662
|
+
# from the association name. So <tt>has_one :author</tt> will by default be linked to the +Author+ class, but
|
663
|
+
# if the real class name is +Person+, you'll have to specify it with this option.
|
664
|
+
# * <tt>:conditions</tt> - specify the conditions that the associated object must meet in order to be included as a "WHERE"
|
665
|
+
# sql fragment, such as "authorized = 1".
|
666
|
+
# * <tt>:order</tt> - specify the order from which the associated object will be picked at the top. Specified as
|
667
|
+
# an "ORDER BY" sql fragment, such as "last_name, first_name DESC"
|
668
|
+
# * <tt>:foreign_key</tt> - specify the foreign key used for the association. By default this is guessed to be the name
|
669
|
+
# of the associated class in lower-case and "_id" suffixed. So a +Person+ class that makes a belongs_to association to a
|
670
|
+
# +Boss+ class will use "boss_id" as the default foreign_key.
|
671
|
+
# * <tt>:counter_cache</tt> - caches the number of belonging objects on the associate class through use of increment_counter
|
672
|
+
# and decrement_counter. The counter cache is incremented when an object of this class is created and decremented when it's
|
673
|
+
# destroyed. This requires that a column named "#{table_name}_count" (such as comments_count for a belonging Comment class)
|
674
|
+
# is used on the associate class (such as a Post class). You can also specify a custom counter cache column by given that
|
675
|
+
# name instead of a true/false value to this option (e.g., <tt>:counter_cache => :my_custom_counter</tt>.)
|
676
|
+
# * <tt>:include</tt> - specify second-order associations that should be eager loaded when this object is loaded.
|
677
|
+
# * <tt>:polymorphic</tt> - specify this association is a polymorphic association by passing true.
|
678
|
+
#
|
679
|
+
# Option examples:
|
680
|
+
# belongs_to :firm, :foreign_key => "client_of"
|
681
|
+
# belongs_to :author, :class_name => "Person", :foreign_key => "author_id"
|
682
|
+
# belongs_to :valid_coupon, :class_name => "Coupon", :foreign_key => "coupon_id",
|
683
|
+
# :conditions => 'discounts > #{payments_count}'
|
684
|
+
# belongs_to :attachable, :polymorphic => true
|
685
|
+
def belongs_to(association_id, options = {})
|
686
|
+
if options.include?(:class_name) && !options.include?(:foreign_key)
|
687
|
+
::ActiveSupport::Deprecation.warn(
|
688
|
+
"The inferred foreign_key name will change in Rails 2.0 to use the association name instead of its class name when they differ. When using :class_name in belongs_to, use the :foreign_key option to explicitly set the key name to avoid problems in the transition.",
|
689
|
+
caller)
|
690
|
+
end
|
691
|
+
|
692
|
+
reflection = create_belongs_to_reflection(association_id, options)
|
693
|
+
|
694
|
+
if reflection.options[:polymorphic]
|
695
|
+
association_accessor_methods(reflection, BelongsToPolymorphicAssociation)
|
696
|
+
|
697
|
+
module_eval do
|
698
|
+
before_save <<-EOF
|
699
|
+
association = instance_variable_get("@#{reflection.name}")
|
700
|
+
if association && association.target
|
701
|
+
if association.new_record?
|
702
|
+
association.save(true)
|
703
|
+
end
|
704
|
+
|
705
|
+
if association.updated?
|
706
|
+
self["#{reflection.primary_key_name}"] = association.id
|
707
|
+
self["#{reflection.options[:foreign_type]}"] = association.class.base_class.name.to_s
|
708
|
+
end
|
709
|
+
end
|
710
|
+
EOF
|
711
|
+
end
|
712
|
+
else
|
713
|
+
association_accessor_methods(reflection, BelongsToAssociation)
|
714
|
+
association_constructor_method(:build, reflection, BelongsToAssociation)
|
715
|
+
association_constructor_method(:create, reflection, BelongsToAssociation)
|
716
|
+
|
717
|
+
module_eval do
|
718
|
+
before_save <<-EOF
|
719
|
+
association = instance_variable_get("@#{reflection.name}")
|
720
|
+
if !association.nil?
|
721
|
+
if association.new_record?
|
722
|
+
association.save(true)
|
723
|
+
end
|
724
|
+
|
725
|
+
if association.updated?
|
726
|
+
self["#{reflection.primary_key_name}"] = association.id
|
727
|
+
end
|
728
|
+
end
|
729
|
+
EOF
|
730
|
+
end
|
731
|
+
|
732
|
+
# deprecated api
|
733
|
+
deprecated_has_association_method(reflection.name)
|
734
|
+
deprecated_association_comparison_method(reflection.name, reflection.class_name)
|
735
|
+
end
|
736
|
+
|
737
|
+
if options[:counter_cache]
|
738
|
+
cache_column = options[:counter_cache] == true ?
|
739
|
+
"#{self.to_s.underscore.pluralize}_count" :
|
740
|
+
options[:counter_cache]
|
741
|
+
|
742
|
+
module_eval(
|
743
|
+
"after_create '#{reflection.name}.class.increment_counter(\"#{cache_column}\", #{reflection.primary_key_name})" +
|
744
|
+
" unless #{reflection.name}.nil?'"
|
745
|
+
)
|
746
|
+
|
747
|
+
module_eval(
|
748
|
+
"before_destroy '#{reflection.name}.class.decrement_counter(\"#{cache_column}\", #{reflection.primary_key_name})" +
|
749
|
+
" unless #{reflection.name}.nil?'"
|
750
|
+
)
|
751
|
+
end
|
752
|
+
end
|
753
|
+
|
754
|
+
# Associates two classes via an intermediate join table. Unless the join table is explicitly specified as
|
755
|
+
# an option, it is guessed using the lexical order of the class names. So a join between Developer and Project
|
756
|
+
# will give the default join table name of "developers_projects" because "D" outranks "P". Note that this precedence
|
757
|
+
# is calculated using the <tt><</tt> operator for <tt>String</tt>. This means that if the strings are of different lengths,
|
758
|
+
# and the strings are equal when compared up to the shortest length, then the longer string is considered of higher
|
759
|
+
# lexical precedence than the shorter one. For example, one would expect the tables <tt>paper_boxes</tt> and <tt>papers</tt>
|
760
|
+
# to generate a join table name of <tt>papers_paper_boxes</tt> because of the length of the name <tt>paper_boxes</tt>,
|
761
|
+
# but it in fact generates a join table name of <tt>paper_boxes_papers</tt>. Be aware of this caveat, and use the
|
762
|
+
# custom <tt>join_table</tt> option if you need to.
|
763
|
+
#
|
764
|
+
# Deprecated: Any additional fields added to the join table will be placed as attributes when pulling records out through
|
765
|
+
# has_and_belongs_to_many associations. Records returned from join tables with additional attributes will be marked as
|
766
|
+
# ReadOnly (because we can't save changes to the additional attrbutes). It's strongly recommended that you upgrade any
|
767
|
+
# associations with attributes to a real join model (see introduction).
|
768
|
+
#
|
769
|
+
# Adds the following methods for retrieval and query.
|
770
|
+
# +collection+ is replaced with the symbol passed as the first argument, so
|
771
|
+
# <tt>has_and_belongs_to_many :categories</tt> would add among others <tt>categories.empty?</tt>.
|
772
|
+
# * <tt>collection(force_reload = false)</tt> - returns an array of all the associated objects.
|
773
|
+
# An empty array is returned if none is found.
|
774
|
+
# * <tt>collection<<(object, ...)</tt> - adds one or more objects to the collection by creating associations in the join table
|
775
|
+
# (collection.push and collection.concat are aliases to this method).
|
776
|
+
# * <tt>collection.push_with_attributes(object, join_attributes)</tt> - adds one to the collection by creating an association in the join table that
|
777
|
+
# also holds the attributes from <tt>join_attributes</tt> (should be a hash with the column names as keys). This can be used to have additional
|
778
|
+
# attributes on the join, which will be injected into the associated objects when they are retrieved through the collection.
|
779
|
+
# (collection.concat_with_attributes is an alias to this method). This method is now deprecated.
|
780
|
+
# * <tt>collection.delete(object, ...)</tt> - removes one or more objects from the collection by removing their associations from the join table.
|
781
|
+
# This does not destroy the objects.
|
782
|
+
# * <tt>collection=objects</tt> - replaces the collections content by deleting and adding objects as appropriate.
|
783
|
+
# * <tt>collection_singular_ids</tt> - returns an array of the associated objects ids
|
784
|
+
# * <tt>collection_singular_ids=ids</tt> - replace the collection by the objects identified by the primary keys in +ids+
|
785
|
+
# * <tt>collection.clear</tt> - removes every object from the collection. This does not destroy the objects.
|
786
|
+
# * <tt>collection.empty?</tt> - returns true if there are no associated objects.
|
787
|
+
# * <tt>collection.size</tt> - returns the number of associated objects.
|
788
|
+
# * <tt>collection.find(id)</tt> - finds an associated object responding to the +id+ and that
|
789
|
+
# meets the condition that it has to be associated with this object.
|
790
|
+
# * <tt>collection.build(attributes = {})</tt> - returns a new object of the collection type that has been instantiated
|
791
|
+
# with +attributes+ and linked to this object through the join table but has not yet been saved.
|
792
|
+
# * <tt>collection.create(attributes = {})</tt> - returns a new object of the collection type that has been instantiated
|
793
|
+
# with +attributes+ and linked to this object through the join table and that has already been saved (if it passed the validation).
|
794
|
+
#
|
795
|
+
# Example: An Developer class declares <tt>has_and_belongs_to_many :projects</tt>, which will add:
|
796
|
+
# * <tt>Developer#projects</tt>
|
797
|
+
# * <tt>Developer#projects<<</tt>
|
798
|
+
# * <tt>Developer#projects.delete</tt>
|
799
|
+
# * <tt>Developer#projects=</tt>
|
800
|
+
# * <tt>Developer#project_ids</tt>
|
801
|
+
# * <tt>Developer#project_ids=</tt>
|
802
|
+
# * <tt>Developer#projects.clear</tt>
|
803
|
+
# * <tt>Developer#projects.empty?</tt>
|
804
|
+
# * <tt>Developer#projects.size</tt>
|
805
|
+
# * <tt>Developer#projects.find(id)</tt>
|
806
|
+
# * <tt>Developer#projects.build</tt> (similar to <tt>Project.new("project_id" => id)</tt>)
|
807
|
+
# * <tt>Developer#projects.create</tt> (similar to <tt>c = Project.new("project_id" => id); c.save; c</tt>)
|
808
|
+
# The declaration may include an options hash to specialize the behavior of the association.
|
809
|
+
#
|
810
|
+
# Options are:
|
811
|
+
# * <tt>:class_name</tt> - specify the class name of the association. Use it only if that name can't be inferred
|
812
|
+
# from the association name. So <tt>has_and_belongs_to_many :projects</tt> will by default be linked to the
|
813
|
+
# +Project+ class, but if the real class name is +SuperProject+, you'll have to specify it with this option.
|
814
|
+
# * <tt>:join_table</tt> - specify the name of the join table if the default based on lexical order isn't what you want.
|
815
|
+
# WARNING: If you're overwriting the table name of either class, the table_name method MUST be declared underneath any
|
816
|
+
# has_and_belongs_to_many declaration in order to work.
|
817
|
+
# * <tt>:foreign_key</tt> - specify the foreign key used for the association. By default this is guessed to be the name
|
818
|
+
# of this class in lower-case and "_id" suffixed. So a +Person+ class that makes a has_and_belongs_to_many association
|
819
|
+
# will use "person_id" as the default foreign_key.
|
820
|
+
# * <tt>:association_foreign_key</tt> - specify the association foreign key used for the association. By default this is
|
821
|
+
# guessed to be the name of the associated class in lower-case and "_id" suffixed. So if the associated class is +Project+,
|
822
|
+
# the has_and_belongs_to_many association will use "project_id" as the default association foreign_key.
|
823
|
+
# * <tt>:conditions</tt> - specify the conditions that the associated object must meet in order to be included as a "WHERE"
|
824
|
+
# sql fragment, such as "authorized = 1".
|
825
|
+
# * <tt>:order</tt> - specify the order in which the associated objects are returned as a "ORDER BY" sql fragment, such as "last_name, first_name DESC"
|
826
|
+
# * <tt>:uniq</tt> - if set to true, duplicate associated objects will be ignored by accessors and query methods
|
827
|
+
# * <tt>:finder_sql</tt> - overwrite the default generated SQL used to fetch the association with a manual one
|
828
|
+
# * <tt>:delete_sql</tt> - overwrite the default generated SQL used to remove links between the associated
|
829
|
+
# classes with a manual one
|
830
|
+
# * <tt>:insert_sql</tt> - overwrite the default generated SQL used to add links between the associated classes
|
831
|
+
# with a manual one
|
832
|
+
# * <tt>:extend</tt> - anonymous module for extending the proxy, see "Association extensions".
|
833
|
+
# * <tt>:include</tt> - specify second-order associations that should be eager loaded when the collection is loaded.
|
834
|
+
# * <tt>:group</tt>: An attribute name by which the result should be grouped. Uses the GROUP BY SQL-clause.
|
835
|
+
# * <tt>:limit</tt>: An integer determining the limit on the number of rows that should be returned.
|
836
|
+
# * <tt>:offset</tt>: An integer determining the offset from where the rows should be fetched. So at 5, it would skip the first 4 rows.
|
837
|
+
# * <tt>:select</tt>: By default, this is * as in SELECT * FROM, but can be changed if you for example want to do a join, but not
|
838
|
+
# include the joined columns.
|
839
|
+
#
|
840
|
+
# Option examples:
|
841
|
+
# has_and_belongs_to_many :projects
|
842
|
+
# has_and_belongs_to_many :projects, :include => [ :milestones, :manager ]
|
843
|
+
# has_and_belongs_to_many :nations, :class_name => "Country"
|
844
|
+
# has_and_belongs_to_many :categories, :join_table => "prods_cats"
|
845
|
+
# has_and_belongs_to_many :active_projects, :join_table => 'developers_projects', :delete_sql =>
|
846
|
+
# 'DELETE FROM developers_projects WHERE active=1 AND developer_id = #{id} AND project_id = #{record.id}'
|
847
|
+
def has_and_belongs_to_many(association_id, options = {}, &extension)
|
848
|
+
reflection = create_has_and_belongs_to_many_reflection(association_id, options, &extension)
|
849
|
+
|
850
|
+
add_multiple_associated_save_callbacks(reflection.name)
|
851
|
+
collection_accessor_methods(reflection, HasAndBelongsToManyAssociation)
|
852
|
+
|
853
|
+
# Don't use a before_destroy callback since users' before_destroy
|
854
|
+
# callbacks will be executed after the association is wiped out.
|
855
|
+
old_method = "destroy_without_habtm_shim_for_#{reflection.name}"
|
856
|
+
class_eval <<-end_eval
|
857
|
+
alias_method :#{old_method}, :destroy_without_callbacks
|
858
|
+
def destroy_without_callbacks
|
859
|
+
#{reflection.name}.clear
|
860
|
+
#{old_method}
|
861
|
+
end
|
862
|
+
end_eval
|
863
|
+
|
864
|
+
add_association_callbacks(reflection.name, options)
|
865
|
+
|
866
|
+
# deprecated api
|
867
|
+
deprecated_collection_count_method(reflection.name)
|
868
|
+
deprecated_add_association_relation(reflection.name)
|
869
|
+
deprecated_remove_association_relation(reflection.name)
|
870
|
+
deprecated_has_collection_method(reflection.name)
|
871
|
+
end
|
872
|
+
|
873
|
+
private
|
874
|
+
def join_table_name(first_table_name, second_table_name)
|
875
|
+
if first_table_name < second_table_name
|
876
|
+
join_table = "#{first_table_name}_#{second_table_name}"
|
877
|
+
else
|
878
|
+
join_table = "#{second_table_name}_#{first_table_name}"
|
879
|
+
end
|
880
|
+
|
881
|
+
table_name_prefix + join_table + table_name_suffix
|
882
|
+
end
|
883
|
+
|
884
|
+
def association_accessor_methods(reflection, association_proxy_class)
|
885
|
+
define_method(reflection.name) do |*params|
|
886
|
+
force_reload = params.first unless params.empty?
|
887
|
+
association = instance_variable_get("@#{reflection.name}")
|
888
|
+
|
889
|
+
if association.nil? || force_reload
|
890
|
+
association = association_proxy_class.new(self, reflection)
|
891
|
+
retval = association.reload
|
892
|
+
if retval.nil? and association_proxy_class == BelongsToAssociation
|
893
|
+
instance_variable_set("@#{reflection.name}", nil)
|
894
|
+
return nil
|
895
|
+
end
|
896
|
+
instance_variable_set("@#{reflection.name}", association)
|
897
|
+
end
|
898
|
+
|
899
|
+
association.target.nil? ? nil : association
|
900
|
+
end
|
901
|
+
|
902
|
+
define_method("#{reflection.name}=") do |new_value|
|
903
|
+
association = instance_variable_get("@#{reflection.name}")
|
904
|
+
if association.nil?
|
905
|
+
association = association_proxy_class.new(self, reflection)
|
906
|
+
end
|
907
|
+
|
908
|
+
association.replace(new_value)
|
909
|
+
|
910
|
+
unless new_value.nil?
|
911
|
+
instance_variable_set("@#{reflection.name}", association)
|
912
|
+
else
|
913
|
+
instance_variable_set("@#{reflection.name}", nil)
|
914
|
+
return nil
|
915
|
+
end
|
916
|
+
|
917
|
+
association
|
918
|
+
end
|
919
|
+
|
920
|
+
define_method("set_#{reflection.name}_target") do |target|
|
921
|
+
return if target.nil? and association_proxy_class == BelongsToAssociation
|
922
|
+
association = association_proxy_class.new(self, reflection)
|
923
|
+
association.target = target
|
924
|
+
instance_variable_set("@#{reflection.name}", association)
|
925
|
+
end
|
926
|
+
end
|
927
|
+
|
928
|
+
def collection_reader_method(reflection, association_proxy_class)
|
929
|
+
define_method(reflection.name) do |*params|
|
930
|
+
force_reload = params.first unless params.empty?
|
931
|
+
association = instance_variable_get("@#{reflection.name}")
|
932
|
+
|
933
|
+
unless association.respond_to?(:loaded?)
|
934
|
+
association = association_proxy_class.new(self, reflection)
|
935
|
+
instance_variable_set("@#{reflection.name}", association)
|
936
|
+
end
|
937
|
+
|
938
|
+
association.reload if force_reload
|
939
|
+
|
940
|
+
association
|
941
|
+
end
|
942
|
+
end
|
943
|
+
|
944
|
+
def collection_accessor_methods(reflection, association_proxy_class)
|
945
|
+
collection_reader_method(reflection, association_proxy_class)
|
946
|
+
|
947
|
+
define_method("#{reflection.name}=") do |new_value|
|
948
|
+
# Loads proxy class instance (defined in collection_reader_method) if not already loaded
|
949
|
+
association = send(reflection.name)
|
950
|
+
association.replace(new_value)
|
951
|
+
association
|
952
|
+
end
|
953
|
+
|
954
|
+
define_method("#{reflection.name.to_s.singularize}_ids") do
|
955
|
+
send(reflection.name).map(&:id)
|
956
|
+
end
|
957
|
+
|
958
|
+
define_method("#{reflection.name.to_s.singularize}_ids=") do |new_value|
|
959
|
+
ids = (new_value || []).reject { |nid| nid.blank? }
|
960
|
+
send("#{reflection.name}=", reflection.class_name.constantize.find(ids))
|
961
|
+
end
|
962
|
+
end
|
963
|
+
|
964
|
+
def add_multiple_associated_save_callbacks(association_name)
|
965
|
+
method_name = "validate_associated_records_for_#{association_name}".to_sym
|
966
|
+
define_method(method_name) do
|
967
|
+
association = instance_variable_get("@#{association_name}")
|
968
|
+
if association.respond_to?(:loaded?)
|
969
|
+
if new_record?
|
970
|
+
association
|
971
|
+
else
|
972
|
+
association.select { |record| record.new_record? }
|
973
|
+
end.each do |record|
|
974
|
+
errors.add "#{association_name}" unless record.valid?
|
975
|
+
end
|
976
|
+
end
|
977
|
+
end
|
978
|
+
|
979
|
+
validate method_name
|
980
|
+
before_save("@new_record_before_save = new_record?; true")
|
981
|
+
|
982
|
+
after_callback = <<-end_eval
|
983
|
+
association = instance_variable_get("@#{association_name}")
|
984
|
+
|
985
|
+
if association.respond_to?(:loaded?)
|
986
|
+
if @new_record_before_save
|
987
|
+
records_to_save = association
|
988
|
+
else
|
989
|
+
records_to_save = association.select { |record| record.new_record? }
|
990
|
+
end
|
991
|
+
records_to_save.each { |record| association.send(:insert_record, record) }
|
992
|
+
association.send(:construct_sql) # reconstruct the SQL queries now that we know the owner's id
|
993
|
+
end
|
994
|
+
end_eval
|
995
|
+
|
996
|
+
# Doesn't use after_save as that would save associations added in after_create/after_update twice
|
997
|
+
after_create(after_callback)
|
998
|
+
after_update(after_callback)
|
999
|
+
end
|
1000
|
+
|
1001
|
+
def association_constructor_method(constructor, reflection, association_proxy_class)
|
1002
|
+
define_method("#{constructor}_#{reflection.name}") do |*params|
|
1003
|
+
attributees = params.first unless params.empty?
|
1004
|
+
replace_existing = params[1].nil? ? true : params[1]
|
1005
|
+
association = instance_variable_get("@#{reflection.name}")
|
1006
|
+
|
1007
|
+
if association.nil?
|
1008
|
+
association = association_proxy_class.new(self, reflection)
|
1009
|
+
instance_variable_set("@#{reflection.name}", association)
|
1010
|
+
end
|
1011
|
+
|
1012
|
+
if association_proxy_class == HasOneAssociation
|
1013
|
+
association.send(constructor, attributees, replace_existing)
|
1014
|
+
else
|
1015
|
+
association.send(constructor, attributees)
|
1016
|
+
end
|
1017
|
+
end
|
1018
|
+
end
|
1019
|
+
|
1020
|
+
def find_with_associations(options = {})
|
1021
|
+
catch :invalid_query do
|
1022
|
+
join_dependency = JoinDependency.new(self, merge_includes(scope(:find, :include), options[:include]), options[:joins])
|
1023
|
+
rows = select_all_rows(options, join_dependency)
|
1024
|
+
return join_dependency.instantiate(rows)
|
1025
|
+
end
|
1026
|
+
[]
|
1027
|
+
end
|
1028
|
+
|
1029
|
+
def configure_dependency_for_has_many(reflection)
|
1030
|
+
if reflection.options[:dependent] == true
|
1031
|
+
::ActiveSupport::Deprecation.warn("The :dependent => true option is deprecated and will be removed from Rails 2.0. Please use :dependent => :destroy instead. See http://www.rubyonrails.org/deprecation for details.", caller)
|
1032
|
+
end
|
1033
|
+
|
1034
|
+
if reflection.options[:dependent] && reflection.options[:exclusively_dependent]
|
1035
|
+
raise ArgumentError, ':dependent and :exclusively_dependent are mutually exclusive options. You may specify one or the other.'
|
1036
|
+
end
|
1037
|
+
|
1038
|
+
if reflection.options[:exclusively_dependent]
|
1039
|
+
reflection.options[:dependent] = :delete_all
|
1040
|
+
::ActiveSupport::Deprecation.warn("The :exclusively_dependent option is deprecated and will be removed from Rails 2.0. Please use :dependent => :delete_all instead. See http://www.rubyonrails.org/deprecation for details.", caller)
|
1041
|
+
end
|
1042
|
+
|
1043
|
+
# See HasManyAssociation#delete_records. Dependent associations
|
1044
|
+
# delete children, otherwise foreign key is set to NULL.
|
1045
|
+
|
1046
|
+
# Add polymorphic type if the :as option is present
|
1047
|
+
dependent_conditions = %(#{reflection.primary_key_name} = \#{record.quoted_id})
|
1048
|
+
if reflection.options[:as]
|
1049
|
+
dependent_conditions += " AND #{reflection.options[:as]}_type = '#{base_class.name}'"
|
1050
|
+
end
|
1051
|
+
|
1052
|
+
case reflection.options[:dependent]
|
1053
|
+
when :destroy, true
|
1054
|
+
module_eval "before_destroy '#{reflection.name}.each { |o| o.destroy }'"
|
1055
|
+
when :delete_all
|
1056
|
+
module_eval "before_destroy { |record| #{reflection.class_name}.delete_all(%(#{dependent_conditions})) }"
|
1057
|
+
when :nullify
|
1058
|
+
module_eval "before_destroy { |record| #{reflection.class_name}.update_all(%(#{reflection.primary_key_name} = NULL), %(#{dependent_conditions})) }"
|
1059
|
+
when nil, false
|
1060
|
+
# pass
|
1061
|
+
else
|
1062
|
+
raise ArgumentError, 'The :dependent option expects either :destroy, :delete_all, or :nullify'
|
1063
|
+
end
|
1064
|
+
end
|
1065
|
+
|
1066
|
+
def configure_dependency_for_has_one(reflection)
|
1067
|
+
case reflection.options[:dependent]
|
1068
|
+
when :destroy, true
|
1069
|
+
module_eval "before_destroy '#{reflection.name}.destroy unless #{reflection.name}.nil?'"
|
1070
|
+
when :delete
|
1071
|
+
module_eval "before_destroy '#{reflection.class_name}.delete(#{reflection.name}.id) unless #{reflection.name}.nil?'"
|
1072
|
+
when :nullify
|
1073
|
+
module_eval "before_destroy '#{reflection.name}.update_attribute(\"#{reflection.primary_key_name}\", nil) unless #{reflection.name}.nil?'"
|
1074
|
+
when nil, false
|
1075
|
+
# pass
|
1076
|
+
else
|
1077
|
+
raise ArgumentError, "The :dependent option expects either :destroy, :delete or :nullify."
|
1078
|
+
end
|
1079
|
+
end
|
1080
|
+
|
1081
|
+
|
1082
|
+
def add_deprecated_api_for_has_many(association_name)
|
1083
|
+
deprecated_collection_count_method(association_name)
|
1084
|
+
deprecated_add_association_relation(association_name)
|
1085
|
+
deprecated_remove_association_relation(association_name)
|
1086
|
+
deprecated_has_collection_method(association_name)
|
1087
|
+
deprecated_find_in_collection_method(association_name)
|
1088
|
+
deprecated_find_all_in_collection_method(association_name)
|
1089
|
+
deprecated_collection_create_method(association_name)
|
1090
|
+
deprecated_collection_build_method(association_name)
|
1091
|
+
end
|
1092
|
+
|
1093
|
+
def create_has_many_reflection(association_id, options, &extension)
|
1094
|
+
options.assert_valid_keys(
|
1095
|
+
:class_name, :table_name, :foreign_key,
|
1096
|
+
:exclusively_dependent, :dependent,
|
1097
|
+
:select, :conditions, :include, :order, :group, :limit, :offset,
|
1098
|
+
:as, :through, :source, :source_type,
|
1099
|
+
:uniq,
|
1100
|
+
:finder_sql, :counter_sql,
|
1101
|
+
:before_add, :after_add, :before_remove, :after_remove,
|
1102
|
+
:extend
|
1103
|
+
)
|
1104
|
+
|
1105
|
+
options[:extend] = create_extension_module(association_id, extension) if block_given?
|
1106
|
+
|
1107
|
+
create_reflection(:has_many, association_id, options, self)
|
1108
|
+
end
|
1109
|
+
|
1110
|
+
def create_has_one_reflection(association_id, options)
|
1111
|
+
options.assert_valid_keys(
|
1112
|
+
:class_name, :foreign_key, :remote, :conditions, :order, :include, :dependent, :counter_cache, :extend, :as
|
1113
|
+
)
|
1114
|
+
|
1115
|
+
create_reflection(:has_one, association_id, options, self)
|
1116
|
+
end
|
1117
|
+
|
1118
|
+
def create_belongs_to_reflection(association_id, options)
|
1119
|
+
options.assert_valid_keys(
|
1120
|
+
:class_name, :foreign_key, :foreign_type, :remote, :conditions, :order, :include, :dependent,
|
1121
|
+
:counter_cache, :extend, :polymorphic
|
1122
|
+
)
|
1123
|
+
|
1124
|
+
reflection = create_reflection(:belongs_to, association_id, options, self)
|
1125
|
+
|
1126
|
+
if options[:polymorphic]
|
1127
|
+
reflection.options[:foreign_type] ||= reflection.class_name.underscore + "_type"
|
1128
|
+
end
|
1129
|
+
|
1130
|
+
reflection
|
1131
|
+
end
|
1132
|
+
|
1133
|
+
def create_has_and_belongs_to_many_reflection(association_id, options, &extension)
|
1134
|
+
options.assert_valid_keys(
|
1135
|
+
:class_name, :table_name, :join_table, :foreign_key, :association_foreign_key,
|
1136
|
+
:select, :conditions, :include, :order, :group, :limit, :offset,
|
1137
|
+
:uniq,
|
1138
|
+
:finder_sql, :delete_sql, :insert_sql,
|
1139
|
+
:before_add, :after_add, :before_remove, :after_remove,
|
1140
|
+
:extend
|
1141
|
+
)
|
1142
|
+
|
1143
|
+
options[:extend] = create_extension_module(association_id, extension) if block_given?
|
1144
|
+
|
1145
|
+
reflection = create_reflection(:has_and_belongs_to_many, association_id, options, self)
|
1146
|
+
|
1147
|
+
reflection.options[:join_table] ||= join_table_name(undecorated_table_name(self.to_s), undecorated_table_name(reflection.class_name))
|
1148
|
+
|
1149
|
+
reflection
|
1150
|
+
end
|
1151
|
+
|
1152
|
+
def reflect_on_included_associations(associations)
|
1153
|
+
[ associations ].flatten.collect { |association| reflect_on_association(association.to_s.intern) }
|
1154
|
+
end
|
1155
|
+
|
1156
|
+
def guard_against_unlimitable_reflections(reflections, options)
|
1157
|
+
if (options[:offset] || options[:limit]) && !using_limitable_reflections?(reflections)
|
1158
|
+
raise(
|
1159
|
+
ConfigurationError,
|
1160
|
+
"You can not use offset and limit together with has_many or has_and_belongs_to_many associations"
|
1161
|
+
)
|
1162
|
+
end
|
1163
|
+
end
|
1164
|
+
|
1165
|
+
def select_all_rows(options, join_dependency)
|
1166
|
+
connection.select_all(
|
1167
|
+
construct_finder_sql_with_included_associations(options, join_dependency),
|
1168
|
+
"#{name} Load Including Associations"
|
1169
|
+
)
|
1170
|
+
end
|
1171
|
+
|
1172
|
+
def construct_finder_sql_with_included_associations(options, join_dependency)
|
1173
|
+
scope = scope(:find)
|
1174
|
+
sql = "SELECT #{column_aliases(join_dependency)} FROM #{(scope && scope[:from]) || options[:from] || table_name} "
|
1175
|
+
sql << join_dependency.join_associations.collect{|join| join.association_join }.join
|
1176
|
+
|
1177
|
+
add_joins!(sql, options, scope)
|
1178
|
+
add_conditions!(sql, options[:conditions], scope)
|
1179
|
+
add_limited_ids_condition!(sql, options, join_dependency) if !using_limitable_reflections?(join_dependency.reflections) && ((scope && scope[:limit]) || options[:limit])
|
1180
|
+
|
1181
|
+
sql << "GROUP BY #{options[:group]} " if options[:group]
|
1182
|
+
|
1183
|
+
add_order!(sql, options[:order], scope)
|
1184
|
+
add_limit!(sql, options, scope) if using_limitable_reflections?(join_dependency.reflections)
|
1185
|
+
add_lock!(sql, options, scope)
|
1186
|
+
|
1187
|
+
return sanitize_sql(sql)
|
1188
|
+
end
|
1189
|
+
|
1190
|
+
def add_limited_ids_condition!(sql, options, join_dependency)
|
1191
|
+
unless (id_list = select_limited_ids_list(options, join_dependency)).empty?
|
1192
|
+
sql << "#{condition_word(sql)} #{table_name}.#{primary_key} IN (#{id_list}) "
|
1193
|
+
else
|
1194
|
+
throw :invalid_query
|
1195
|
+
end
|
1196
|
+
end
|
1197
|
+
|
1198
|
+
def select_limited_ids_list(options, join_dependency)
|
1199
|
+
connection.select_all(
|
1200
|
+
construct_finder_sql_for_association_limiting(options, join_dependency),
|
1201
|
+
"#{name} Load IDs For Limited Eager Loading"
|
1202
|
+
).collect { |row| connection.quote(row[primary_key]) }.join(", ")
|
1203
|
+
end
|
1204
|
+
|
1205
|
+
def construct_finder_sql_for_association_limiting(options, join_dependency)
|
1206
|
+
scope = scope(:find)
|
1207
|
+
is_distinct = include_eager_conditions?(options) || include_eager_order?(options)
|
1208
|
+
sql = "SELECT "
|
1209
|
+
if is_distinct
|
1210
|
+
sql << connection.distinct("#{table_name}.#{primary_key}", options[:order])
|
1211
|
+
else
|
1212
|
+
sql << primary_key
|
1213
|
+
end
|
1214
|
+
sql << " FROM #{table_name} "
|
1215
|
+
|
1216
|
+
if is_distinct
|
1217
|
+
sql << join_dependency.join_associations.collect(&:association_join).join
|
1218
|
+
add_joins!(sql, options, scope)
|
1219
|
+
end
|
1220
|
+
|
1221
|
+
add_conditions!(sql, options[:conditions], scope)
|
1222
|
+
if options[:order]
|
1223
|
+
if is_distinct
|
1224
|
+
connection.add_order_by_for_association_limiting!(sql, options)
|
1225
|
+
else
|
1226
|
+
sql << "ORDER BY #{options[:order]}"
|
1227
|
+
end
|
1228
|
+
end
|
1229
|
+
add_limit!(sql, options, scope)
|
1230
|
+
return sanitize_sql(sql)
|
1231
|
+
end
|
1232
|
+
|
1233
|
+
# Checks if the conditions reference a table other than the current model table
|
1234
|
+
def include_eager_conditions?(options)
|
1235
|
+
# look in both sets of conditions
|
1236
|
+
conditions = [scope(:find, :conditions), options[:conditions]].inject([]) do |all, cond|
|
1237
|
+
case cond
|
1238
|
+
when nil then all
|
1239
|
+
when Array then all << cond.first
|
1240
|
+
else all << cond
|
1241
|
+
end
|
1242
|
+
end
|
1243
|
+
return false unless conditions.any?
|
1244
|
+
conditions.join(' ').scan(/([\.\w]+)\.\w+/).flatten.any? do |condition_table_name|
|
1245
|
+
condition_table_name != table_name
|
1246
|
+
end
|
1247
|
+
end
|
1248
|
+
|
1249
|
+
# Checks if the query order references a table other than the current model's table.
|
1250
|
+
def include_eager_order?(options)
|
1251
|
+
order = options[:order]
|
1252
|
+
return false unless order
|
1253
|
+
order.scan(/([\.\w]+)\.\w+/).flatten.any? do |order_table_name|
|
1254
|
+
order_table_name != table_name
|
1255
|
+
end
|
1256
|
+
end
|
1257
|
+
|
1258
|
+
def using_limitable_reflections?(reflections)
|
1259
|
+
reflections.reject { |r| [ :belongs_to, :has_one ].include?(r.macro) }.length.zero?
|
1260
|
+
end
|
1261
|
+
|
1262
|
+
def column_aliases(join_dependency)
|
1263
|
+
join_dependency.joins.collect{|join| join.column_names_with_alias.collect{|column_name, aliased_name|
|
1264
|
+
"#{join.aliased_table_name}.#{connection.quote_column_name column_name} AS #{aliased_name}"}}.flatten.join(", ")
|
1265
|
+
end
|
1266
|
+
|
1267
|
+
def add_association_callbacks(association_name, options)
|
1268
|
+
callbacks = %w(before_add after_add before_remove after_remove)
|
1269
|
+
callbacks.each do |callback_name|
|
1270
|
+
full_callback_name = "#{callback_name}_for_#{association_name}"
|
1271
|
+
defined_callbacks = options[callback_name.to_sym]
|
1272
|
+
if options.has_key?(callback_name.to_sym)
|
1273
|
+
class_inheritable_reader full_callback_name.to_sym
|
1274
|
+
write_inheritable_array(full_callback_name.to_sym, [defined_callbacks].flatten)
|
1275
|
+
end
|
1276
|
+
end
|
1277
|
+
end
|
1278
|
+
|
1279
|
+
def condition_word(sql)
|
1280
|
+
sql =~ /where/i ? " AND " : "WHERE "
|
1281
|
+
end
|
1282
|
+
|
1283
|
+
def create_extension_module(association_id, extension)
|
1284
|
+
extension_module_name = "#{self.to_s}#{association_id.to_s.camelize}AssociationExtension"
|
1285
|
+
|
1286
|
+
silence_warnings do
|
1287
|
+
Object.const_set(extension_module_name, Module.new(&extension))
|
1288
|
+
end
|
1289
|
+
|
1290
|
+
extension_module_name.constantize
|
1291
|
+
end
|
1292
|
+
|
1293
|
+
class JoinDependency # :nodoc:
|
1294
|
+
attr_reader :joins, :reflections, :table_aliases
|
1295
|
+
|
1296
|
+
def initialize(base, associations, joins)
|
1297
|
+
@joins = [JoinBase.new(base, joins)]
|
1298
|
+
@associations = associations
|
1299
|
+
@reflections = []
|
1300
|
+
@base_records_hash = {}
|
1301
|
+
@base_records_in_order = []
|
1302
|
+
@table_aliases = Hash.new { |aliases, table| aliases[table] = 0 }
|
1303
|
+
@table_aliases[base.table_name] = 1
|
1304
|
+
build(associations)
|
1305
|
+
end
|
1306
|
+
|
1307
|
+
def join_associations
|
1308
|
+
@joins[1..-1].to_a
|
1309
|
+
end
|
1310
|
+
|
1311
|
+
def join_base
|
1312
|
+
@joins[0]
|
1313
|
+
end
|
1314
|
+
|
1315
|
+
def instantiate(rows)
|
1316
|
+
rows.each_with_index do |row, i|
|
1317
|
+
primary_id = join_base.record_id(row)
|
1318
|
+
unless @base_records_hash[primary_id]
|
1319
|
+
@base_records_in_order << (@base_records_hash[primary_id] = join_base.instantiate(row))
|
1320
|
+
end
|
1321
|
+
construct(@base_records_hash[primary_id], @associations, join_associations.dup, row)
|
1322
|
+
end
|
1323
|
+
return @base_records_in_order
|
1324
|
+
end
|
1325
|
+
|
1326
|
+
def aliased_table_names_for(table_name)
|
1327
|
+
joins.select{|join| join.table_name == table_name }.collect{|join| join.aliased_table_name}
|
1328
|
+
end
|
1329
|
+
|
1330
|
+
protected
|
1331
|
+
def build(associations, parent = nil)
|
1332
|
+
parent ||= @joins.last
|
1333
|
+
case associations
|
1334
|
+
when Symbol, String
|
1335
|
+
reflection = parent.reflections[associations.to_s.intern] or
|
1336
|
+
raise ConfigurationError, "Association named '#{ associations }' was not found; perhaps you misspelled it?"
|
1337
|
+
@reflections << reflection
|
1338
|
+
@joins << JoinAssociation.new(reflection, self, parent)
|
1339
|
+
when Array
|
1340
|
+
associations.each do |association|
|
1341
|
+
build(association, parent)
|
1342
|
+
end
|
1343
|
+
when Hash
|
1344
|
+
associations.keys.sort{|a,b|a.to_s<=>b.to_s}.each do |name|
|
1345
|
+
build(name, parent)
|
1346
|
+
build(associations[name])
|
1347
|
+
end
|
1348
|
+
else
|
1349
|
+
raise ConfigurationError, associations.inspect
|
1350
|
+
end
|
1351
|
+
end
|
1352
|
+
|
1353
|
+
def construct(parent, associations, joins, row)
|
1354
|
+
case associations
|
1355
|
+
when Symbol, String
|
1356
|
+
while (join = joins.shift).reflection.name.to_s != associations.to_s
|
1357
|
+
raise ConfigurationError, "Not Enough Associations" if joins.empty?
|
1358
|
+
end
|
1359
|
+
construct_association(parent, join, row)
|
1360
|
+
when Array
|
1361
|
+
associations.each do |association|
|
1362
|
+
construct(parent, association, joins, row)
|
1363
|
+
end
|
1364
|
+
when Hash
|
1365
|
+
associations.keys.sort{|a,b|a.to_s<=>b.to_s}.each do |name|
|
1366
|
+
association = construct_association(parent, joins.shift, row)
|
1367
|
+
construct(association, associations[name], joins, row) if association
|
1368
|
+
end
|
1369
|
+
else
|
1370
|
+
raise ConfigurationError, associations.inspect
|
1371
|
+
end
|
1372
|
+
end
|
1373
|
+
|
1374
|
+
def construct_association(record, join, row)
|
1375
|
+
case join.reflection.macro
|
1376
|
+
when :has_many, :has_and_belongs_to_many
|
1377
|
+
collection = record.send(join.reflection.name)
|
1378
|
+
collection.loaded
|
1379
|
+
|
1380
|
+
return nil if record.id.to_s != join.parent.record_id(row).to_s or row[join.aliased_primary_key].nil?
|
1381
|
+
association = join.instantiate(row)
|
1382
|
+
collection.target.push(association) unless collection.target.include?(association)
|
1383
|
+
when :has_one
|
1384
|
+
return if record.id.to_s != join.parent.record_id(row).to_s
|
1385
|
+
association = join.instantiate(row) unless row[join.aliased_primary_key].nil?
|
1386
|
+
record.send("set_#{join.reflection.name}_target", association)
|
1387
|
+
when :belongs_to
|
1388
|
+
return if record.id.to_s != join.parent.record_id(row).to_s or row[join.aliased_primary_key].nil?
|
1389
|
+
association = join.instantiate(row)
|
1390
|
+
record.send("set_#{join.reflection.name}_target", association)
|
1391
|
+
else
|
1392
|
+
raise ConfigurationError, "unknown macro: #{join.reflection.macro}"
|
1393
|
+
end
|
1394
|
+
return association
|
1395
|
+
end
|
1396
|
+
|
1397
|
+
class JoinBase # :nodoc:
|
1398
|
+
attr_reader :active_record, :table_joins
|
1399
|
+
delegate :table_name, :column_names, :primary_key, :reflections, :sanitize_sql, :to => :active_record
|
1400
|
+
|
1401
|
+
def initialize(active_record, joins = nil)
|
1402
|
+
@active_record = active_record
|
1403
|
+
@cached_record = {}
|
1404
|
+
@table_joins = joins
|
1405
|
+
end
|
1406
|
+
|
1407
|
+
def aliased_prefix
|
1408
|
+
"t0"
|
1409
|
+
end
|
1410
|
+
|
1411
|
+
def aliased_primary_key
|
1412
|
+
"#{ aliased_prefix }_r0"
|
1413
|
+
end
|
1414
|
+
|
1415
|
+
def aliased_table_name
|
1416
|
+
active_record.table_name
|
1417
|
+
end
|
1418
|
+
|
1419
|
+
def column_names_with_alias
|
1420
|
+
unless @column_names_with_alias
|
1421
|
+
@column_names_with_alias = []
|
1422
|
+
([primary_key] + (column_names - [primary_key])).each_with_index do |column_name, i|
|
1423
|
+
@column_names_with_alias << [column_name, "#{ aliased_prefix }_r#{ i }"]
|
1424
|
+
end
|
1425
|
+
end
|
1426
|
+
return @column_names_with_alias
|
1427
|
+
end
|
1428
|
+
|
1429
|
+
def extract_record(row)
|
1430
|
+
column_names_with_alias.inject({}){|record, (cn, an)| record[cn] = row[an]; record}
|
1431
|
+
end
|
1432
|
+
|
1433
|
+
def record_id(row)
|
1434
|
+
row[aliased_primary_key]
|
1435
|
+
end
|
1436
|
+
|
1437
|
+
def instantiate(row)
|
1438
|
+
@cached_record[record_id(row)] ||= active_record.instantiate(extract_record(row))
|
1439
|
+
end
|
1440
|
+
end
|
1441
|
+
|
1442
|
+
class JoinAssociation < JoinBase # :nodoc:
|
1443
|
+
attr_reader :reflection, :parent, :aliased_table_name, :aliased_prefix, :aliased_join_table_name, :parent_table_name
|
1444
|
+
delegate :options, :klass, :through_reflection, :source_reflection, :to => :reflection
|
1445
|
+
|
1446
|
+
def initialize(reflection, join_dependency, parent = nil)
|
1447
|
+
reflection.check_validity!
|
1448
|
+
if reflection.options[:polymorphic]
|
1449
|
+
raise EagerLoadPolymorphicError.new(reflection)
|
1450
|
+
end
|
1451
|
+
|
1452
|
+
super(reflection.klass)
|
1453
|
+
@parent = parent
|
1454
|
+
@reflection = reflection
|
1455
|
+
@aliased_prefix = "t#{ join_dependency.joins.size }"
|
1456
|
+
@aliased_table_name = table_name #.tr('.', '_') # start with the table name, sub out any .'s
|
1457
|
+
@parent_table_name = parent.active_record.table_name
|
1458
|
+
|
1459
|
+
if !parent.table_joins.blank? && parent.table_joins.to_s.downcase =~ %r{join(\s+\w+)?\s+#{aliased_table_name.downcase}\son}
|
1460
|
+
join_dependency.table_aliases[aliased_table_name] += 1
|
1461
|
+
end
|
1462
|
+
|
1463
|
+
unless join_dependency.table_aliases[aliased_table_name].zero?
|
1464
|
+
# if the table name has been used, then use an alias
|
1465
|
+
@aliased_table_name = active_record.connection.table_alias_for "#{pluralize(reflection.name)}_#{parent_table_name}"
|
1466
|
+
table_index = join_dependency.table_aliases[aliased_table_name]
|
1467
|
+
join_dependency.table_aliases[aliased_table_name] += 1
|
1468
|
+
@aliased_table_name = @aliased_table_name[0..active_record.connection.table_alias_length-3] + "_#{table_index+1}" if table_index > 0
|
1469
|
+
else
|
1470
|
+
join_dependency.table_aliases[aliased_table_name] += 1
|
1471
|
+
end
|
1472
|
+
|
1473
|
+
if reflection.macro == :has_and_belongs_to_many || (reflection.macro == :has_many && reflection.options[:through])
|
1474
|
+
@aliased_join_table_name = reflection.macro == :has_and_belongs_to_many ? reflection.options[:join_table] : reflection.through_reflection.klass.table_name
|
1475
|
+
unless join_dependency.table_aliases[aliased_join_table_name].zero?
|
1476
|
+
@aliased_join_table_name = active_record.connection.table_alias_for "#{pluralize(reflection.name)}_#{parent_table_name}_join"
|
1477
|
+
table_index = join_dependency.table_aliases[aliased_join_table_name]
|
1478
|
+
join_dependency.table_aliases[aliased_join_table_name] += 1
|
1479
|
+
@aliased_join_table_name = @aliased_join_table_name[0..active_record.connection.table_alias_length-3] + "_#{table_index+1}" if table_index > 0
|
1480
|
+
else
|
1481
|
+
join_dependency.table_aliases[aliased_join_table_name] += 1
|
1482
|
+
end
|
1483
|
+
end
|
1484
|
+
end
|
1485
|
+
|
1486
|
+
def association_join
|
1487
|
+
join = case reflection.macro
|
1488
|
+
when :has_and_belongs_to_many
|
1489
|
+
" LEFT OUTER JOIN %s ON %s.%s = %s.%s " % [
|
1490
|
+
table_alias_for(options[:join_table], aliased_join_table_name),
|
1491
|
+
aliased_join_table_name,
|
1492
|
+
options[:foreign_key] || reflection.active_record.to_s.classify.foreign_key,
|
1493
|
+
parent.aliased_table_name, reflection.active_record.primary_key] +
|
1494
|
+
" LEFT OUTER JOIN %s ON %s.%s = %s.%s " % [
|
1495
|
+
table_name_and_alias, aliased_table_name, klass.primary_key,
|
1496
|
+
aliased_join_table_name, options[:association_foreign_key] || klass.table_name.classify.foreign_key
|
1497
|
+
]
|
1498
|
+
when :has_many, :has_one
|
1499
|
+
case
|
1500
|
+
when reflection.macro == :has_many && reflection.options[:through]
|
1501
|
+
through_conditions = through_reflection.options[:conditions] ? "AND #{interpolate_sql(sanitize_sql(through_reflection.options[:conditions]))}" : ''
|
1502
|
+
|
1503
|
+
jt_foreign_key = jt_as_extra = jt_source_extra = jt_sti_extra = nil
|
1504
|
+
first_key = second_key = as_extra = nil
|
1505
|
+
|
1506
|
+
if through_reflection.options[:as] # has_many :through against a polymorphic join
|
1507
|
+
jt_foreign_key = through_reflection.options[:as].to_s + '_id'
|
1508
|
+
jt_as_extra = " AND %s.%s = %s" % [
|
1509
|
+
aliased_join_table_name, reflection.active_record.connection.quote_column_name(through_reflection.options[:as].to_s + '_type'),
|
1510
|
+
klass.quote_value(parent.active_record.base_class.name)
|
1511
|
+
]
|
1512
|
+
else
|
1513
|
+
jt_foreign_key = through_reflection.primary_key_name
|
1514
|
+
end
|
1515
|
+
|
1516
|
+
case source_reflection.macro
|
1517
|
+
when :has_many
|
1518
|
+
if source_reflection.options[:as]
|
1519
|
+
first_key = "#{source_reflection.options[:as]}_id"
|
1520
|
+
second_key = options[:foreign_key] || primary_key
|
1521
|
+
as_extra = " AND %s.%s = %s" % [
|
1522
|
+
aliased_table_name, reflection.active_record.connection.quote_column_name("#{source_reflection.options[:as]}_type"),
|
1523
|
+
klass.quote_value(source_reflection.active_record.base_class.name)
|
1524
|
+
]
|
1525
|
+
else
|
1526
|
+
first_key = through_reflection.klass.base_class.to_s.classify.foreign_key
|
1527
|
+
second_key = options[:foreign_key] || primary_key
|
1528
|
+
end
|
1529
|
+
|
1530
|
+
unless through_reflection.klass.descends_from_active_record?
|
1531
|
+
jt_sti_extra = " AND %s.%s = %s" % [
|
1532
|
+
aliased_join_table_name,
|
1533
|
+
reflection.active_record.connection.quote_column_name(through_reflection.active_record.inheritance_column),
|
1534
|
+
through_reflection.klass.quote_value(through_reflection.klass.name.demodulize)]
|
1535
|
+
end
|
1536
|
+
when :belongs_to
|
1537
|
+
first_key = primary_key
|
1538
|
+
if reflection.options[:source_type]
|
1539
|
+
second_key = source_reflection.association_foreign_key
|
1540
|
+
jt_source_extra = " AND %s.%s = %s" % [
|
1541
|
+
aliased_join_table_name, reflection.active_record.connection.quote_column_name(reflection.source_reflection.options[:foreign_type]),
|
1542
|
+
klass.quote_value(reflection.options[:source_type])
|
1543
|
+
]
|
1544
|
+
else
|
1545
|
+
second_key = source_reflection.options[:foreign_key] || klass.to_s.classify.foreign_key
|
1546
|
+
end
|
1547
|
+
end
|
1548
|
+
|
1549
|
+
" LEFT OUTER JOIN %s ON (%s.%s = %s.%s%s%s%s) " % [
|
1550
|
+
table_alias_for(through_reflection.klass.table_name, aliased_join_table_name),
|
1551
|
+
parent.aliased_table_name, reflection.active_record.connection.quote_column_name(parent.primary_key),
|
1552
|
+
aliased_join_table_name, reflection.active_record.connection.quote_column_name(jt_foreign_key),
|
1553
|
+
jt_as_extra, jt_source_extra, jt_sti_extra
|
1554
|
+
] +
|
1555
|
+
" LEFT OUTER JOIN %s ON (%s.%s = %s.%s%s) " % [
|
1556
|
+
table_name_and_alias,
|
1557
|
+
aliased_table_name, reflection.active_record.connection.quote_column_name(first_key),
|
1558
|
+
aliased_join_table_name, reflection.active_record.connection.quote_column_name(second_key),
|
1559
|
+
as_extra
|
1560
|
+
]
|
1561
|
+
|
1562
|
+
when reflection.macro == :has_many && reflection.options[:as]
|
1563
|
+
" LEFT OUTER JOIN %s ON %s.%s = %s.%s AND %s.%s = %s" % [
|
1564
|
+
table_name_and_alias,
|
1565
|
+
aliased_table_name, "#{reflection.options[:as]}_id",
|
1566
|
+
parent.aliased_table_name, parent.primary_key,
|
1567
|
+
aliased_table_name, "#{reflection.options[:as]}_type",
|
1568
|
+
klass.quote_value(parent.active_record.base_class.name)
|
1569
|
+
]
|
1570
|
+
when reflection.macro == :has_one && reflection.options[:as]
|
1571
|
+
" LEFT OUTER JOIN %s ON %s.%s = %s.%s AND %s.%s = %s " % [
|
1572
|
+
table_name_and_alias,
|
1573
|
+
aliased_table_name, "#{reflection.options[:as]}_id",
|
1574
|
+
parent.aliased_table_name, parent.primary_key,
|
1575
|
+
aliased_table_name, "#{reflection.options[:as]}_type",
|
1576
|
+
klass.quote_value(reflection.active_record.base_class.name)
|
1577
|
+
]
|
1578
|
+
else
|
1579
|
+
foreign_key = options[:foreign_key] || reflection.active_record.name.foreign_key
|
1580
|
+
" LEFT OUTER JOIN %s ON %s.%s = %s.%s " % [
|
1581
|
+
table_name_and_alias,
|
1582
|
+
aliased_table_name, foreign_key,
|
1583
|
+
parent.aliased_table_name, parent.primary_key
|
1584
|
+
]
|
1585
|
+
end
|
1586
|
+
when :belongs_to
|
1587
|
+
" LEFT OUTER JOIN %s ON %s.%s = %s.%s " % [
|
1588
|
+
table_name_and_alias, aliased_table_name, reflection.klass.primary_key,
|
1589
|
+
parent.aliased_table_name, options[:foreign_key] || klass.to_s.foreign_key
|
1590
|
+
]
|
1591
|
+
else
|
1592
|
+
""
|
1593
|
+
end || ''
|
1594
|
+
join << %(AND %s.%s = %s ) % [
|
1595
|
+
aliased_table_name,
|
1596
|
+
reflection.active_record.connection.quote_column_name(klass.inheritance_column),
|
1597
|
+
klass.quote_value(klass.name.demodulize)] unless klass.descends_from_active_record?
|
1598
|
+
|
1599
|
+
[through_reflection, reflection].each do |ref|
|
1600
|
+
join << "AND #{interpolate_sql(sanitize_sql(ref.options[:conditions]))} " if ref && ref.options[:conditions]
|
1601
|
+
end
|
1602
|
+
|
1603
|
+
join
|
1604
|
+
end
|
1605
|
+
|
1606
|
+
protected
|
1607
|
+
|
1608
|
+
def pluralize(table_name)
|
1609
|
+
ActiveRecord::Base.pluralize_table_names ? table_name.to_s.pluralize : table_name
|
1610
|
+
end
|
1611
|
+
|
1612
|
+
def table_alias_for(table_name, table_alias)
|
1613
|
+
"#{table_name} #{table_alias if table_name != table_alias}".strip
|
1614
|
+
end
|
1615
|
+
|
1616
|
+
def table_name_and_alias
|
1617
|
+
table_alias_for table_name, @aliased_table_name
|
1618
|
+
end
|
1619
|
+
|
1620
|
+
def interpolate_sql(sql)
|
1621
|
+
instance_eval("%@#{sql.gsub('@', '\@')}@")
|
1622
|
+
end
|
1623
|
+
end
|
1624
|
+
end
|
1625
|
+
end
|
1626
|
+
end
|
1627
|
+
end
|