muck-raker 0.1.13 → 0.1.14
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +27 -8
- data/VERSION +1 -1
- data/app/controllers/recommender/entries_controller.rb +13 -12
- data/app/controllers/recommender/feeds_controller.rb +64 -0
- data/app/controllers/recommender/recommendations_controller.rb +1 -1
- data/app/helpers/muck_raker_feeds_helper.rb +3 -0
- data/app/helpers/muck_raker_helper.rb +27 -4
- data/app/models/entry.rb +5 -4
- data/app/models/feed.rb +1 -0
- data/app/models/tag_cloud.rb +3 -3
- data/app/views/entries/_result_status.html.erb +8 -1
- data/app/views/entries/_tag_cloud.html.erb +2 -2
- data/app/views/entries/browse_by_tags.html.erb +1 -1
- data/app/views/entries/details.html.erb +4 -4
- data/app/views/entries/search.html.erb +1 -1
- data/app/views/recommendations/index.xml.builder +5 -3
- data/config/muck_raker_routes.rb +1 -0
- data/db/migrate/20090716035935_change_tag_cloud_grain_sizes.rb +9 -0
- data/db/migrate/20090717173900_add_contributor_to_feeds.rb +9 -0
- data/db/migrate/20090717175825_normalize_entries_subjects.rb +17 -0
- data/lib/muck_raker/tasks.rb +21 -3
- data/locales/en.yml +11 -4
- data/muck-raker.gemspec +320 -10
- data/raker/lib/aggregatord.jar +0 -0
- data/raker/lib/recommenderd.jar +0 -0
- data/test/rails_root/.gitignore +8 -0
- data/test/rails_root/.rake_tasks +103 -0
- data/test/rails_root/Capfile +3 -0
- data/test/rails_root/Rakefile +15 -0
- data/test/rails_root/app/controllers/application_controller.rb +21 -0
- data/test/rails_root/app/controllers/default_controller.rb +7 -0
- data/test/rails_root/app/helpers/application_helper.rb +3 -0
- data/test/rails_root/app/models/.keep +0 -0
- data/test/rails_root/app/models/user.rb +6 -0
- data/test/rails_root/app/models/user_session.rb +2 -0
- data/test/rails_root/app/views/default/index.html.erb +0 -0
- data/test/rails_root/app/views/layouts/default.html.erb +26 -0
- data/test/rails_root/config/amazon_s3.yml +14 -0
- data/test/rails_root/config/boot.rb +109 -0
- data/test/rails_root/config/database.yml +14 -0
- data/test/rails_root/config/environment.rb +29 -0
- data/test/rails_root/config/environments/development.rb +19 -0
- data/test/rails_root/config/environments/production.rb +1 -0
- data/test/rails_root/config/environments/test.rb +34 -0
- data/test/rails_root/config/global_config.yml +77 -0
- data/test/rails_root/config/initializers/inflections.rb +10 -0
- data/test/rails_root/config/initializers/mime_types.rb +5 -0
- data/test/rails_root/config/initializers/requires.rb +13 -0
- data/test/rails_root/config/initializers/session_store.rb +8 -0
- data/test/rails_root/config/routes.rb +3 -0
- data/test/rails_root/config/solr/README.txt +0 -0
- data/test/rails_root/config/solr/cores/de/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/de/conf/schema.xml +81 -0
- data/test/rails_root/config/solr/cores/de/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/de/conf/stopwords.txt +341 -0
- data/test/rails_root/config/solr/cores/de/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/en/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/en/conf/schema.xml +83 -0
- data/test/rails_root/config/solr/cores/en/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/en/conf/stopwords.txt +341 -0
- data/test/rails_root/config/solr/cores/en/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/es/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/es/conf/schema.xml +81 -0
- data/test/rails_root/config/solr/cores/es/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/es/conf/stopwords.txt +206 -0
- data/test/rails_root/config/solr/cores/es/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/fr/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/fr/conf/schema.xml +82 -0
- data/test/rails_root/config/solr/cores/fr/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/fr/conf/stopwords.txt +57 -0
- data/test/rails_root/config/solr/cores/fr/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/ja/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/ja/conf/schema.xml +69 -0
- data/test/rails_root/config/solr/cores/ja/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/ja/conf/stopwords.txt +341 -0
- data/test/rails_root/config/solr/cores/ja/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/nl/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/nl/conf/schema.xml +78 -0
- data/test/rails_root/config/solr/cores/nl/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/nl/conf/stopwords.txt +45691 -0
- data/test/rails_root/config/solr/cores/nl/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/ru/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/ru/conf/schema.xml +78 -0
- data/test/rails_root/config/solr/cores/ru/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/ru/conf/stopwords.txt +341 -0
- data/test/rails_root/config/solr/cores/ru/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/cores/zh/conf/protwords.txt +21 -0
- data/test/rails_root/config/solr/cores/zh/conf/schema.xml +72 -0
- data/test/rails_root/config/solr/cores/zh/conf/solrconfig.xml +304 -0
- data/test/rails_root/config/solr/cores/zh/conf/stopwords.txt +341 -0
- data/test/rails_root/config/solr/cores/zh/conf/synonyms.txt +31 -0
- data/test/rails_root/config/solr/solr.xml +50 -0
- data/test/rails_root/db/.keep +0 -0
- data/test/rails_root/db/migrate/20090320174818_create_muck_permissions_and_roles.rb +16 -0
- data/test/rails_root/db/migrate/20090602041838_create_users.rb +39 -0
- data/test/rails_root/db/migrate/20090704220055_create_slugs.rb +18 -0
- data/test/rails_root/db/migrate/20090704220120_acts_as_taggable_on_migration.rb +29 -0
- data/test/rails_root/db/migrate/20090717173900_add_contributor_to_feeds.rb +9 -0
- data/test/rails_root/db/schema.rb +166 -0
- data/test/rails_root/features/step_definitions/webrat_steps.rb +99 -0
- data/test/rails_root/features/support/env.rb +14 -0
- data/test/rails_root/migrate/20090602191243_create_muck_raker.rb +307 -0
- data/test/rails_root/migrate/20090619211125_create_tag_clouds.rb +19 -0
- data/test/rails_root/migrate/20090623181458_add_grain_size_to_entries.rb +16 -0
- data/test/rails_root/migrate/20090703175825_denormalize_entries_subjects.rb +16 -0
- data/test/rails_root/public/.htaccess +40 -0
- data/test/rails_root/public/404.html +30 -0
- data/test/rails_root/public/422.html +30 -0
- data/test/rails_root/public/500.html +30 -0
- data/test/rails_root/public/dispatch.rb +10 -0
- data/test/rails_root/public/favicon.ico +0 -0
- data/test/rails_root/public/images/arrow_left.gif +0 -0
- data/test/rails_root/public/images/arrow_right.gif +0 -0
- data/test/rails_root/public/images/blue/preview.gif +0 -0
- data/test/rails_root/public/images/icons/accept.png +0 -0
- data/test/rails_root/public/images/icons/add.png +0 -0
- data/test/rails_root/public/images/icons/delete.png +0 -0
- data/test/rails_root/public/images/icons/vote.png +0 -0
- data/test/rails_root/public/images/loading.gif +0 -0
- data/test/rails_root/public/images/profile_default.jpg +0 -0
- data/test/rails_root/public/images/rails.png +0 -0
- data/test/rails_root/public/images/red/preview.gif +0 -0
- data/test/rails_root/public/images/spinner.gif +0 -0
- data/test/rails_root/public/images/sprites.png +0 -0
- data/test/rails_root/public/javascripts/application.js +2 -0
- data/test/rails_root/public/javascripts/builder.js +136 -0
- data/test/rails_root/public/javascripts/controls.js +963 -0
- data/test/rails_root/public/javascripts/dragdrop.js +972 -0
- data/test/rails_root/public/javascripts/effects.js +1120 -0
- data/test/rails_root/public/javascripts/fancyzoom.min.js +1 -0
- data/test/rails_root/public/javascripts/jquery/jquery-ui.js +273 -0
- data/test/rails_root/public/javascripts/jquery/jquery.form.js +637 -0
- data/test/rails_root/public/javascripts/jquery/jquery.jgrowl.js +2 -0
- data/test/rails_root/public/javascripts/jquery/jquery.js +19 -0
- data/test/rails_root/public/javascripts/jquery/jquery.tips.js +69 -0
- data/test/rails_root/public/javascripts/muck.js +76 -0
- data/test/rails_root/public/javascripts/muck_activities.js +108 -0
- data/test/rails_root/public/javascripts/prototype.js +4225 -0
- data/test/rails_root/public/javascripts/scriptaculous.js +58 -0
- data/test/rails_root/public/javascripts/slider.js +277 -0
- data/test/rails_root/public/javascripts/sound.js +60 -0
- data/test/rails_root/public/robots.txt +1 -0
- data/test/rails_root/public/stylesheets/.keep +0 -0
- data/test/rails_root/public/stylesheets/admin.css +12 -0
- data/test/rails_root/public/stylesheets/blueprint/ie.css +26 -0
- data/test/rails_root/public/stylesheets/blueprint/liquid_screen.css +203 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/buttons/icons/cross.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/buttons/icons/key.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/buttons/icons/tick.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/buttons/readme.txt +32 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/buttons/screen.css +97 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/fancy-type/readme.txt +14 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/fancy-type/screen.css +71 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/doc.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/email.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/external.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/feed.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/im.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/pdf.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/visited.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/icons/xls.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/readme.txt +18 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/link-icons/screen.css +40 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/liquid/liquid.css +134 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/liquid/src/liquid.css +197 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/rtl/readme.txt +10 -0
- data/test/rails_root/public/stylesheets/blueprint/plugins/rtl/screen.css +109 -0
- data/test/rails_root/public/stylesheets/blueprint/print.css +30 -0
- data/test/rails_root/public/stylesheets/blueprint/screen.css +251 -0
- data/test/rails_root/public/stylesheets/blueprint/sprite.css +1 -0
- data/test/rails_root/public/stylesheets/blueprint/src/forms.css +49 -0
- data/test/rails_root/public/stylesheets/blueprint/src/grid.css +213 -0
- data/test/rails_root/public/stylesheets/blueprint/src/grid.png +0 -0
- data/test/rails_root/public/stylesheets/blueprint/src/ie.css +59 -0
- data/test/rails_root/public/stylesheets/blueprint/src/print.css +85 -0
- data/test/rails_root/public/stylesheets/blueprint/src/reset.css +38 -0
- data/test/rails_root/public/stylesheets/blueprint/src/typography.css +105 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_diagonals-small_0_aaaaaa_40x40.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_diagonals-thick_15_444444_40x40.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_glass_100_f0f0f0_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_glass_50_99c2ff_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_glass_55_fbf5d0_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_glass_80_e6e6e6_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_highlight-hard_100_f9f9f9_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-bg_highlight-soft_100_e7eef3_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_222222_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_2694e8_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_2e83ff_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_72a7cf_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_888888_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_cd0a0a_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/images/ui-icons_ffffff_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/cupertino/jquery-ui-1.7.1.custom.css +404 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_flat_55_fbec88_40x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_glass_75_d0e5f5_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_glass_85_dfeffc_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_gloss-wave_55_5c9ccc_500x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_inset-hard_100_f5f8f9_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-bg_inset-hard_100_fcfdfd_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_217bc0_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_2e83ff_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_469bdd_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_6da8d5_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_cd0a0a_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_d8e7f3_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/images/ui-icons_f9bd01_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/redmond/jquery-ui-1.7.1.custom.css +404 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_flat_0_aaaaaa_40x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_flat_75_ffffff_40x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_glass_55_fbf9ee_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_glass_75_dadada_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_glass_75_e6e6e6_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_glass_95_fef1ec_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-bg_highlight-soft_75_cccccc_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-icons_222222_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-icons_2e83ff_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-icons_454545_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-icons_888888_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/images/ui-icons_cd0a0a_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/smoothness/jquery-ui-1.7.1.custom.css +404 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_diagonals-thick_18_b81900_40x40.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_diagonals-thick_20_666666_40x40.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_flat_10_000000_40x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_glass_100_f6f6f6_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_glass_100_fdf5ce_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_gloss-wave_35_f6a828_500x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_highlight-soft_100_eeeeee_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-bg_highlight-soft_75_ffe45c_1x100.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-icons_222222_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-icons_228ef1_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-icons_ef8c08_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-icons_ffd27a_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/images/ui-icons_ffffff_256x240.png +0 -0
- data/test/rails_root/public/stylesheets/jquery/ui-lightness/jquery-ui-1.7.1.custom.css +404 -0
- data/test/rails_root/public/stylesheets/reset.css +0 -0
- data/test/rails_root/public/stylesheets/styles.css +79 -0
- data/test/rails_root/public/stylesheets/themes/blue/styles.css +1 -0
- data/test/rails_root/public/stylesheets/themes/red/styles.css +1 -0
- data/test/rails_root/script/about +3 -0
- data/test/rails_root/script/breakpointer +3 -0
- data/test/rails_root/script/console +3 -0
- data/test/rails_root/script/create_project.rb +52 -0
- data/test/rails_root/script/cucumber +7 -0
- data/test/rails_root/script/dbconsole +3 -0
- data/test/rails_root/script/destroy +3 -0
- data/test/rails_root/script/generate +3 -0
- data/test/rails_root/script/performance/benchmarker +3 -0
- data/test/rails_root/script/performance/profiler +3 -0
- data/test/rails_root/script/performance/request +3 -0
- data/test/rails_root/script/plugin +3 -0
- data/test/rails_root/script/process/inspector +3 -0
- data/test/rails_root/script/process/reaper +3 -0
- data/test/rails_root/script/process/spawner +3 -0
- data/test/rails_root/script/runner +3 -0
- data/test/rails_root/script/server +3 -0
- data/test/rails_root/test/factories.rb +96 -0
- data/test/rails_root/test/functional/.keep +0 -0
- data/test/rails_root/test/functional/feeds_controller_test.rb +14 -0
- data/test/rails_root/test/integration/.keep +0 -0
- data/test/rails_root/test/mocks/development/.keep +0 -0
- data/test/rails_root/test/mocks/test/.keep +0 -0
- data/test/rails_root/test/shoulda_macros/controller.rb +45 -0
- data/test/rails_root/test/shoulda_macros/forms.rb +32 -0
- data/test/rails_root/test/shoulda_macros/models.rb +50 -0
- data/test/rails_root/test/shoulda_macros/pagination.rb +53 -0
- data/test/rails_root/test/shoulda_macros/plugins.rb +34 -0
- data/test/rails_root/test/test_helper.rb +46 -0
- data/test/rails_root/test/unit/.keep +0 -0
- data/test/rails_root/test/unit/entry_test.rb +13 -0
- data/test/rails_root/test/unit/feed_test.rb +16 -0
- data/test/rails_root/test/unit/tag_cloud_test.rb +35 -0
- data/test/rails_root/vendor/plugins/ssl_requirement/README +43 -0
- data/test/rails_root/vendor/plugins/ssl_requirement/lib/ssl_requirement.rb +62 -0
- data/test/rails_root/vendor/plugins/ssl_requirement/test/ssl_requirement_test.rb +132 -0
- data/test/rails_root/vendor/plugins/validation_reflection/CHANGELOG +24 -0
- data/test/rails_root/vendor/plugins/validation_reflection/LICENSE +20 -0
- data/test/rails_root/vendor/plugins/validation_reflection/README +64 -0
- data/test/rails_root/vendor/plugins/validation_reflection/Rakefile +22 -0
- data/test/rails_root/vendor/plugins/validation_reflection/about.yml +7 -0
- data/test/rails_root/vendor/plugins/validation_reflection/init.rb +8 -0
- data/test/rails_root/vendor/plugins/validation_reflection/lib/boiler_plate/validation_reflection.rb +129 -0
- data/test/rails_root/vendor/plugins/validation_reflection/test/test_helper.rb +36 -0
- data/test/rails_root/vendor/plugins/validation_reflection/test/validation_reflection_test.rb +126 -0
- metadata +315 -7
- data/app/models/user.rb +0 -36
- data/test/recommender_test.rb +0 -8
- data/test/test_helper.rb +0 -20
@@ -0,0 +1,96 @@
|
|
1
|
+
Factory.sequence :email do |n|
|
2
|
+
"somebody#{n}@example.com"
|
3
|
+
end
|
4
|
+
|
5
|
+
Factory.sequence :uri do |n|
|
6
|
+
"www#{n}.example.com"
|
7
|
+
end
|
8
|
+
|
9
|
+
Factory.sequence :login do |n|
|
10
|
+
"inquire#{n}"
|
11
|
+
end
|
12
|
+
|
13
|
+
Factory.sequence :name do |n|
|
14
|
+
"a_name#{n}"
|
15
|
+
end
|
16
|
+
|
17
|
+
Factory.sequence :abbr do |n|
|
18
|
+
"abbr#{n}"
|
19
|
+
end
|
20
|
+
|
21
|
+
Factory.sequence :locale do |n|
|
22
|
+
"a#{n}"
|
23
|
+
end
|
24
|
+
|
25
|
+
Factory.sequence :description do |n|
|
26
|
+
"This is the description: #{n}"
|
27
|
+
end
|
28
|
+
|
29
|
+
Factory.sequence :title do |n|
|
30
|
+
"This is the title: #{n}"
|
31
|
+
end
|
32
|
+
|
33
|
+
Factory.define :state do |f|
|
34
|
+
f.name { Factory.next(:name) }
|
35
|
+
f.abbreviation { Factory.next(:abbr) }
|
36
|
+
f.country {|a| a.association(:country) }
|
37
|
+
end
|
38
|
+
|
39
|
+
Factory.define :country do |f|
|
40
|
+
f.name { Factory.next(:name) }
|
41
|
+
f.abbreviation { Factory.next(:abbr) }
|
42
|
+
end
|
43
|
+
|
44
|
+
Factory.define :language do |f|
|
45
|
+
f.name { Factory.next(:name) }
|
46
|
+
f.english_name { Factory.next(:english_name) }
|
47
|
+
f.locale { Factory.next(:locale) }
|
48
|
+
f.supported true
|
49
|
+
f.muck_raker_supported true
|
50
|
+
end
|
51
|
+
|
52
|
+
Factory.define :user do |f|
|
53
|
+
f.login { Factory.next(:login) }
|
54
|
+
f.email { Factory.next(:email) }
|
55
|
+
f.password 'inquire_pass'
|
56
|
+
f.password_confirmation 'inquire_pass'
|
57
|
+
f.first_name 'test'
|
58
|
+
f.last_name 'guy'
|
59
|
+
f.terms_of_service true
|
60
|
+
f.activated_at DateTime.now
|
61
|
+
end
|
62
|
+
|
63
|
+
Factory.define :permission do |f|
|
64
|
+
f.role {|a| a.association(:role)}
|
65
|
+
f.user {|a| a.association(:user)}
|
66
|
+
end
|
67
|
+
|
68
|
+
Factory.define :role do |f|
|
69
|
+
f.rolename 'administrator'
|
70
|
+
end
|
71
|
+
|
72
|
+
Factory.define :feed do |f|
|
73
|
+
f.contributor { |a| a.association(:user) }
|
74
|
+
f.uri { Factory.next(:uri) }
|
75
|
+
f.display_uri { Factory.next(:uri) }
|
76
|
+
f.title { Factory.next(:title) }
|
77
|
+
f.short_title { Factory.next(:title) }
|
78
|
+
f.description { Factory.next(:description) }
|
79
|
+
f.top_tags { Factory.next(:name) }
|
80
|
+
f.priority 1
|
81
|
+
f.status 1
|
82
|
+
f.last_requested_at DateTime.now
|
83
|
+
f.last_harvested_at DateTime.now
|
84
|
+
f.harvest_interval 86400
|
85
|
+
f.failed_requests 0
|
86
|
+
f.harvested_from_display_uri { Factory.next(:uri) }
|
87
|
+
f.harvested_from_title { Factory.next(:title) }
|
88
|
+
f.harvested_from_short_title { Factory.next(:title) }
|
89
|
+
f.entries_count 0
|
90
|
+
f.default_language { |a| a.association(:language) }
|
91
|
+
f.default_grain_size 'unknown'
|
92
|
+
end
|
93
|
+
|
94
|
+
Factory.define :entry do |f|
|
95
|
+
end
|
96
|
+
|
File without changes
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
|
3
|
+
class Muck::FeedsControllerTest < ActionController::TestCase
|
4
|
+
|
5
|
+
tests Muck::FeedsController
|
6
|
+
|
7
|
+
context "feeds controller" do
|
8
|
+
setup do
|
9
|
+
@quentin = Factory(:user)
|
10
|
+
@aaron = Factory(:user)
|
11
|
+
end
|
12
|
+
|
13
|
+
end
|
14
|
+
end
|
File without changes
|
File without changes
|
File without changes
|
@@ -0,0 +1,45 @@
|
|
1
|
+
module MuckControllerMacros
|
2
|
+
|
3
|
+
def should_require_login(*args)
|
4
|
+
args = Hash[*args]
|
5
|
+
login_url = args.delete :login_url
|
6
|
+
args.each do |action, verb|
|
7
|
+
should "Require login for '#{action}' action" do
|
8
|
+
send(verb, action)
|
9
|
+
assert_redirected_to(login_url)
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
def should_require_role(role, redirect_url, *actions)
|
15
|
+
actions.each do |action|
|
16
|
+
should "require role for '#{action}' action" do
|
17
|
+
get(action)
|
18
|
+
ensure_flash(/permission/i)
|
19
|
+
assert_response :redirect
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
#from: http://blog.internautdesign.com/2008/9/11/more-on-custom-shoulda-macros-scoping-of-instance-variables
|
25
|
+
def should_not_allow action, object, url= "/login", msg=nil
|
26
|
+
msg ||= "a #{object.class.to_s.downcase}"
|
27
|
+
should "not be able to #{action} #{msg}" do
|
28
|
+
object = eval(object, self.send(:binding), __FILE__, __LINE__)
|
29
|
+
get action, :id => object.id
|
30
|
+
assert_redirected_to url
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def should_allow action, object, msg=nil
|
35
|
+
msg ||= "a #{object.class.to_s.downcase}"
|
36
|
+
should "be able to #{action} #{msg}" do
|
37
|
+
object = eval(object, self.send(:binding), __FILE__, __LINE__)
|
38
|
+
get action, :id => object.id
|
39
|
+
assert_response :success
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
end
|
44
|
+
|
45
|
+
ActionController::TestCase.extend(MuckControllerMacros)
|
@@ -0,0 +1,32 @@
|
|
1
|
+
module ShouldaFormMacros
|
2
|
+
def self.should_have_form(opts)
|
3
|
+
model = self.name.gsub(/ControllerTest$/, '').singularize.downcase
|
4
|
+
model = model[model.rindex('::')+2..model.size] if model.include?('::')
|
5
|
+
http_method, hidden_http_method = form_http_method opts[:method]
|
6
|
+
should "have a #{model} form" do
|
7
|
+
assert_select "form[action=?][method=#{http_method}]", eval(opts[:action]) do
|
8
|
+
if hidden_http_method
|
9
|
+
assert_select "input[type=hidden][name=_method][value=#{hidden_http_method}]"
|
10
|
+
end
|
11
|
+
opts[:fields].each do |attribute, type|
|
12
|
+
attribute = attribute.is_a?(Symbol) ? "#{model}[#{attribute.to_s}]" : attribute
|
13
|
+
assert_select "input[type=#{type.to_s}][name=?]", attribute
|
14
|
+
end
|
15
|
+
assert_select "input[type=submit]"
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def self.form_http_method(http_method)
|
21
|
+
http_method = http_method.nil? ? 'post' : http_method.to_s
|
22
|
+
if http_method == "post" || http_method == "get"
|
23
|
+
return http_method, nil
|
24
|
+
else
|
25
|
+
return "post", http_method
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
class ActiveSupport::TestCase
|
31
|
+
extend ShouldaFormMacros
|
32
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
module ShouldaModelMacros
|
2
|
+
|
3
|
+
def should_sanitize(*attributes)
|
4
|
+
bad_scripts = [
|
5
|
+
%|';alert(String.fromCharCode(88,83,83))//\';alert(String.fromCharCode(88,83,83))//";alert(String.fromCharCode(88,83,83))//\";alert(String.fromCharCode(88,83,83))//--></SCRIPT>">'><SCRIPT>alert(String.fromCharCode(88,83,83))</SCRIPT>|,
|
6
|
+
%|'';!--"<XSS>=&{()}|,
|
7
|
+
%|<SCRIPT SRC=http://ha.ckers.org/xss.js></SCRIPT>|,
|
8
|
+
%|<IMG SRC="javascript:alert('XSS');">|,
|
9
|
+
%|<IMG SRC=javascript:alert('XSS')>|,
|
10
|
+
%|<IMG SRC=JaVaScRiPt:alert('XSS')>|,
|
11
|
+
%|<IMG SRC=JaVaScRiPt:alert('XSS')>|,
|
12
|
+
%|<IMG SRC=`javascript:alert("RSnake says, 'XSS'")`>|,
|
13
|
+
%|<IMG """><SCRIPT>alert("XSS")</SCRIPT>">|,
|
14
|
+
%|<IMG SRC=javascript:alert(String.fromCharCode(88,83,83))>|,
|
15
|
+
%|<A HREF="h
|
16
|
+
tt p://6	6.000146.0x7.147/">XSS</A>|,
|
17
|
+
%|<script>alert('message');</script>| ]
|
18
|
+
|
19
|
+
klass = model_class
|
20
|
+
attributes.each do |attribute|
|
21
|
+
attribute = attribute.to_sym
|
22
|
+
should "white list #{attribute}" do
|
23
|
+
assert object = klass.find(:first), "Can't find first #{klass}"
|
24
|
+
bad_scripts.each do |bad_value|
|
25
|
+
object.send("#{attribute}=", bad_value)
|
26
|
+
object.save
|
27
|
+
clean_value = object.send("#{attribute}")
|
28
|
+
assert !clean_value.include?(bad_value), "#{attribute} is not white listed. #{bad_value} made it through"
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def should_accept_nested_attributes_for(*attr_names)
|
35
|
+
klass = self.name.gsub(/Test$/, '').constantize
|
36
|
+
|
37
|
+
context "#{klass}" do
|
38
|
+
attr_names.each do |association_name|
|
39
|
+
should "accept nested attrs for #{association_name}" do
|
40
|
+
assert klass.instance_methods.include?("#{association_name}_attributes="),
|
41
|
+
"#{klass} does not accept nested attributes for #{association_name}"
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
class ActiveSupport::TestCase
|
49
|
+
extend ShouldaModelMacros
|
50
|
+
end
|
@@ -0,0 +1,53 @@
|
|
1
|
+
module ShouldaPaginationMacros
|
2
|
+
# Example:
|
3
|
+
# context "a GET to index logged in as admin" do
|
4
|
+
# setup do
|
5
|
+
# login_as_admin
|
6
|
+
# get :index
|
7
|
+
# end
|
8
|
+
# should_paginate_collection :users
|
9
|
+
# should_display_pagination
|
10
|
+
# end
|
11
|
+
def self.should_paginate_collection(collection_name)
|
12
|
+
should "paginate #{collection_name}" do
|
13
|
+
assert collection = assigns(collection_name),
|
14
|
+
"Controller isn't assigning to @#{collection_name.to_s}."
|
15
|
+
assert_kind_of WillPaginate::Collection, collection,
|
16
|
+
"@#{collection_name.to_s} isn't a WillPaginate collection."
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def self.should_display_pagination
|
21
|
+
should "display pagination" do
|
22
|
+
assert_select "div.pagination", { :minimum => 1 },
|
23
|
+
"View isn't displaying pagination. Add <%= will_paginate @collection %>."
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
# Example:
|
28
|
+
# context "a GET to index not logged in as admin" do
|
29
|
+
# setup { get :index }
|
30
|
+
# should_not_paginate_collection :users
|
31
|
+
# should_not_display_pagination
|
32
|
+
# end
|
33
|
+
def self.should_not_paginate_collection(collection_name)
|
34
|
+
should "not paginate #{collection_name}" do
|
35
|
+
assert collection = assigns(collection_name),
|
36
|
+
"Controller isn't assigning to @#{collection_name.to_s}."
|
37
|
+
assert_not_equal WillPaginate::Collection, collection.class,
|
38
|
+
"@#{collection_name.to_s} is a WillPaginate collection."
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
def self.should_not_display_pagination
|
43
|
+
should "not display pagination" do
|
44
|
+
assert_select "div.pagination", { :count => 0 },
|
45
|
+
"View is displaying pagination. Check your logic."
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
|
51
|
+
class ActiveSupport::TestCase
|
52
|
+
extend ShouldaPaginationMacros
|
53
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module ShouldaPluginMacros
|
2
|
+
|
3
|
+
def self.should_act_as_taggable_on_steroids
|
4
|
+
klass = self.name.gsub(/Test$/, '').constantize
|
5
|
+
|
6
|
+
should "include ActsAsTaggableOnSteroids methods" do
|
7
|
+
assert klass.extended_by.include?(ActiveRecord::Acts::Taggable::ClassMethods)
|
8
|
+
assert klass.extended_by.include?(ActiveRecord::Acts::Taggable::SingletonMethods)
|
9
|
+
assert klass.include?(ActiveRecord::Acts::Taggable::InstanceMethods)
|
10
|
+
end
|
11
|
+
|
12
|
+
should_have_many :taggings, :tags
|
13
|
+
end
|
14
|
+
|
15
|
+
|
16
|
+
def self.should_act_as_list
|
17
|
+
klass = self.name.gsub(/Test$/, '').constantize
|
18
|
+
|
19
|
+
context "To support acts_as_list" do
|
20
|
+
should_have_db_column('position', :type => :integer)
|
21
|
+
end
|
22
|
+
|
23
|
+
should "include ActsAsList methods" do
|
24
|
+
assert klass.include?(ActiveRecord::Acts::List::InstanceMethods)
|
25
|
+
end
|
26
|
+
|
27
|
+
should_have_instance_methods :acts_as_list_class, :position_column, :scope_condition
|
28
|
+
end
|
29
|
+
|
30
|
+
end
|
31
|
+
|
32
|
+
ActiveSupport::TestCase.extend(ShouldaPluginMacros)
|
33
|
+
Test::Unit::TestCase.extend(ShouldaPluginMacros)
|
34
|
+
ActionController::TestCase.extend(ShouldaPluginMacros)
|
@@ -0,0 +1,46 @@
|
|
1
|
+
$:.reject! { |e| e.include? 'TextMate' }
|
2
|
+
ENV["RAILS_ENV"] = "test"
|
3
|
+
require File.expand_path(File.dirname(__FILE__) + "/../config/environment")
|
4
|
+
require 'test_help'
|
5
|
+
require 'ruby-debug'
|
6
|
+
gem 'thoughtbot-factory_girl' # from github
|
7
|
+
require 'factory_girl'
|
8
|
+
require 'mocha'
|
9
|
+
require 'authlogic/test_case'
|
10
|
+
require 'redgreen' rescue LoadError
|
11
|
+
require File.expand_path(File.dirname(__FILE__) + '/factories')
|
12
|
+
require File.join(File.dirname(__FILE__), 'shoulda_macros', 'controller')
|
13
|
+
require File.join(File.dirname(__FILE__), 'shoulda_macros', 'models')
|
14
|
+
|
15
|
+
class ActiveSupport::TestCase
|
16
|
+
self.use_transactional_fixtures = true
|
17
|
+
self.use_instantiated_fixtures = false
|
18
|
+
|
19
|
+
include Authlogic::TestCase
|
20
|
+
|
21
|
+
def login_as(user)
|
22
|
+
success = UserSession.create(user)
|
23
|
+
if !success
|
24
|
+
errors = user.errors.full_messages.to_sentence
|
25
|
+
message = 'User has not been activated' if !user.active?
|
26
|
+
raise "could not login as #{user.to_param}. Please make sure the user is valid. #{message} #{errors}"
|
27
|
+
end
|
28
|
+
UserSession.find
|
29
|
+
end
|
30
|
+
|
31
|
+
def assure_logout
|
32
|
+
user_session = UserSession.find
|
33
|
+
user_session.destroy if user_session
|
34
|
+
end
|
35
|
+
|
36
|
+
def ensure_flash(val)
|
37
|
+
assert_contains flash.values, val, ", Flash: #{flash.inspect}"
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
# turn off solr for tests
|
42
|
+
class ActsAsSolr::Post
|
43
|
+
def self.execute(request)
|
44
|
+
true
|
45
|
+
end
|
46
|
+
end
|
File without changes
|
@@ -0,0 +1,16 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
|
3
|
+
# Used to test muck_content_permission
|
4
|
+
class FeedTest < ActiveSupport::TestCase
|
5
|
+
|
6
|
+
context "A feed instance" do
|
7
|
+
setup do
|
8
|
+
@feed = Factory(:feed)
|
9
|
+
end
|
10
|
+
|
11
|
+
should_have_many :entries
|
12
|
+
should_belong_to :contributor
|
13
|
+
|
14
|
+
end
|
15
|
+
|
16
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
require File.dirname(__FILE__) + '/../test_helper'
|
2
|
+
|
3
|
+
# Used to test muck_content_translation
|
4
|
+
class ContentTranslationTest < ActiveSupport::TestCase
|
5
|
+
|
6
|
+
context "A content translation instance" do
|
7
|
+
should_belong_to :content
|
8
|
+
should_have_named_scope :by_newest
|
9
|
+
should_have_named_scope :recent
|
10
|
+
should_have_named_scope :by_alpha
|
11
|
+
should_have_named_scope :by_locale
|
12
|
+
end
|
13
|
+
|
14
|
+
context "find by locale" do
|
15
|
+
setup do
|
16
|
+
ContentTranslation.destroy_all
|
17
|
+
@content_one = Factory(:content)
|
18
|
+
@content_two = Factory(:content)
|
19
|
+
end
|
20
|
+
should "find two English translations" do
|
21
|
+
translations = ContentTranslation.by_locale('en')
|
22
|
+
assert_equal 2, translations.length
|
23
|
+
end
|
24
|
+
should "find two Spanish translations" do
|
25
|
+
translations = ContentTranslation.by_locale('es')
|
26
|
+
assert_equal 2, translations.length
|
27
|
+
end
|
28
|
+
should "delete translations" do
|
29
|
+
assert_difference "ContentTranslation.count", -(@content_two.content_translations.count) do
|
30
|
+
@content_two.destroy
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
SSL Requirement
|
2
|
+
===============
|
3
|
+
|
4
|
+
SSL requirement adds a declarative way of specifying that certain actions
|
5
|
+
should only be allowed to run under SSL, and if they're accessed without it,
|
6
|
+
they should be redirected.
|
7
|
+
|
8
|
+
Example:
|
9
|
+
|
10
|
+
class ApplicationController < ActiveRecord::Base
|
11
|
+
include SslRequirement
|
12
|
+
end
|
13
|
+
|
14
|
+
class AccountController < ApplicationController
|
15
|
+
ssl_required :signup, :payment
|
16
|
+
ssl_allowed :index
|
17
|
+
|
18
|
+
def signup
|
19
|
+
# Non-SSL access will be redirected to SSL
|
20
|
+
end
|
21
|
+
|
22
|
+
def payment
|
23
|
+
# Non-SSL access will be redirected to SSL
|
24
|
+
end
|
25
|
+
|
26
|
+
def index
|
27
|
+
# This action will work either with or without SSL
|
28
|
+
end
|
29
|
+
|
30
|
+
def other
|
31
|
+
# SSL access will be redirected to non-SSL
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
You can overwrite the protected method ssl_required? to rely on other things
|
36
|
+
than just the declarative specification. Say, only premium accounts get SSL.
|
37
|
+
|
38
|
+
P.S.: Beware when you include the SslRequirement module. At the time of
|
39
|
+
inclusion, it'll add the before_filter that validates the declarations. Some
|
40
|
+
times you'll want to run other before_filters before that. They should then be
|
41
|
+
declared ahead of including this module.
|
42
|
+
|
43
|
+
Copyright (c) 2005 David Heinemeier Hansson, released under the MIT license
|
@@ -0,0 +1,62 @@
|
|
1
|
+
# Copyright (c) 2005 David Heinemeier Hansson
|
2
|
+
#
|
3
|
+
# Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
# a copy of this software and associated documentation files (the
|
5
|
+
# "Software"), to deal in the Software without restriction, including
|
6
|
+
# without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
# distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
# permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
# the following conditions:
|
10
|
+
#
|
11
|
+
# The above copyright notice and this permission notice shall be
|
12
|
+
# included in all copies or substantial portions of the Software.
|
13
|
+
#
|
14
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
21
|
+
module SslRequirement
|
22
|
+
def self.included(controller)
|
23
|
+
controller.extend(ClassMethods)
|
24
|
+
controller.before_filter(:ensure_proper_protocol)
|
25
|
+
end
|
26
|
+
|
27
|
+
module ClassMethods
|
28
|
+
# Specifies that the named actions requires an SSL connection to be performed (which is enforced by ensure_proper_protocol).
|
29
|
+
def ssl_required(*actions)
|
30
|
+
write_inheritable_array(:ssl_required_actions, actions)
|
31
|
+
end
|
32
|
+
|
33
|
+
def ssl_allowed(*actions)
|
34
|
+
write_inheritable_array(:ssl_allowed_actions, actions)
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
protected
|
39
|
+
# Returns true if the current action is supposed to run as SSL
|
40
|
+
def ssl_required?
|
41
|
+
(self.class.read_inheritable_attribute(:ssl_required_actions) || []).include?(action_name.to_sym)
|
42
|
+
end
|
43
|
+
|
44
|
+
def ssl_allowed?
|
45
|
+
(self.class.read_inheritable_attribute(:ssl_allowed_actions) || []).include?(action_name.to_sym)
|
46
|
+
end
|
47
|
+
|
48
|
+
private
|
49
|
+
def ensure_proper_protocol
|
50
|
+
return true if ssl_allowed?
|
51
|
+
|
52
|
+
if ssl_required? && !request.ssl?
|
53
|
+
redirect_to "https://" + request.host + request.request_uri
|
54
|
+
flash.keep
|
55
|
+
return false
|
56
|
+
elsif request.ssl? && !ssl_required?
|
57
|
+
redirect_to "http://" + request.host + request.request_uri
|
58
|
+
flash.keep
|
59
|
+
return false
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,132 @@
|
|
1
|
+
begin
|
2
|
+
require 'action_controller'
|
3
|
+
rescue LoadError
|
4
|
+
if ENV['ACTIONCONTROLLER_PATH'].nil?
|
5
|
+
abort <<MSG
|
6
|
+
Please set the ACTIONCONTROLLER_PATH environment variable to the directory
|
7
|
+
containing the action_controller.rb file.
|
8
|
+
MSG
|
9
|
+
else
|
10
|
+
$LOAD_PATH.unshift << ENV['ACTIONCONTROLLER_PATH']
|
11
|
+
begin
|
12
|
+
require 'action_controller'
|
13
|
+
rescue LoadError
|
14
|
+
abort "ActionController could not be found."
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
require 'action_controller/test_process'
|
20
|
+
require 'test/unit'
|
21
|
+
require "#{File.dirname(__FILE__)}/../lib/ssl_requirement"
|
22
|
+
|
23
|
+
ActionController::Base.logger = nil
|
24
|
+
ActionController::Routing::Routes.reload rescue nil
|
25
|
+
|
26
|
+
class SslRequirementController < ActionController::Base
|
27
|
+
include SslRequirement
|
28
|
+
|
29
|
+
ssl_required :a, :b
|
30
|
+
ssl_allowed :c
|
31
|
+
|
32
|
+
def a
|
33
|
+
render :nothing => true
|
34
|
+
end
|
35
|
+
|
36
|
+
def b
|
37
|
+
render :nothing => true
|
38
|
+
end
|
39
|
+
|
40
|
+
def c
|
41
|
+
render :nothing => true
|
42
|
+
end
|
43
|
+
|
44
|
+
def d
|
45
|
+
render :nothing => true
|
46
|
+
end
|
47
|
+
|
48
|
+
def set_flash
|
49
|
+
flash[:foo] = "bar"
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
class SslRequirementTest < Test::Unit::TestCase
|
54
|
+
def setup
|
55
|
+
@controller = SslRequirementController.new
|
56
|
+
@request = ActionController::TestRequest.new
|
57
|
+
@response = ActionController::TestResponse.new
|
58
|
+
end
|
59
|
+
|
60
|
+
def test_redirect_to_https_preserves_flash
|
61
|
+
get :set_flash
|
62
|
+
get :b
|
63
|
+
assert_response :redirect
|
64
|
+
assert_equal "bar", flash[:foo]
|
65
|
+
end
|
66
|
+
|
67
|
+
def test_not_redirecting_to_https_does_not_preserve_the_flash
|
68
|
+
get :set_flash
|
69
|
+
get :d
|
70
|
+
assert_response :success
|
71
|
+
assert_nil flash[:foo]
|
72
|
+
end
|
73
|
+
|
74
|
+
def test_redirect_to_http_preserves_flash
|
75
|
+
get :set_flash
|
76
|
+
@request.env['HTTPS'] = "on"
|
77
|
+
get :d
|
78
|
+
assert_response :redirect
|
79
|
+
assert_equal "bar", flash[:foo]
|
80
|
+
end
|
81
|
+
|
82
|
+
def test_not_redirecting_to_http_does_not_preserve_the_flash
|
83
|
+
get :set_flash
|
84
|
+
@request.env['HTTPS'] = "on"
|
85
|
+
get :a
|
86
|
+
assert_response :success
|
87
|
+
assert_nil flash[:foo]
|
88
|
+
end
|
89
|
+
|
90
|
+
def test_required_without_ssl
|
91
|
+
assert_not_equal "on", @request.env["HTTPS"]
|
92
|
+
get :a
|
93
|
+
assert_response :redirect
|
94
|
+
assert_match %r{^https://}, @response.headers['Location']
|
95
|
+
get :b
|
96
|
+
assert_response :redirect
|
97
|
+
assert_match %r{^https://}, @response.headers['Location']
|
98
|
+
end
|
99
|
+
|
100
|
+
def test_required_with_ssl
|
101
|
+
@request.env['HTTPS'] = "on"
|
102
|
+
get :a
|
103
|
+
assert_response :success
|
104
|
+
get :b
|
105
|
+
assert_response :success
|
106
|
+
end
|
107
|
+
|
108
|
+
def test_disallowed_without_ssl
|
109
|
+
assert_not_equal "on", @request.env["HTTPS"]
|
110
|
+
get :d
|
111
|
+
assert_response :success
|
112
|
+
end
|
113
|
+
|
114
|
+
def test_disallowed_with_ssl
|
115
|
+
@request.env['HTTPS'] = "on"
|
116
|
+
get :d
|
117
|
+
assert_response :redirect
|
118
|
+
assert_match %r{^http://}, @response.headers['Location']
|
119
|
+
end
|
120
|
+
|
121
|
+
def test_allowed_without_ssl
|
122
|
+
assert_not_equal "on", @request.env["HTTPS"]
|
123
|
+
get :c
|
124
|
+
assert_response :success
|
125
|
+
end
|
126
|
+
|
127
|
+
def test_allowed_with_ssl
|
128
|
+
@request.env['HTTPS'] = "on"
|
129
|
+
get :c
|
130
|
+
assert_response :success
|
131
|
+
end
|
132
|
+
end
|