radiant 0.8.2 → 0.9.0.rc2
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of radiant might be problematic. Click here for more details.
- data/CHANGELOG +258 -389
- data/CONTRIBUTORS +21 -0
- data/app/controllers/admin/layouts_controller.rb +2 -8
- data/app/controllers/admin/pages_controller.rb +0 -19
- data/app/controllers/admin/preferences_controller.rb +3 -4
- data/app/controllers/admin/references_controller.rb +1 -1
- data/app/controllers/admin/resource_controller.rb +11 -10
- data/app/controllers/admin/snippets_controller.rb +5 -6
- data/app/controllers/admin/users_controller.rb +15 -1
- data/app/controllers/admin/welcome_controller.rb +5 -5
- data/app/controllers/application_controller.rb +34 -2
- data/app/controllers/site_controller.rb +20 -6
- data/app/helpers/admin/layouts_helper.rb +19 -0
- data/app/helpers/admin/node_helper.rb +10 -10
- data/app/helpers/admin/pages_helper.rb +82 -22
- data/app/helpers/admin/references_helper.rb +6 -3
- data/app/helpers/admin/snippets_helper.rb +39 -0
- data/app/helpers/admin/users_helper.rb +2 -2
- data/app/helpers/application_helper.rb +93 -27
- data/app/models/layout.rb +3 -4
- data/app/models/page.rb +35 -20
- data/app/models/page_part.rb +4 -4
- data/app/models/radiant/config.rb +11 -7
- data/app/models/snippet.rb +5 -5
- data/app/models/standard_tags.rb +116 -20
- data/app/models/status.rb +3 -1
- data/app/models/user.rb +37 -33
- data/app/views/admin/extensions/index.html.haml +26 -25
- data/app/views/admin/layouts/_form.html.haml +26 -23
- data/app/views/admin/layouts/edit.html.haml +5 -3
- data/app/views/admin/layouts/index.html.haml +31 -32
- data/app/views/admin/layouts/new.html.haml +4 -2
- data/app/views/admin/layouts/remove.html.haml +9 -9
- data/app/views/admin/page_parts/_page_part.html.haml +11 -10
- data/app/views/admin/pages/_fields.html.haml +42 -48
- data/app/views/admin/pages/_meta_row.html.haml +2 -4
- data/app/views/admin/pages/_node.html.haml +5 -5
- data/app/views/admin/pages/_popups.html.haml +12 -29
- data/app/views/admin/pages/edit.html.haml +6 -3
- data/app/views/admin/pages/index.html.haml +22 -24
- data/app/views/admin/pages/new.html.haml +4 -3
- data/app/views/admin/pages/remove.html.haml +14 -17
- data/app/views/admin/preferences/edit.html.haml +36 -28
- data/app/views/admin/references/_tag_reference.haml +2 -2
- data/app/views/admin/references/filters.haml +6 -0
- data/app/views/admin/references/tags.haml +30 -0
- data/app/views/admin/snippets/_form.html.haml +22 -18
- data/app/views/admin/snippets/edit.html.haml +6 -2
- data/app/views/admin/snippets/index.html.haml +29 -29
- data/app/views/admin/snippets/new.html.haml +4 -2
- data/app/views/admin/snippets/remove.html.haml +9 -11
- data/app/views/admin/users/_avatar.html.haml +3 -0
- data/app/views/admin/users/_form.html.haml +47 -67
- data/app/views/admin/users/_password_fields.html.haml +18 -0
- data/app/views/admin/users/edit.html.haml +5 -1
- data/app/views/admin/users/index.html.haml +33 -30
- data/app/views/admin/users/new.html.haml +2 -1
- data/app/views/admin/users/remove.html.haml +8 -10
- data/app/views/admin/welcome/login.html.haml +19 -58
- data/app/views/layouts/application.html.haml +30 -29
- data/config/boot.rb +1 -1
- data/config/cucumber.yml +7 -0
- data/config/database.db2.yml +4 -1
- data/config/database.mysql.yml +5 -2
- data/config/database.postgresql.yml +5 -2
- data/config/database.sqlite.yml +4 -1
- data/config/database.sqlserver.yml +5 -2
- data/config/environment.rb +14 -2
- data/config/environments/cucumber.rb +29 -0
- data/config/environments/production.rb +6 -1
- data/config/environments/test.rb +6 -3
- data/config/initializers/haml.rb +2 -0
- data/config/initializers/pagination.rb +1 -0
- data/config/locales/en.yml +190 -0
- data/config/locales/en_available_tags.yml +454 -0
- data/config/routes.rb +2 -2
- data/db/migrate/20090226140109_add_user_language.rb +9 -0
- data/db/migrate/20090929164633_rename_developer_role_to_designer.rb +9 -0
- data/db/migrate/20091003095744_change_user_language_to_locale.rb +9 -0
- data/db/schema.rb +3 -2
- data/features/admin/content_negotiation.feature +4 -4
- data/features/admin/layouts_management.feature +2 -2
- data/features/admin/pages_management.feature +31 -17
- data/features/admin/snippets_management.feature +19 -17
- data/features/admin/user_permissions.feature +49 -41
- data/features/admin/user_preferences.feature +6 -6
- data/features/admin/users_management.feature +8 -9
- data/features/page_serving.feature +8 -8
- data/features/step_definitions/admin/admin_steps.rb +8 -2
- data/features/step_definitions/admin/content_negotiation_steps.rb +14 -5
- data/features/step_definitions/admin/pages_management_steps.rb +1 -1
- data/features/step_definitions/admin/users_management_steps.rb +3 -0
- data/features/step_definitions/page_serving_steps.rb +0 -19
- data/features/step_definitions/web_steps.rb +263 -0
- data/features/support/dataset.rb +9 -0
- data/features/support/env.rb +44 -14
- data/features/support/paths.rb +57 -12
- data/lib/generators/extension/extension_generator.rb +29 -1
- data/lib/generators/extension/templates/RSpecRakefile +14 -1
- data/lib/generators/extension/templates/Rakefile +17 -0
- data/lib/generators/extension/templates/en.yml +3 -0
- data/lib/generators/extension/templates/extension.rb +10 -10
- data/lib/generators/extension/templates/routes.rb +5 -0
- data/lib/generators/extension/templates/tasks.rake +27 -0
- data/lib/generators/extension/templates/test_helper.rb +1 -1
- data/lib/generators/instance/instance_generator.rb +3 -2
- data/lib/generators/instance/templates/databases/sqlserver.yml +2 -1
- data/lib/generators/instance/templates/instance_boot.rb +1 -1
- data/lib/generators/instance/templates/instance_environment.rb +8 -1
- data/lib/generators/language_extension/USAGE +27 -0
- data/lib/generators/language_extension/language_extension_generator.rb +49 -0
- data/lib/generators/language_extension/templates/README +3 -0
- data/lib/generators/language_extension/templates/RSpecRakefile +123 -0
- data/lib/generators/language_extension/templates/Rakefile +25 -0
- data/lib/generators/language_extension/templates/available_tags.yml +553 -0
- data/lib/generators/language_extension/templates/cucumber.yml +1 -0
- data/lib/generators/language_extension/templates/cucumber_env.rb +16 -0
- data/lib/generators/language_extension/templates/cucumber_paths.rb +14 -0
- data/lib/generators/language_extension/templates/extension.rb +8 -0
- data/lib/generators/language_extension/templates/functional_test.rb +15 -0
- data/lib/generators/language_extension/templates/lang.yml +181 -0
- data/lib/generators/language_extension/templates/spec.opts +6 -0
- data/lib/generators/language_extension/templates/spec_helper.rb +36 -0
- data/lib/generators/language_extension/templates/tasks.rake +28 -0
- data/lib/generators/language_extension/templates/test_helper.rb +26 -0
- data/lib/login_system.rb +14 -17
- data/lib/radiant.rb +4 -3
- data/lib/radiant/admin_ui.rb +114 -58
- data/lib/radiant/available_locales.rb +31 -0
- data/lib/radiant/cache.rb +12 -0
- data/lib/radiant/extension.rb +29 -3
- data/lib/radiant/extension/script.rb +44 -13
- data/lib/radiant/extension_loader.rb +21 -7
- data/lib/radiant/initializer.rb +23 -23
- data/lib/radiant/pagination/link_renderer.rb +31 -0
- data/lib/radiant/setup.rb +1 -0
- data/lib/radiant/taggable.rb +2 -1
- data/lib/task_support.rb +21 -1
- data/lib/tasks/ci.rake +17 -0
- data/lib/tasks/cucumber.rake +39 -13
- data/lib/tasks/extensions.rake +12 -1
- data/lib/tasks/framework.rake +44 -8
- data/lib/tasks/prototype.rake +34 -0
- data/lib/tasks/release.rake +6 -4
- data/lib/tasks/rspec.rake +7 -7
- data/lib/tasks/translate.rake +59 -0
- data/lib/tasks/undefine.rake +4 -0
- data/lib/translation_support.rb +54 -0
- data/public/images/admin/add_tab.png +0 -0
- data/public/images/admin/avatar_32x32.png +0 -0
- data/public/images/admin/avatar_96x96.png +0 -0
- data/public/images/admin/{brown-bottom-line.gif → brown_bottom_line.gif} +0 -0
- data/public/images/admin/buttons_background.png +0 -0
- data/public/images/admin/calendar_down.gif +0 -0
- data/public/images/admin/collapse.png +0 -0
- data/public/images/admin/draft_page.png +0 -0
- data/public/images/admin/expand.png +0 -0
- data/public/images/admin/layout.png +0 -0
- data/public/images/admin/login_shadow.png +0 -0
- data/public/images/admin/metadata_toggle.png +0 -0
- data/public/images/admin/minus_disabled.png +0 -0
- data/public/images/admin/minus_grey.png +0 -0
- data/public/images/admin/navigation_background.gif +0 -0
- data/public/images/admin/navigation_secondary_background.png +0 -0
- data/public/images/admin/navigation_secondary_separator.gif +0 -0
- data/public/images/admin/navigation_shadow.png +0 -0
- data/public/images/admin/navigation_tabs.png +0 -0
- data/public/images/admin/{new-homepage.png → new_homepage.png} +0 -0
- data/public/images/admin/{new-layout.png → new_layout.png} +0 -0
- data/public/images/admin/{new-snippet.png → new_snippet.png} +0 -0
- data/public/images/admin/{new-user.png → new_user.png} +0 -0
- data/public/images/admin/page.png +0 -0
- data/public/images/admin/plus_grey.png +0 -0
- data/public/images/admin/popup_border_background.png +0 -0
- data/public/images/admin/popup_border_bottom_left.png +0 -0
- data/public/images/admin/popup_border_bottom_right.png +0 -0
- data/public/images/admin/popup_border_top_left.png +0 -0
- data/public/images/admin/popup_border_top_right.png +0 -0
- data/public/images/admin/single_form_shadow.png +0 -0
- data/public/images/admin/snippet.png +0 -0
- data/public/images/admin/spacer.gif +0 -0
- data/public/images/admin/status_background.png +0 -0
- data/public/images/admin/status_bottom_left.png +0 -0
- data/public/images/admin/status_bottom_right.png +0 -0
- data/public/images/admin/status_spinner.gif +0 -0
- data/public/images/admin/status_top_left.png +0 -0
- data/public/images/admin/status_top_right.png +0 -0
- data/public/images/admin/tab_close.png +0 -0
- data/public/images/admin/vertical_tan_gradient.png +0 -0
- data/public/images/admin/view_site.png +0 -0
- data/public/images/admin/virtual_page.png +0 -0
- data/public/images/radiant-badge-color.png +0 -0
- data/public/javascripts/admin/application.js +82 -0
- data/public/javascripts/admin/codearea.js +165 -0
- data/public/javascripts/{controls.js → admin/controls.js} +78 -76
- data/public/javascripts/admin/cookie.js +80 -0
- data/public/javascripts/admin/dateinput.js +402 -0
- data/public/javascripts/{dragdrop.js → admin/dragdrop.js} +167 -166
- data/public/javascripts/{effects.js → admin/effects.js} +168 -174
- data/public/javascripts/admin/lowpro.js +340 -0
- data/public/javascripts/admin/overrides.js +1 -0
- data/public/javascripts/admin/pagestatus.js +17 -0
- data/public/javascripts/admin/popup.js +216 -0
- data/public/javascripts/{prototype.js → admin/prototype.js} +1574 -1020
- data/public/javascripts/admin/ruledtable.js +5 -5
- data/public/javascripts/admin/shortcuts.js +27 -0
- data/public/javascripts/admin/sitemap.js +37 -20
- data/public/javascripts/admin/status.js +233 -0
- data/public/javascripts/admin/tabcontrol.js +88 -100
- data/public/javascripts/admin/toggle.js +430 -0
- data/public/javascripts/admin/utility.js +52 -0
- data/public/stylesheets/admin/main.css +1088 -588
- data/public/stylesheets/admin/overrides.css +1 -0
- data/public/stylesheets/sass/admin/main.sass +26 -0
- data/public/stylesheets/sass/admin/modules/_links.sass +15 -0
- data/public/stylesheets/sass/admin/modules/_opacity.sass +7 -0
- data/public/stylesheets/sass/admin/modules/_rounded.sass +41 -0
- data/public/stylesheets/sass/admin/modules/_shadow.sass +9 -0
- data/public/stylesheets/sass/admin/overrides.sass +2 -0
- data/public/stylesheets/sass/admin/partials/_actions.sass +43 -0
- data/public/stylesheets/sass/admin/partials/_avatars.sass +10 -0
- data/public/stylesheets/sass/admin/partials/_base.sass +59 -0
- data/public/stylesheets/sass/admin/partials/_content.sass +199 -0
- data/public/stylesheets/sass/admin/partials/_dateinput.sass +62 -0
- data/public/stylesheets/sass/admin/partials/_depreciated.sass +26 -0
- data/public/stylesheets/sass/admin/partials/_footer.sass +12 -0
- data/public/stylesheets/sass/admin/partials/_forms.sass +309 -0
- data/public/stylesheets/sass/admin/partials/_header.sass +112 -0
- data/public/stylesheets/sass/admin/partials/_layout.sass +10 -0
- data/public/stylesheets/sass/admin/partials/_messages.sass +10 -0
- data/public/stylesheets/sass/admin/partials/_popup.sass +117 -0
- data/public/stylesheets/sass/admin/partials/_reset.sass +36 -0
- data/public/stylesheets/sass/admin/partials/_tabcontrol.sass +70 -0
- data/public/stylesheets/sass/admin/partials/_toolbar.sass +31 -0
- data/rerun.txt +1 -0
- data/script/cucumber +9 -7
- data/spec/controllers/admin/export_controller_spec.rb +1 -1
- data/spec/controllers/admin/layouts_controller_spec.rb +5 -5
- data/spec/controllers/admin/pages_controller_spec.rb +26 -7
- data/spec/controllers/admin/preferences_controller_spec.rb +5 -6
- data/spec/controllers/admin/references_controller_spec.rb +1 -1
- data/spec/controllers/admin/snippets_controller_spec.rb +6 -6
- data/spec/controllers/admin/users_controller_spec.rb +10 -1
- data/spec/controllers/admin/welcome_controller_spec.rb +3 -3
- data/spec/controllers/application_controller_spec.rb +14 -0
- data/spec/controllers/site_controller_spec.rb +48 -1
- data/spec/datasets/pages_dataset.rb +5 -1
- data/spec/datasets/users_dataset.rb +23 -10
- data/spec/generators/extension_controller_generator_spec.rb +16 -6
- data/spec/generators/extension_generator_spec.rb +49 -18
- data/spec/generators/extension_generators_spec_helper.rb +53 -26
- data/spec/generators/extension_mailer_generator_spec.rb +3 -3
- data/spec/generators/instance_generator_spec.rb +152 -0
- data/spec/helpers/admin/node_helper_spec.rb +8 -8
- data/spec/helpers/admin/references_helper_spec.rb +4 -4
- data/spec/helpers/admin/users_helper_spec.rb +2 -2
- data/spec/helpers/application_helper_spec.rb +68 -32
- data/spec/lib/login_system_spec.rb +1 -1
- data/spec/lib/radiant/admin_ui/nav_tabs_spec.rb +139 -0
- data/spec/lib/radiant/admin_ui_spec.rb +30 -131
- data/spec/lib/radiant/available_locales_spec.rb +13 -0
- data/spec/lib/radiant/extension/script_spec.rb +24 -11
- data/spec/lib/radiant/extension_loader_spec.rb +37 -7
- data/spec/lib/radiant/extension_spec.rb +32 -1
- data/spec/lib/radiant/initializer_spec.rb +32 -2
- data/spec/lib/radiant/taggable_spec.rb +10 -8
- data/spec/lib/radiant_spec.rb +5 -1
- data/spec/lib/task_support_spec.rb +31 -0
- data/spec/lib/translation_support_spec.rb +16 -0
- data/spec/matchers/generator_matchers.rb +145 -147
- data/spec/matchers/render_form_errors_matcher.rb +1 -1
- data/spec/models/page_spec.rb +36 -0
- data/spec/models/radiant/config_spec.rb +2 -2
- data/spec/models/standard_tags_spec.rb +96 -26
- data/spec/models/user_spec.rb +32 -8
- data/test/fixtures/extensions/{01_basic → basic}/app/controllers/basic_extension_controller.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/app/metal/basic_metal.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/app/models/basic_extension_mailer.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/app/models/basic_extension_model.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/app/views/basic_extension/index.html.erb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/app/views/basic_extension/override.html.erb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/app/views/basic_extension_mailer/message.text.html.erb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/basic_extension.rb +3 -4
- data/test/fixtures/extensions/{01_basic → basic}/db/migrate/200812131420_create_initial_schema.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/db/migrate/200812131421_modify_initial_schema.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/lib/new_module.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/vendor/plugins/multiple/init.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/vendor/plugins/multiple/lib/multiple.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/vendor/plugins/plugin_normal/init.rb +0 -0
- data/test/fixtures/extensions/{01_basic → basic}/vendor/plugins/plugin_normal/lib/normal_plugin.rb +0 -0
- data/test/fixtures/extensions/load_order_blue/load_order_blue_extension.rb +0 -3
- data/test/fixtures/extensions/load_order_green/load_order_green_extension.rb +0 -3
- data/test/fixtures/extensions/load_order_red/load_order_red_extension.rb +0 -3
- data/test/fixtures/extensions/locale/config/locales/en-uk.yml +3 -0
- data/test/fixtures/extensions/locale/config/locales/en.yml +3 -0
- data/test/fixtures/extensions/locale/locale_extension.rb +5 -0
- data/test/fixtures/extensions/{02_overriding → overriding}/app/metal/basic_metal.rb +0 -0
- data/test/fixtures/extensions/{02_overriding → overriding}/app/views/basic_extension/override.html.erb +0 -0
- data/test/fixtures/extensions/{02_overriding → overriding}/overriding_extension.rb +0 -3
- data/test/fixtures/extensions/{02_overriding → overriding}/vendor/plugins/multiple/init.rb +0 -0
- data/test/fixtures/extensions/{02_overriding → overriding}/vendor/plugins/multiple/lib/multiple.rb +0 -0
- data/test/fixtures/extensions/routed/config/routes.rb +1 -0
- data/test/fixtures/extensions/routed/routed_extension.rb +2 -0
- data/test/fixtures/extensions/{03_upgrading → upgrading}/db/migrate/01_first.rb +0 -0
- data/test/fixtures/extensions/{03_upgrading → upgrading}/db/migrate/02_second.rb +0 -0
- data/test/fixtures/extensions/{03_upgrading → upgrading}/db/migrate/03_pending.rb +0 -0
- data/test/fixtures/extensions/{03_upgrading → upgrading}/db/migrate/04_dont_run.rb +0 -0
- data/test/fixtures/extensions/{03_upgrading → upgrading}/upgrading_extension.rb +0 -0
- data/test/fixtures/gems/misnamed_ext-0.0.0/misnamed_ext_extension.rb +2 -0
- data/test/fixtures/gems/radiant-gem_ext-extension-0.0.0/gem_ext_extension.rb +2 -0
- data/test/fixtures/gems/radiant-gem_ext-extension-0.0.0/lib/gem_ext.rb +3 -0
- data/test/test_helper.rb +1 -1
- data/vendor/extensions/archive/archive_extension.rb +1 -1
- data/vendor/extensions/dutch_language_pack/README +3 -0
- data/vendor/extensions/dutch_language_pack/Rakefile +123 -0
- data/vendor/extensions/dutch_language_pack/config/locales/nl.yml +187 -0
- data/vendor/extensions/dutch_language_pack/config/locales/nl_available_tags.yml +553 -0
- data/vendor/extensions/dutch_language_pack/dutch_language_pack_extension.rb +9 -0
- data/vendor/extensions/dutch_language_pack/lib/tasks/i18n_nl_extension_tasks.rake +28 -0
- data/vendor/extensions/french_language_pack/README +3 -0
- data/vendor/extensions/french_language_pack/Rakefile +123 -0
- data/vendor/extensions/french_language_pack/config/locales/fr.yml +184 -0
- data/vendor/extensions/french_language_pack/config/locales/fr_available_tags.yml +553 -0
- data/vendor/extensions/french_language_pack/french_language_pack_extension.rb +9 -0
- data/vendor/extensions/french_language_pack/lib/tasks/i18n_fr_extension_tasks.rake +28 -0
- data/vendor/extensions/german_language_pack/README +3 -0
- data/vendor/extensions/german_language_pack/Rakefile +123 -0
- data/vendor/extensions/german_language_pack/config/locales/de.yml +184 -0
- data/vendor/extensions/german_language_pack/config/locales/de_available_tags.yml +553 -0
- data/vendor/extensions/german_language_pack/german_language_pack_extension.rb +9 -0
- data/vendor/extensions/german_language_pack/lib/tasks/i18n_de_extension_tasks.rake +28 -0
- data/vendor/extensions/italian_language_pack/README +3 -0
- data/vendor/extensions/italian_language_pack/Rakefile +123 -0
- data/vendor/extensions/italian_language_pack/config/locales/it.yml +184 -0
- data/vendor/extensions/italian_language_pack/config/locales/it_available_tags.yml +553 -0
- data/vendor/extensions/italian_language_pack/italian_language_pack_extension.rb +8 -0
- data/vendor/extensions/italian_language_pack/lib/tasks/i18n_it_extension_tasks.rake +28 -0
- data/vendor/extensions/japanese_language_pack/README +3 -0
- data/vendor/extensions/japanese_language_pack/Rakefile +123 -0
- data/vendor/extensions/japanese_language_pack/config/locales/ja.yml +184 -0
- data/vendor/extensions/japanese_language_pack/config/locales/ja_available_tags.yml +553 -0
- data/vendor/extensions/japanese_language_pack/japanese_language_pack_extension.rb +9 -0
- data/vendor/extensions/japanese_language_pack/lib/tasks/i18n_ja_extension_tasks.rake +28 -0
- data/vendor/extensions/markdown_filter/lib/markdown_filter.rb +5 -1
- data/vendor/extensions/markdown_filter/lib/markdown_tags.rb +4 -4
- data/vendor/extensions/markdown_filter/markdown.html +122 -122
- data/vendor/extensions/markdown_filter/markdown_filter_extension.rb +2 -2
- data/vendor/extensions/markdown_filter/smartypants.html +47 -47
- data/vendor/extensions/markdown_filter/spec/models/markdown_filter_spec.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/AUTHORS +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/COPYING +24 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/ChangeLog +2624 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/GPL +674 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/README +20 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/Rakefile +283 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/VERSION +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/benchmark.rb +34 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/generate_data.rb +110 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-jruby-1.4.0.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.8.6.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.8.7.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.9.1p243.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.9.2dev.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/mdbasics.text +306 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/mdsyntax.text +888 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/static-jruby-1.4.0.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/static-ruby-1.8.6.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/static-ruby-1.8.7.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/static-ruby-1.9.1p243.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/static-ruby-1.9.2dev.dat +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/testing.sh +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/timing.sh +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/bin/kramdown +71 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/default.css +293 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/default.template +78 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/index.page +91 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/installation.page +90 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/news.feed +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/news.page +27 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/quickref.page +551 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/syntax.page +1451 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/tests.page +51 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/virtual +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown.rb +23 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/compatibility.rb +34 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter.rb +36 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/base.rb +75 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/html.rb +325 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/latex.rb +516 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/document.rb +145 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/error.rb +27 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/options.rb +262 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser.rb +33 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown.rb +292 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/attribute_list.rb +102 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/autolink.rb +42 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/blank_line.rb +43 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/blockquote.rb +42 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/codeblock.rb +58 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/codespan.rb +57 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/emphasis.rb +69 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/eob.rb +39 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/escaped_chars.rb +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/extension.rb +109 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/footnote.rb +73 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/header.rb +81 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/horizontal_rule.rb +39 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/html.rb +253 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/html_entity.rb +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/line_break.rb +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/link.rb +153 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/list.rb +225 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/paragraph.rb +44 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/smart_quotes.rb +213 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/table.rb +125 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/typographic_symbol.rb +48 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/version.rb +28 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/setup.rb +1585 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/run_tests.rb +58 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/test_files.rb +39 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/01_blank_line/spaces.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/01_blank_line/spaces.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/01_blank_line/tabs.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/01_blank_line/tabs.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/beginning.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/beginning.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/end.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/end.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/middle.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/middle.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/indented.html +18 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/indented.text +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/no_newline_at_end.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/no_newline_at_end.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/one_para.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/one_para.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/two_para.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/03_paragraph/two_para.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/atx_header.html +34 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/atx_header.text +32 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/atx_header_no_newline_at_end.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/atx_header_no_newline_at_end.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/setext_header.html +31 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/setext_header.text +36 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/setext_header_no_newline_at_end.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/setext_header_no_newline_at_end.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/with_auto_ids.html +17 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/with_auto_ids.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/with_auto_ids.text +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/indented.html +25 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/indented.text +14 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/nested.html +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/nested.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/no_newline_at_end.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/no_newline_at_end.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/only_first_quoted.html +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/only_first_quoted.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/with_code_blocks.html +15 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/with_code_blocks.text +11 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/error.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/error.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/no_newline_at_end.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/no_newline_at_end.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/normal.html +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/normal.text +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/tilde_syntax.html +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/tilde_syntax.text +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/whitespace.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/whitespace.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/with_blank_line.html +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/with_blank_line.text +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/with_eob_marker.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/with_eob_marker.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/error.html +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/error.text +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/normal.html +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/normal.text +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/sepspaces.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/sepspaces.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/septabs.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/septabs.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/escaping.html +17 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/escaping.text +17 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/list_and_hr.html +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/list_and_hr.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/list_and_others.html +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/list_and_others.text +25 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/mixed.html +111 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/mixed.text +66 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/nested.html +17 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/nested.text +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/other_first_element.html +39 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/other_first_element.text +18 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/simple_ol.html +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/simple_ol.text +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/simple_ul.html +61 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/simple_ul.text +43 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/single_item.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/single_item.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/special_cases.html +29 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/special_cases.text +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/comment.html +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/comment.text +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/deflists.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/deflists.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/deflists.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/tables.html +14 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/tables.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/tables.text +14 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/filtered_html.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/filtered_html.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/filtered_html.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_and_codeblocks.html +15 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_and_codeblocks.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_and_codeblocks.text +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/invalid_html_1.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/invalid_html_1.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/invalid_html_2.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/invalid_html_2.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/markdown_attr.html +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/markdown_attr.text +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/not_parsed.html +24 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/not_parsed.text +24 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_raw.html +32 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_raw.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_raw.text +30 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_span.html +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_span.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_span.text +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_block_html.html +21 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_block_html.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_block_html.text +17 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/processing_instruction.html +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/processing_instruction.text +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/simple.html +62 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/simple.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/simple.text +57 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/10_ald/simple.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/10_ald/simple.text +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/auto_id_and_ial.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/auto_id_and_ial.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/auto_id_and_ial.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/simple.html +20 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/simple.text +27 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/comment.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/comment.text +11 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/ignored.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/ignored.text +11 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.text +11 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options.html +24 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options.text +28 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options2.html +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options2.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options3.html +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options3.text +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/definition_at_beginning.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/definition_at_beginning.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/multiple_terms.html +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/multiple_terms.text +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/no_def_list.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/no_def_list.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/para_wrapping.html +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/para_wrapping.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/separated_by_eob.html +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/separated_by_eob.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/simple.html +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/simple.text +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/styled_terms.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/styled_terms.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/too_much_space.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/too_much_space.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/with_blocks.html +38 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/with_blocks.text +24 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/errors.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/errors.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/footer.html +65 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/footer.text +25 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/header.html +103 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/header.text +32 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/no_table.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/no_table.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/simple.html +61 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/simple.text +16 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/encoding.html +46 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/encoding.text +28 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/empty.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/empty.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/image_in_a.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/image_in_a.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/imagelinks.html +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/imagelinks.text +14 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/inline.html +40 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/inline.text +42 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/link_defs.html +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/link_defs.text +22 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/links_with_angle_brackets.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/links_with_angle_brackets.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/reference.html +32 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/reference.text +42 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/empty.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/empty.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/errors.html +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/errors.text +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/nesting.html +34 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/nesting.text +30 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/normal.html +46 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/normal.text +46 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/empty.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/empty.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/errors.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/errors.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/normal.html +16 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/normal.text +16 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/definitions.html +14 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/definitions.text +18 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/footnote_nr.html +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/footnote_nr.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/footnote_nr.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/markers.html +46 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/markers.text +26 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/across_lines.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/across_lines.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/link_with_mailto.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/link_with_mailto.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/markdown_attr.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/markdown_attr.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/normal.html +28 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/normal.text +28 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/autolinks/url_links.html +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/autolinks/url_links.text +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/escaped_chars/normal.html +41 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/escaped_chars/normal.text +41 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/ial/simple.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/ial/simple.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/line_breaks/normal.html +11 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/line_breaks/normal.text +11 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/greaterthan.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/greaterthan.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/lowerthan.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/lowerthan.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.html +15 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.text +15 -0
- data/vendor/extensions/russian_language_pack/README +3 -0
- data/vendor/extensions/russian_language_pack/Rakefile +123 -0
- data/vendor/extensions/russian_language_pack/config/locales/ru.yml +180 -0
- data/vendor/extensions/russian_language_pack/config/locales/ru_available_tags.yml +553 -0
- data/vendor/extensions/russian_language_pack/lib/tasks/i18n_ru_extension_tasks.rake +28 -0
- data/vendor/extensions/russian_language_pack/russian_language_pack_extension.rb +9 -0
- data/vendor/extensions/textile_filter/textile.html +114 -114
- data/vendor/plugins/dataset/lib/dataset/extensions/cucumber.rb +5 -4
- data/vendor/plugins/dataset/lib/dataset/load.rb +0 -10
- data/vendor/plugins/dataset/lib/dataset/session.rb +4 -20
- data/vendor/plugins/dataset/lib/dataset/session_binding.rb +5 -15
- data/vendor/plugins/haml/CONTRIBUTING +4 -0
- data/vendor/plugins/haml/MIT-LICENSE +1 -1
- data/vendor/plugins/haml/README.md +357 -0
- data/vendor/plugins/haml/Rakefile +233 -26
- data/vendor/plugins/haml/TODO +47 -0
- data/vendor/plugins/haml/VERSION +1 -1
- data/vendor/plugins/haml/VERSION_NAME +1 -0
- data/vendor/plugins/haml/doc-src/FAQ.md +175 -0
- data/vendor/plugins/haml/doc-src/HAML_CHANGELOG.md +479 -0
- data/vendor/plugins/haml/doc-src/HAML_REFERENCE.md +1184 -0
- data/vendor/plugins/haml/doc-src/SASS_CHANGELOG.md +695 -0
- data/vendor/plugins/haml/doc-src/SASS_REFERENCE.md +1150 -0
- data/vendor/plugins/haml/extra/haml-mode.el +514 -97
- data/vendor/plugins/haml/extra/sass-mode.el +155 -38
- data/vendor/plugins/haml/extra/update_watch.rb +13 -0
- data/vendor/plugins/haml/haml.gemspec +51 -0
- data/vendor/plugins/haml/init.rb +11 -3
- data/vendor/plugins/haml/lib/haml.rb +15 -993
- data/vendor/plugins/haml/lib/haml/buffer.rb +147 -85
- data/vendor/plugins/haml/lib/haml/engine.rb +137 -103
- data/vendor/plugins/haml/lib/haml/error.rb +7 -7
- data/vendor/plugins/haml/lib/haml/exec.rb +141 -45
- data/vendor/plugins/haml/lib/haml/filters.rb +108 -43
- data/vendor/plugins/haml/lib/haml/helpers.rb +267 -168
- data/vendor/plugins/haml/lib/haml/helpers/action_view_extensions.rb +48 -38
- data/vendor/plugins/haml/lib/haml/helpers/action_view_mods.rb +135 -138
- data/vendor/plugins/haml/lib/haml/helpers/xss_mods.rb +125 -0
- data/vendor/plugins/haml/lib/haml/html.rb +146 -100
- data/vendor/plugins/haml/lib/haml/precompiler.rb +528 -277
- data/vendor/plugins/haml/lib/haml/shared.rb +78 -0
- data/vendor/plugins/haml/lib/haml/template.rb +49 -15
- data/vendor/plugins/haml/lib/haml/template/patch.rb +2 -2
- data/vendor/plugins/haml/lib/haml/template/plugin.rb +9 -6
- data/vendor/plugins/haml/lib/haml/util.rb +299 -6
- data/vendor/plugins/haml/lib/haml/version.rb +30 -13
- data/vendor/plugins/haml/lib/sass.rb +7 -856
- data/vendor/plugins/haml/lib/sass/css.rb +171 -161
- data/vendor/plugins/haml/lib/sass/engine.rb +365 -316
- data/vendor/plugins/haml/lib/sass/environment.rb +79 -0
- data/vendor/plugins/haml/lib/sass/error.rb +33 -11
- data/vendor/plugins/haml/lib/sass/files.rb +147 -0
- data/vendor/plugins/haml/lib/sass/plugin.rb +177 -123
- data/vendor/plugins/haml/lib/sass/plugin/merb.rb +9 -16
- data/vendor/plugins/haml/lib/sass/plugin/rack.rb +65 -0
- data/vendor/plugins/haml/lib/sass/plugin/rails.rb +15 -15
- data/vendor/plugins/haml/lib/sass/repl.rb +58 -0
- data/vendor/plugins/haml/lib/sass/script.rb +62 -0
- data/vendor/plugins/haml/lib/sass/script/bool.rb +17 -0
- data/vendor/plugins/haml/lib/sass/script/color.rb +222 -0
- data/vendor/plugins/haml/lib/sass/script/funcall.rb +50 -0
- data/vendor/plugins/haml/lib/sass/script/functions.rb +257 -0
- data/vendor/plugins/haml/lib/sass/script/lexer.rb +194 -0
- data/vendor/plugins/haml/lib/sass/script/literal.rb +177 -0
- data/vendor/plugins/haml/lib/sass/script/node.rb +14 -0
- data/vendor/plugins/haml/lib/sass/script/number.rb +383 -0
- data/vendor/plugins/haml/lib/sass/script/operation.rb +45 -0
- data/vendor/plugins/haml/lib/sass/script/parser.rb +222 -0
- data/vendor/plugins/haml/lib/sass/script/string.rb +12 -0
- data/vendor/plugins/haml/lib/sass/script/unary_operation.rb +34 -0
- data/vendor/plugins/haml/lib/sass/script/variable.rb +31 -0
- data/vendor/plugins/haml/lib/sass/tree/comment_node.rb +74 -10
- data/vendor/plugins/haml/lib/sass/tree/debug_node.rb +30 -0
- data/vendor/plugins/haml/lib/sass/tree/directive_node.rb +39 -17
- data/vendor/plugins/haml/lib/sass/tree/for_node.rb +48 -0
- data/vendor/plugins/haml/lib/sass/tree/if_node.rb +54 -0
- data/vendor/plugins/haml/lib/sass/tree/import_node.rb +65 -0
- data/vendor/plugins/haml/lib/sass/tree/mixin_def_node.rb +29 -0
- data/vendor/plugins/haml/lib/sass/tree/mixin_node.rb +48 -0
- data/vendor/plugins/haml/lib/sass/tree/node.rb +216 -11
- data/vendor/plugins/haml/lib/sass/tree/prop_node.rb +121 -0
- data/vendor/plugins/haml/lib/sass/tree/rule_node.rb +182 -51
- data/vendor/plugins/haml/lib/sass/tree/variable_node.rb +34 -0
- data/vendor/plugins/haml/lib/sass/tree/while_node.rb +31 -0
- data/vendor/plugins/haml/test/haml/engine_test.rb +659 -44
- data/vendor/plugins/haml/test/haml/helper_test.rb +60 -2
- data/vendor/plugins/haml/test/haml/html2haml_test.rb +60 -0
- data/vendor/plugins/haml/test/haml/results/content_for_layout.xhtml +0 -3
- data/vendor/plugins/haml/test/haml/results/filters.xhtml +2 -0
- data/vendor/plugins/haml/test/haml/results/just_stuff.xhtml +3 -3
- data/vendor/plugins/haml/test/haml/results/list.xhtml +1 -1
- data/vendor/plugins/haml/test/haml/results/standard.xhtml +120 -0
- data/vendor/plugins/haml/test/haml/rhtml/standard.rhtml +2 -2
- data/vendor/plugins/haml/test/haml/template_test.rb +117 -11
- data/vendor/plugins/haml/test/haml/templates/content_for_layout.haml +0 -2
- data/vendor/plugins/haml/test/haml/templates/list.haml +1 -1
- data/vendor/plugins/haml/test/haml/templates/standard.haml +2 -2
- data/vendor/plugins/haml/test/haml/templates/standard_ugly.haml +2 -2
- data/vendor/plugins/haml/test/haml/util_test.rb +107 -0
- data/vendor/plugins/haml/test/linked_rails.rb +11 -2
- data/vendor/plugins/haml/test/sass/css2sass_test.rb +83 -24
- data/vendor/plugins/haml/test/sass/engine_test.rb +743 -67
- data/vendor/plugins/haml/test/sass/functions_test.rb +174 -0
- data/vendor/plugins/haml/test/sass/more_results/more1.css +9 -0
- data/vendor/plugins/haml/test/sass/more_results/more1_with_line_comments.css +26 -0
- data/vendor/plugins/haml/test/sass/more_results/more_import.css +29 -0
- data/vendor/plugins/haml/test/sass/more_templates/_more_partial.sass +2 -0
- data/vendor/plugins/haml/test/sass/more_templates/more1.sass +23 -0
- data/vendor/plugins/haml/test/sass/more_templates/more_import.sass +11 -0
- data/vendor/plugins/haml/test/sass/plugin_test.rb +130 -48
- data/vendor/plugins/haml/test/sass/results/line_numbers.css +49 -0
- data/vendor/plugins/haml/test/sass/results/script.css +16 -0
- data/vendor/plugins/haml/test/sass/results/subdir/subdir.css +2 -0
- data/vendor/plugins/haml/test/sass/results/units.css +11 -0
- data/vendor/plugins/haml/test/sass/script_test.rb +267 -0
- data/vendor/plugins/haml/test/sass/templates/complex.sass +0 -3
- data/vendor/plugins/haml/test/sass/templates/import.sass +2 -2
- data/vendor/plugins/haml/test/sass/templates/importee.sass +7 -2
- data/vendor/plugins/haml/test/sass/templates/line_numbers.sass +13 -0
- data/vendor/plugins/haml/test/sass/templates/script.sass +101 -0
- data/vendor/plugins/haml/test/sass/templates/subdir/nested_subdir/_nested_partial.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/subdir/subdir.sass +2 -2
- data/vendor/plugins/haml/test/sass/templates/units.sass +11 -0
- data/vendor/plugins/haml/test/test_helper.rb +26 -4
- data/vendor/plugins/haml/yard/default/fulldoc/html/css/common.sass +22 -0
- data/vendor/plugins/haml/yard/default/layout/html/footer.erb +12 -0
- data/vendor/plugins/haml/yard/inherited_hash.rb +41 -0
- data/vendor/radius/CHANGELOG +8 -0
- data/vendor/radius/Manifest.txt +21 -0
- data/vendor/radius/{QUICKSTART → QUICKSTART.rdoc} +11 -12
- data/vendor/radius/{README → README.rdoc} +38 -17
- data/vendor/radius/Rakefile +31 -86
- data/vendor/radius/lib/radius.rb +10 -502
- data/vendor/radius/lib/radius/context.rb +139 -0
- data/vendor/radius/lib/radius/delegating_open_struct.rb +31 -0
- data/vendor/radius/lib/radius/error.rb +43 -0
- data/vendor/radius/lib/radius/parse_tag.rb +24 -0
- data/vendor/radius/lib/radius/parser.rb +65 -0
- data/vendor/radius/lib/radius/parser/scan.rb +1247 -0
- data/vendor/radius/lib/radius/parser/scan.rl +123 -0
- data/vendor/radius/lib/radius/tag_binding.rb +71 -0
- data/vendor/radius/lib/radius/tag_definitions.rb +78 -0
- data/vendor/radius/lib/radius/utility.rb +30 -0
- data/vendor/radius/lib/radius/version.rb +14 -0
- data/vendor/radius/radius.gemspec +38 -0
- data/vendor/radius/tasks/scan.rake +27 -0
- data/vendor/radius/test/context_test.rb +61 -0
- data/vendor/radius/test/{radius_test.rb → parser_test.rb} +45 -82
- data/vendor/radius/test/quickstart_test.rb +153 -0
- data/vendor/radius/test/test_helper.rb +28 -0
- data/vendor/rails/Rakefile +81 -0
- data/vendor/rails/actionmailer/CHANGELOG +4 -0
- data/vendor/rails/actionmailer/Rakefile +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.3/tmail/parser.rb +2 -0
- data/vendor/rails/actionmailer/lib/action_mailer/version.rb +1 -1
- data/vendor/rails/actionmailer/lib/actionmailer.rb +1 -0
- data/vendor/rails/actionmailer/test/fixtures/helpers/example_helper.rb +1 -1
- data/vendor/rails/actionmailer/test/mail_service_test.rb +3 -1
- data/vendor/rails/actionpack/CHANGELOG +12 -0
- data/vendor/rails/actionpack/Rakefile +1 -1
- data/vendor/rails/actionpack/lib/action_controller.rb +3 -1
- data/vendor/rails/actionpack/lib/action_controller/assertions/dom_assertions.rb +19 -3
- data/vendor/rails/actionpack/lib/action_controller/assertions/selector_assertions.rb +16 -10
- data/vendor/rails/actionpack/lib/action_controller/base.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/caching.rb +1 -0
- data/vendor/rails/actionpack/lib/action_controller/cookies.rb +2 -1
- data/vendor/rails/actionpack/lib/action_controller/http_authentication.rb +3 -2
- data/vendor/rails/actionpack/lib/action_controller/integration.rb +15 -3
- data/vendor/rails/actionpack/lib/action_controller/layout.rb +6 -1
- data/vendor/rails/actionpack/lib/action_controller/middlewares.rb +2 -0
- data/vendor/rails/actionpack/lib/action_controller/polymorphic_routes.rb +6 -21
- data/vendor/rails/actionpack/lib/action_controller/rack_lint_patch.rb +36 -0
- data/vendor/rails/actionpack/lib/action_controller/request_forgery_protection.rb +6 -2
- data/vendor/rails/actionpack/lib/action_controller/response.rb +2 -1
- data/vendor/rails/actionpack/lib/action_controller/string_coercion.rb +29 -0
- data/vendor/rails/actionpack/lib/action_controller/test_case.rb +6 -1
- data/vendor/rails/actionpack/lib/action_controller/test_process.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/translation.rb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/uploaded_file.rb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/vendor/html-scanner/html/node.rb +1 -1
- data/vendor/rails/actionpack/lib/action_pack/version.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view.rb +3 -3
- data/vendor/rails/actionpack/lib/action_view/base.rb +6 -1
- data/vendor/rails/actionpack/lib/action_view/erb/util.rb +6 -0
- data/vendor/rails/actionpack/lib/action_view/helpers.rb +2 -0
- data/vendor/rails/actionpack/lib/action_view/helpers/active_record_helper.rb +3 -3
- data/vendor/rails/actionpack/lib/action_view/helpers/asset_tag_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/capture_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/date_helper.rb +27 -15
- data/vendor/rails/actionpack/lib/action_view/helpers/form_helper.rb +32 -11
- data/vendor/rails/actionpack/lib/action_view/helpers/form_options_helper.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/form_tag_helper.rb +3 -3
- data/vendor/rails/actionpack/lib/action_view/helpers/number_helper.rb +6 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/prototype_helper.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/raw_output_helper.rb +9 -0
- data/vendor/rails/actionpack/lib/action_view/helpers/sanitize_helper.rb +10 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/tag_helper.rb +4 -4
- data/vendor/rails/actionpack/lib/action_view/helpers/translation_helper.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/url_helper.rb +3 -3
- data/vendor/rails/actionpack/lib/action_view/locale/en.yml +3 -0
- data/vendor/rails/actionpack/lib/action_view/partials.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/safe_buffer.rb +28 -0
- data/vendor/rails/actionpack/lib/action_view/template.rb +8 -2
- data/vendor/rails/actionpack/lib/action_view/test_case.rb +102 -27
- data/vendor/rails/actionpack/lib/actionpack.rb +1 -0
- data/vendor/rails/actionpack/test/controller/cookie_test.rb +7 -0
- data/vendor/rails/actionpack/test/controller/dom_assertions_test.rb +53 -0
- data/vendor/rails/actionpack/test/controller/filter_params_test.rb +1 -0
- data/vendor/rails/actionpack/test/controller/html-scanner/sanitizer_test.rb +1 -0
- data/vendor/rails/actionpack/test/controller/http_digest_authentication_test.rb +22 -0
- data/vendor/rails/actionpack/test/controller/integration_test.rb +38 -0
- data/vendor/rails/actionpack/test/controller/layout_test.rb +11 -0
- data/vendor/rails/actionpack/test/controller/polymorphic_routes_test.rb +4 -0
- data/vendor/rails/actionpack/test/controller/request_forgery_protection_test.rb +19 -1
- data/vendor/rails/actionpack/test/controller/routing_test.rb +23 -15
- data/vendor/rails/actionpack/test/controller/session/test_session_test.rb +2 -2
- data/vendor/rails/actionpack/test/fixtures/layout_tests/abs_path_layout.rhtml +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/_from_helper.erb +1 -0
- data/vendor/rails/actionpack/test/template/active_record_helper_test.rb +1 -1
- data/vendor/rails/actionpack/test/template/asset_tag_helper_test.rb +12 -0
- data/vendor/rails/actionpack/test/template/benchmark_helper_test.rb +6 -6
- data/vendor/rails/actionpack/test/template/compiled_templates_test.rb +2 -1
- data/vendor/rails/actionpack/test/template/date_helper_i18n_test.rb +10 -9
- data/vendor/rails/actionpack/test/template/date_helper_test.rb +29 -13
- data/vendor/rails/actionpack/test/template/form_helper_test.rb +90 -10
- data/vendor/rails/actionpack/test/template/number_helper_test.rb +4 -0
- data/vendor/rails/actionpack/test/template/raw_output_helper_test.rb +21 -0
- data/vendor/rails/actionpack/test/template/sanitize_helper_test.rb +10 -1
- data/vendor/rails/actionpack/test/template/tag_helper_test.rb +1 -0
- data/vendor/rails/actionpack/test/view/safe_buffer_test.rb +36 -0
- data/vendor/rails/actionpack/test/view/test_case_test.rb +173 -5
- data/vendor/rails/activemodel/CHANGES +12 -0
- data/vendor/rails/activemodel/README +21 -0
- data/vendor/rails/activemodel/Rakefile +24 -0
- data/vendor/rails/activemodel/lib/active_model.rb +5 -0
- data/vendor/rails/activemodel/lib/active_model/base.rb +8 -0
- data/vendor/rails/activemodel/lib/active_model/callbacks.rb +7 -0
- data/vendor/rails/activemodel/lib/active_model/core.rb +7 -0
- data/vendor/rails/activemodel/lib/active_model/deprecated_error_methods.rb +38 -0
- data/vendor/rails/activemodel/lib/active_model/errors.rb +82 -0
- data/vendor/rails/activemodel/lib/active_model/observing.rb +98 -0
- data/vendor/rails/activemodel/lib/active_model/state_machine.rb +68 -0
- data/vendor/rails/activemodel/lib/active_model/state_machine/event.rb +64 -0
- data/vendor/rails/activemodel/lib/active_model/state_machine/machine.rb +78 -0
- data/vendor/rails/activemodel/lib/active_model/state_machine/state.rb +47 -0
- data/vendor/rails/activemodel/lib/active_model/state_machine/state_transition.rb +40 -0
- data/vendor/rails/activemodel/lib/active_model/validations.rb +126 -0
- data/vendor/rails/activemodel/lib/active_model/validations/acceptance.rb +45 -0
- data/vendor/rails/activemodel/lib/active_model/validations/associated.rb +46 -0
- data/vendor/rails/activemodel/lib/active_model/validations/confirmation.rb +44 -0
- data/vendor/rails/activemodel/lib/active_model/validations/exclusion.rb +37 -0
- data/vendor/rails/activemodel/lib/active_model/validations/format.rb +39 -0
- data/vendor/rails/activemodel/lib/active_model/validations/inclusion.rb +37 -0
- data/vendor/rails/activemodel/lib/active_model/validations/length.rb +95 -0
- data/vendor/rails/activemodel/lib/active_model/validations/numericality.rb +80 -0
- data/vendor/rails/activemodel/lib/active_model/validations/presence.rb +42 -0
- data/vendor/rails/activemodel/lib/active_model/validations/uniqueness.rb +104 -0
- data/vendor/rails/activemodel/test/observing_test.rb +121 -0
- data/vendor/rails/activemodel/test/state_machine/event_test.rb +49 -0
- data/vendor/rails/activemodel/test/state_machine/machine_test.rb +43 -0
- data/vendor/rails/activemodel/test/state_machine/state_test.rb +72 -0
- data/vendor/rails/activemodel/test/state_machine/state_transition_test.rb +84 -0
- data/vendor/rails/activemodel/test/state_machine_test.rb +312 -0
- data/vendor/rails/activemodel/test/test_helper.rb +21 -0
- data/vendor/rails/activerecord/CHANGELOG +8 -0
- data/vendor/rails/activerecord/MIT-LICENSE +20 -0
- data/vendor/rails/activerecord/Rakefile +1 -1
- data/vendor/rails/activerecord/lib/active_record/associations.rb +10 -7
- data/vendor/rails/activerecord/lib/active_record/associations/association_proxy.rb +7 -8
- data/vendor/rails/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb +2 -2
- data/vendor/rails/activerecord/lib/active_record/associations/has_one_association.rb +9 -0
- data/vendor/rails/activerecord/lib/active_record/autosave_association.rb +32 -23
- data/vendor/rails/activerecord/lib/active_record/base.rb +7 -0
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb +6 -2
- data/vendor/rails/activerecord/lib/active_record/fixtures.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/locking/optimistic.rb +0 -33
- data/vendor/rails/activerecord/lib/active_record/locking/pessimistic.rb +0 -22
- data/vendor/rails/activerecord/lib/active_record/nested_attributes.rb +101 -38
- data/vendor/rails/activerecord/lib/active_record/validations.rb +35 -35
- data/vendor/rails/activerecord/lib/active_record/version.rb +1 -1
- data/vendor/rails/activerecord/lib/activerecord.rb +1 -0
- data/vendor/rails/activerecord/test/cases/associations/has_many_associations_test.rb +12 -0
- data/vendor/rails/activerecord/test/cases/associations/has_many_through_associations_test.rb +22 -0
- data/vendor/rails/activerecord/test/cases/associations/has_one_associations_test.rb +21 -0
- data/vendor/rails/activerecord/test/cases/autosave_association_test.rb +230 -11
- data/vendor/rails/activerecord/test/cases/base_test.rb +2 -0
- data/vendor/rails/activerecord/test/cases/connection_test_mysql.rb +8 -0
- data/vendor/rails/activerecord/test/cases/fixtures_test.rb +2 -2
- data/vendor/rails/activerecord/test/cases/locking_test.rb +0 -18
- data/vendor/rails/activerecord/test/cases/nested_attributes_test.rb +109 -37
- data/vendor/rails/activerecord/test/cases/reflection_test.rb +3 -3
- data/vendor/rails/activerecord/test/cases/validations_i18n_test.rb +8 -0
- data/vendor/rails/activerecord/test/cases/validations_test.rb +37 -9
- data/vendor/rails/activerecord/test/fixtures/accounts.yml +1 -0
- data/vendor/rails/activerecord/test/models/company.rb +10 -0
- data/vendor/rails/activerecord/test/models/pirate.rb +9 -2
- data/vendor/rails/activerecord/test/models/treasure.rb +2 -0
- data/vendor/rails/activerecord/test/schema/mysql_specific_schema.rb +12 -0
- data/vendor/rails/activerecord/test/schema/schema.rb +1 -0
- data/vendor/rails/activeresource/CHANGELOG +9 -0
- data/vendor/rails/activeresource/MIT-LICENSE +20 -0
- data/vendor/rails/activeresource/Rakefile +1 -1
- data/vendor/rails/activeresource/lib/active_resource/validations.rb +2 -2
- data/vendor/rails/activeresource/lib/active_resource/version.rb +1 -1
- data/vendor/rails/activeresource/lib/activeresource.rb +1 -0
- data/vendor/rails/activeresource/test/base_errors_test.rb +2 -2
- data/vendor/rails/activesupport/CHANGELOG +8 -0
- data/vendor/rails/activesupport/MIT-LICENSE +20 -0
- data/vendor/rails/activesupport/Rakefile +175 -0
- data/vendor/rails/activesupport/bin/generate_tables +147 -0
- data/vendor/rails/activesupport/install.rb +30 -0
- data/vendor/rails/activesupport/lib/active_support/cache.rb +7 -0
- data/vendor/rails/activesupport/lib/active_support/cache/mem_cache_store.rb +5 -0
- data/vendor/rails/activesupport/lib/active_support/cache/strategy/local_cache.rb +5 -5
- data/vendor/rails/activesupport/lib/active_support/core_ext.rb +7 -3
- data/vendor/rails/activesupport/lib/active_support/core_ext/blank.rb +2 -58
- data/vendor/rails/activesupport/lib/active_support/core_ext/kernel/debugger.rb +1 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/name_error.rb +3 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/object.rb +1 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/object/blank.rb +58 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/string.rb +2 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/string/output_safety.rb +48 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/time/calculations.rb +2 -1
- data/vendor/rails/activesupport/lib/active_support/deprecation.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/json/backends/jsongem.rb +2 -3
- data/vendor/rails/activesupport/lib/active_support/json/backends/yaml.rb +1 -5
- data/vendor/rails/activesupport/lib/active_support/json/decoding.rb +2 -0
- data/vendor/rails/activesupport/lib/active_support/message_verifier.rb +30 -10
- data/vendor/rails/activesupport/lib/active_support/multibyte/chars.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/multibyte/utils.rb +4 -4
- data/vendor/rails/activesupport/lib/active_support/ordered_hash.rb +7 -0
- data/vendor/rails/activesupport/lib/active_support/vendor.rb +2 -2
- data/vendor/rails/activesupport/lib/active_support/version.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/whiny_nil.rb +8 -2
- data/vendor/rails/activesupport/lib/active_support/xml_mini/nokogiri.rb +13 -21
- data/vendor/rails/activesupport/lib/activesupport.rb +1 -0
- data/vendor/rails/activesupport/test/abstract_unit.rb +36 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/a/b.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/a/c/d.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/a/c/e/f.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/application.rb +1 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder.rb +3 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder/class_folder_subclass.rb +3 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder/inline_class.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder/nested_class.rb +7 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/conflict.rb +1 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/counting_loader.rb +5 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/cross_site_dependency.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/e.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_folder/inline_class.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_folder/nested_class.rb +4 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_folder/nested_sibling.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_with_custom_const_missing/a/b.rb +1 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/multiple_constant_file.rb +2 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/raises_name_error.rb +3 -0
- data/vendor/rails/activesupport/test/autoloading_fixtures/raises_no_method_error.rb +3 -0
- data/vendor/rails/activesupport/test/buffered_logger_test.rb +146 -0
- data/vendor/rails/activesupport/test/caching_test.rb +348 -0
- data/vendor/rails/activesupport/test/callbacks_test.rb +188 -0
- data/vendor/rails/activesupport/test/clean_backtrace_test.rb +47 -0
- data/vendor/rails/activesupport/test/clean_logger_test.rb +57 -0
- data/vendor/rails/activesupport/test/core_ext/array_ext_test.rb +363 -0
- data/vendor/rails/activesupport/test/core_ext/base64_ext_test.rb +8 -0
- data/vendor/rails/activesupport/test/core_ext/bigdecimal.rb +10 -0
- data/vendor/rails/activesupport/test/core_ext/blank_test.rb +24 -0
- data/vendor/rails/activesupport/test/core_ext/cgi_ext_test.rb +14 -0
- data/vendor/rails/activesupport/test/core_ext/class/attribute_accessor_test.rb +31 -0
- data/vendor/rails/activesupport/test/core_ext/class/class_inheritable_attributes_test.rb +224 -0
- data/vendor/rails/activesupport/test/core_ext/class/delegating_attributes_test.rb +115 -0
- data/vendor/rails/activesupport/test/core_ext/class_test.rb +46 -0
- data/vendor/rails/activesupport/test/core_ext/date_ext_test.rb +278 -0
- data/vendor/rails/activesupport/test/core_ext/date_time_ext_test.rb +359 -0
- data/vendor/rails/activesupport/test/core_ext/duplicable_test.rb +22 -0
- data/vendor/rails/activesupport/test/core_ext/duration_test.rb +121 -0
- data/vendor/rails/activesupport/test/core_ext/enumerable_test.rb +97 -0
- data/vendor/rails/activesupport/test/core_ext/exception_test.rb +68 -0
- data/vendor/rails/activesupport/test/core_ext/file_test.rb +67 -0
- data/vendor/rails/activesupport/test/core_ext/float_ext_test.rb +25 -0
- data/vendor/rails/activesupport/test/core_ext/hash_ext_test.rb +1014 -0
- data/vendor/rails/activesupport/test/core_ext/integer_ext_test.rb +37 -0
- data/vendor/rails/activesupport/test/core_ext/kernel_test.rb +43 -0
- data/vendor/rails/activesupport/test/core_ext/load_error_test.rb +16 -0
- data/vendor/rails/activesupport/test/core_ext/module/attr_accessor_with_default_test.rb +30 -0
- data/vendor/rails/activesupport/test/core_ext/module/attr_internal_test.rb +52 -0
- data/vendor/rails/activesupport/test/core_ext/module/attribute_accessor_test.rb +33 -0
- data/vendor/rails/activesupport/test/core_ext/module/attribute_aliasing_test.rb +58 -0
- data/vendor/rails/activesupport/test/core_ext/module/model_naming_test.rb +27 -0
- data/vendor/rails/activesupport/test/core_ext/module/synchronization_test.rb +85 -0
- data/vendor/rails/activesupport/test/core_ext/module_test.rb +363 -0
- data/vendor/rails/activesupport/test/core_ext/name_error_test.rb +20 -0
- data/vendor/rails/activesupport/test/core_ext/numeric_ext_test.rb +162 -0
- data/vendor/rails/activesupport/test/core_ext/object_and_class_ext_test.rb +282 -0
- data/vendor/rails/activesupport/test/core_ext/object_ext_test.rb +8 -0
- data/vendor/rails/activesupport/test/core_ext/pathname_test.rb +9 -0
- data/vendor/rails/activesupport/test/core_ext/proc_test.rb +11 -0
- data/vendor/rails/activesupport/test/core_ext/range_ext_test.rb +63 -0
- data/vendor/rails/activesupport/test/core_ext/string_ext_test.rb +369 -0
- data/vendor/rails/activesupport/test/core_ext/symbol_test.rb +9 -0
- data/vendor/rails/activesupport/test/core_ext/time_ext_test.rb +744 -0
- data/vendor/rails/activesupport/test/core_ext/time_with_zone_test.rb +845 -0
- data/vendor/rails/activesupport/test/core_ext/uri_ext_test.rb +12 -0
- data/vendor/rails/activesupport/test/dependencies/check_warnings.rb +2 -0
- data/vendor/rails/activesupport/test/dependencies/conflict.rb +1 -0
- data/vendor/rails/activesupport/test/dependencies/cross_site_depender.rb +3 -0
- data/vendor/rails/activesupport/test/dependencies/mutual_one.rb +4 -0
- data/vendor/rails/activesupport/test/dependencies/mutual_two.rb +4 -0
- data/vendor/rails/activesupport/test/dependencies/raises_exception.rb +3 -0
- data/vendor/rails/activesupport/test/dependencies/requires_nonexistent0.rb +1 -0
- data/vendor/rails/activesupport/test/dependencies/requires_nonexistent1.rb +1 -0
- data/vendor/rails/activesupport/test/dependencies/service_one.rb +5 -0
- data/vendor/rails/activesupport/test/dependencies/service_two.rb +2 -0
- data/vendor/rails/activesupport/test/dependencies_test.rb +782 -0
- data/vendor/rails/activesupport/test/deprecation_test.rb +167 -0
- data/vendor/rails/activesupport/test/flush_cache_on_private_memoization_test.rb +43 -0
- data/vendor/rails/activesupport/test/gzip_test.rb +7 -0
- data/vendor/rails/activesupport/test/i18n_test.rb +98 -0
- data/vendor/rails/activesupport/test/inflector_test.rb +298 -0
- data/vendor/rails/activesupport/test/inflector_test_cases.rb +252 -0
- data/vendor/rails/activesupport/test/json/decoding_test.rb +73 -0
- data/vendor/rails/activesupport/test/json/encoding_test.rb +160 -0
- data/vendor/rails/activesupport/test/memoizable_test.rb +247 -0
- data/vendor/rails/activesupport/test/message_encryptor_test.rb +46 -0
- data/vendor/rails/activesupport/test/message_verifier_test.rb +31 -0
- data/vendor/rails/activesupport/test/multibyte_chars_test.rb +606 -0
- data/vendor/rails/activesupport/test/multibyte_conformance.rb +129 -0
- data/vendor/rails/activesupport/test/multibyte_test_helpers.rb +19 -0
- data/vendor/rails/activesupport/test/multibyte_unicode_database_test.rb +22 -0
- data/vendor/rails/activesupport/test/multibyte_utils_test.rb +137 -0
- data/vendor/rails/activesupport/test/option_merger_test.rb +85 -0
- data/vendor/rails/activesupport/test/ordered_hash_test.rb +201 -0
- data/vendor/rails/activesupport/test/ordered_options_test.rb +53 -0
- data/vendor/rails/activesupport/test/rescuable_test.rb +75 -0
- data/vendor/rails/activesupport/test/secure_random_test.rb +19 -0
- data/vendor/rails/activesupport/test/string_inquirer_test.rb +15 -0
- data/vendor/rails/activesupport/test/test_test.rb +148 -0
- data/vendor/rails/activesupport/test/time_zone_test.rb +266 -0
- data/vendor/rails/activesupport/test/whiny_nil_test.rb +50 -0
- data/vendor/rails/activesupport/test/xml_mini/jdom_engine_test.rb +153 -0
- data/vendor/rails/activesupport/test/xml_mini/nokogiri_engine_test.rb +168 -0
- data/vendor/rails/activesupport/test/xml_mini/rexml_engine_test.rb +15 -0
- data/vendor/rails/ci/ci_build.rb +119 -0
- data/vendor/rails/ci/ci_setup_notes.txt +131 -0
- data/vendor/rails/ci/cruise_config.rb +9 -0
- data/vendor/rails/ci/geminstaller.yml +24 -0
- data/vendor/rails/ci/site.css +13 -0
- data/vendor/rails/ci/site_config.rb +72 -0
- data/vendor/rails/doc/template/horo.rb +613 -0
- data/vendor/rails/pushgems.rb +14 -0
- data/vendor/rails/railties/CHANGELOG +6 -0
- data/vendor/rails/railties/Rakefile +6 -6
- data/vendor/rails/railties/lib/commands/plugin.rb +1 -1
- data/vendor/rails/railties/lib/rails/rack/debugger.rb +2 -0
- data/vendor/rails/railties/lib/rails/version.rb +1 -1
- data/vendor/rails/railties/lib/rails_generator/options.rb +7 -7
- data/vendor/rails/railties/lib/tasks/rails.rb +2 -1
- data/vendor/rails/railties/test/abstract_unit.rb +27 -0
- data/vendor/rails/railties/test/backtrace_cleaner_test.rb +61 -0
- data/vendor/rails/railties/test/boot_test.rb +178 -0
- data/vendor/rails/railties/test/console_app_test.rb +42 -0
- data/vendor/rails/railties/test/fcgi_dispatcher_test.rb +266 -0
- data/vendor/rails/railties/test/fixtures/about_yml_plugins/bad_about_yml/about.yml +1 -0
- data/vendor/rails/railties/test/fixtures/about_yml_plugins/bad_about_yml/init.rb +1 -0
- data/vendor/rails/railties/test/fixtures/about_yml_plugins/plugin_without_about_yml/init.rb +1 -0
- data/vendor/rails/railties/test/fixtures/eager/zoo.rb +3 -0
- data/vendor/rails/railties/test/fixtures/eager/zoo/reptile_house.rb +2 -0
- data/vendor/rails/railties/test/fixtures/environment_with_constant.rb +1 -0
- data/vendor/{extensions/markdown_filter/lib/tasks/textile_filter_extension_tasks.rake → rails/railties/test/fixtures/lib/generators/missing_class/missing_class_generator.rb} +0 -0
- data/vendor/rails/railties/test/fixtures/lib/generators/working/working_generator.rb +2 -0
- data/vendor/rails/railties/test/fixtures/metal/multiplemetals/app/metal/metal_a.rb +5 -0
- data/vendor/rails/railties/test/fixtures/metal/multiplemetals/app/metal/metal_b.rb +5 -0
- data/vendor/rails/railties/test/fixtures/metal/pluralmetal/app/metal/legacy_routes.rb +5 -0
- data/vendor/rails/railties/test/fixtures/metal/singlemetal/app/metal/foo_metal.rb +5 -0
- data/vendor/rails/railties/test/fixtures/metal/subfolders/app/metal/Folder/metal_a.rb +7 -0
- data/vendor/rails/railties/test/fixtures/metal/subfolders/app/metal/Folder/metal_b.rb +7 -0
- data/vendor/rails/railties/test/fixtures/plugins/alternate/a/generators/a_generator/a_generator.rb +4 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/gemlike/init.rb +1 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/gemlike/lib/gemlike.rb +2 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/gemlike/rails/init.rb +7 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/plugin_with_no_lib_dir/init.rb +0 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/about.yml +2 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb +4 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/init.rb +7 -0
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/lib/stubby_mixin.rb +2 -0
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/app/controllers/engine_controller.rb +2 -0
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/app/metal/engine_metal.rb +10 -0
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/app/models/engine_model.rb +2 -0
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/config/locales/en.yml +2 -0
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/config/routes.rb +3 -0
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/init.rb +3 -0
- data/vendor/rails/railties/test/fixtures/public/foo/bar.html +1 -0
- data/vendor/rails/railties/test/fixtures/public/foo/index.html +1 -0
- data/vendor/rails/railties/test/fixtures/public/index.html +1 -0
- data/vendor/rails/railties/test/gem_dependency_test.rb +219 -0
- data/vendor/rails/railties/test/generator_lookup_test.rb +40 -0
- data/vendor/rails/railties/test/generators/generator_test_helper.rb +310 -0
- data/vendor/rails/railties/test/generators/rails_controller_generator_test.rb +44 -0
- data/vendor/rails/railties/test/generators/rails_helper_generator_test.rb +36 -0
- data/vendor/rails/railties/test/generators/rails_mailer_generator_test.rb +29 -0
- data/vendor/rails/railties/test/generators/rails_model_generator_test.rb +96 -0
- data/vendor/rails/railties/test/generators/rails_resource_generator_test.rb +29 -0
- data/vendor/rails/railties/test/generators/rails_scaffold_generator_test.rb +151 -0
- data/vendor/rails/railties/test/generators/rails_template_runner_test.rb +216 -0
- data/vendor/rails/railties/test/initializer_test.rb +416 -0
- data/vendor/rails/railties/test/metal_test.rb +72 -0
- data/vendor/rails/railties/test/mocks/routes.rb +6 -0
- data/vendor/rails/railties/test/plugin_loader_test.rb +172 -0
- data/vendor/rails/railties/test/plugin_locator_test.rb +62 -0
- data/vendor/rails/railties/test/plugin_test.rb +162 -0
- data/vendor/rails/railties/test/plugin_test_helper.rb +29 -0
- data/vendor/rails/railties/test/rack_static_test.rb +46 -0
- data/vendor/rails/railties/test/rails_generator_test.rb +145 -0
- data/vendor/rails/railties/test/rails_info_controller_test.rb +52 -0
- data/vendor/rails/railties/test/rails_info_test.rb +99 -0
- data/vendor/rails/railties/test/secret_key_generation_test.rb +38 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-a-0.4.0/lib/dummy-gem-a.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-b-0.4.0/lib/dummy-gem-b.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-b-0.6.0/lib/dummy-gem-b.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-c-0.4.0/lib/dummy-gem-c.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-c-0.6.0/lib/dummy-gem-c.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-d-1.0.0/lib/dummy-gem-d.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-e-1.0.0/lib/dummy-gem-e.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-f-1.0.0/lib/dummy-gem-f.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-g-1.0.0/lib/dummy-gem-g.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-h-1.0.0/lib/dummy-gem-h.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-i-1.0.0/ext/dummy-gem-i/Makefile +0 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-i-1.0.0/lib/dummy-gem-i.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-j-1.0.0/lib/dummy-gem-j.rb +1 -0
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-k-1.0.0/lib/dummy-gem-k.rb +1 -0
- data/vendor/rails/release.rb +25 -0
- metadata +814 -84
- data/app/views/admin/pages/_edit_styles.html.haml +0 -15
- data/app/views/admin/references/filters.js.erb +0 -5
- data/app/views/admin/references/tags.js.erb +0 -5
- data/features/step_definitions/webrat_steps.rb +0 -117
- data/public/images/admin/add-child.png +0 -0
- data/public/images/admin/clear-page-cache.png +0 -0
- data/public/images/admin/remove-disabled.png +0 -0
- data/public/images/admin/remove.png +0 -0
- data/public/images/admin/view-site.gif +0 -0
- data/public/images/admin/virtual-page.png +0 -0
- data/public/javascripts/admin/admin.js +0 -149
- data/public/javascripts/application.js +0 -2
- data/public/javascripts/pngfix.js +0 -39
- data/public/javascripts/string.js +0 -17
- data/vendor/extensions/markdown_filter/vendor/bluecloth/CHANGES +0 -366
- data/vendor/extensions/markdown_filter/vendor/bluecloth/LICENSE +0 -340
- data/vendor/extensions/markdown_filter/vendor/bluecloth/README +0 -99
- data/vendor/extensions/markdown_filter/vendor/bluecloth/bin/bluecloth +0 -83
- data/vendor/extensions/markdown_filter/vendor/bluecloth/install.rb +0 -150
- data/vendor/extensions/markdown_filter/vendor/bluecloth/lib/bluecloth.rb +0 -1144
- data/vendor/extensions/markdown_filter/vendor/bluecloth/test.rb +0 -117
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/00_Class.tests.rb +0 -71
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/05_Markdown.tests.rb +0 -1527
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/10_Bug.tests.rb +0 -57
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/15_Contrib.tests.rb +0 -132
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/bctestcase.rb +0 -274
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/data/antsugar.txt +0 -34
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/data/ml-announce.txt +0 -17
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/data/re-overflow.txt +0 -67
- data/vendor/extensions/markdown_filter/vendor/bluecloth/tests/data/re-overflow2.txt +0 -281
- data/vendor/extensions/markdown_filter/vendor/bluecloth/utils.rb +0 -553
- data/vendor/radius/ROADMAP +0 -12
- data/vendor/rails/activerecord/test/fixtures/fixture_database.sqlite +0 -0
- data/vendor/rails/activerecord/test/fixtures/fixture_database.sqlite3 +0 -0
- data/vendor/rails/activerecord/test/fixtures/fixture_database_2.sqlite +0 -0
- data/vendor/rails/activerecord/test/fixtures/fixture_database_2.sqlite3 +0 -0
- data/vendor/rails/activeresource/test/debug.log +0 -7974
@@ -0,0 +1,22 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class DuplicableTest < Test::Unit::TestCase
|
4
|
+
NO = [nil, false, true, :symbol, 1, 2.3, BigDecimal.new('4.56'), Class.new]
|
5
|
+
YES = ['1', Object.new, /foo/, [], {}, Time.now]
|
6
|
+
|
7
|
+
def test_duplicable
|
8
|
+
NO.each do |v|
|
9
|
+
assert !v.duplicable?
|
10
|
+
begin
|
11
|
+
v.dup
|
12
|
+
fail
|
13
|
+
rescue Exception
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
YES.each do |v|
|
18
|
+
assert v.duplicable?
|
19
|
+
assert_nothing_raised { v.dup }
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
@@ -0,0 +1,121 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class DurationTest < ActiveSupport::TestCase
|
4
|
+
def test_inspect
|
5
|
+
assert_equal '0 seconds', 0.seconds.inspect
|
6
|
+
assert_equal '1 month', 1.month.inspect
|
7
|
+
assert_equal '1 month and 1 day', (1.month + 1.day).inspect
|
8
|
+
assert_equal '6 months and -2 days', (6.months - 2.days).inspect
|
9
|
+
assert_equal '10 seconds', 10.seconds.inspect
|
10
|
+
assert_equal '10 years, 2 months, and 1 day', (10.years + 2.months + 1.day).inspect
|
11
|
+
assert_equal '7 days', 1.week.inspect
|
12
|
+
assert_equal '14 days', 1.fortnight.inspect
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_minus_with_duration_does_not_break_subtraction_of_date_from_date
|
16
|
+
assert_nothing_raised { Date.today - Date.today }
|
17
|
+
end
|
18
|
+
|
19
|
+
def test_plus_with_time
|
20
|
+
assert_equal 1 + 1.second, 1.second + 1, "Duration + Numeric should == Numeric + Duration"
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_argument_error
|
24
|
+
begin
|
25
|
+
1.second.ago('')
|
26
|
+
flunk("no exception was raised")
|
27
|
+
rescue ArgumentError => e
|
28
|
+
assert_equal 'expected a time or date, got ""', e.message, "ensure ArgumentError is not being raised by dependencies.rb"
|
29
|
+
rescue Exception
|
30
|
+
flunk("ArgumentError should be raised, but we got #{$!.class} instead")
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def test_fractional_weeks
|
35
|
+
assert_equal((86400 * 7) * 1.5, 1.5.weeks)
|
36
|
+
assert_equal((86400 * 7) * 1.7, 1.7.weeks)
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_fractional_days
|
40
|
+
assert_equal 86400 * 1.5, 1.5.days
|
41
|
+
assert_equal 86400 * 1.7, 1.7.days
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_since_and_ago_with_fractional_days
|
45
|
+
t = Time.local(2000)
|
46
|
+
# since
|
47
|
+
assert_equal 36.hours.since(t), 1.5.days.since(t)
|
48
|
+
assert_in_delta((24 * 1.7).hours.since(t), 1.7.days.since(t), 1)
|
49
|
+
# ago
|
50
|
+
assert_equal 36.hours.ago(t), 1.5.days.ago(t)
|
51
|
+
assert_in_delta((24 * 1.7).hours.ago(t), 1.7.days.ago(t), 1)
|
52
|
+
end
|
53
|
+
|
54
|
+
def test_since_and_ago_with_fractional_weeks
|
55
|
+
t = Time.local(2000)
|
56
|
+
# since
|
57
|
+
assert_in_delta((7 * 36).hours.since, 1.5.weeks.since, 1)
|
58
|
+
assert_in_delta((7 * 24 * 1.7).hours.since, 1.7.weeks.since, 1)
|
59
|
+
# ago
|
60
|
+
assert_in_delta((7 * 36).hours.ago, 1.5.weeks.ago, 1)
|
61
|
+
assert_in_delta((7 * 24 * 1.7).hours.ago, 1.7.weeks.ago, 1)
|
62
|
+
end
|
63
|
+
|
64
|
+
def test_deprecated_fractional_years
|
65
|
+
years_re = /Fractional years are not respected\. Convert value to integer before calling #years\./
|
66
|
+
assert_deprecated(years_re){1.0.years}
|
67
|
+
assert_deprecated(years_re){1.5.years}
|
68
|
+
assert_not_deprecated{1.years}
|
69
|
+
assert_deprecated(years_re){1.0.year}
|
70
|
+
assert_deprecated(years_re){1.5.year}
|
71
|
+
assert_not_deprecated{1.year}
|
72
|
+
end
|
73
|
+
|
74
|
+
def test_deprecated_fractional_months
|
75
|
+
months_re = /Fractional months are not respected\. Convert value to integer before calling #months\./
|
76
|
+
assert_deprecated(months_re){1.5.months}
|
77
|
+
assert_deprecated(months_re){1.0.months}
|
78
|
+
assert_not_deprecated{1.months}
|
79
|
+
assert_deprecated(months_re){1.5.month}
|
80
|
+
assert_deprecated(months_re){1.0.month}
|
81
|
+
assert_not_deprecated{1.month}
|
82
|
+
end
|
83
|
+
|
84
|
+
def test_since_and_ago_anchored_to_time_now_when_time_zone_default_not_set
|
85
|
+
Time.zone_default = nil
|
86
|
+
with_env_tz 'US/Eastern' do
|
87
|
+
Time.stubs(:now).returns Time.local(2000)
|
88
|
+
# since
|
89
|
+
assert_equal false, 5.seconds.since.is_a?(ActiveSupport::TimeWithZone)
|
90
|
+
assert_equal Time.local(2000,1,1,0,0,5), 5.seconds.since
|
91
|
+
# ago
|
92
|
+
assert_equal false, 5.seconds.ago.is_a?(ActiveSupport::TimeWithZone)
|
93
|
+
assert_equal Time.local(1999,12,31,23,59,55), 5.seconds.ago
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
def test_since_and_ago_anchored_to_time_zone_now_when_time_zone_default_set
|
98
|
+
Time.zone_default = ActiveSupport::TimeZone['Eastern Time (US & Canada)']
|
99
|
+
with_env_tz 'US/Eastern' do
|
100
|
+
Time.stubs(:now).returns Time.local(2000)
|
101
|
+
# since
|
102
|
+
assert_equal true, 5.seconds.since.is_a?(ActiveSupport::TimeWithZone)
|
103
|
+
assert_equal Time.utc(2000,1,1,0,0,5), 5.seconds.since.time
|
104
|
+
assert_equal 'Eastern Time (US & Canada)', 5.seconds.since.time_zone.name
|
105
|
+
# ago
|
106
|
+
assert_equal true, 5.seconds.ago.is_a?(ActiveSupport::TimeWithZone)
|
107
|
+
assert_equal Time.utc(1999,12,31,23,59,55), 5.seconds.ago.time
|
108
|
+
assert_equal 'Eastern Time (US & Canada)', 5.seconds.ago.time_zone.name
|
109
|
+
end
|
110
|
+
ensure
|
111
|
+
Time.zone_default = nil
|
112
|
+
end
|
113
|
+
|
114
|
+
protected
|
115
|
+
def with_env_tz(new_tz = 'US/Eastern')
|
116
|
+
old_tz, ENV['TZ'] = ENV['TZ'], new_tz
|
117
|
+
yield
|
118
|
+
ensure
|
119
|
+
old_tz ? ENV['TZ'] = old_tz : ENV.delete('TZ')
|
120
|
+
end
|
121
|
+
end
|
@@ -0,0 +1,97 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
Payment = Struct.new(:price)
|
4
|
+
class SummablePayment < Payment
|
5
|
+
def +(p) self.class.new(price + p.price) end
|
6
|
+
end
|
7
|
+
|
8
|
+
class EnumerableTests < Test::Unit::TestCase
|
9
|
+
def test_group_by
|
10
|
+
names = %w(marcel sam david jeremy)
|
11
|
+
klass = Struct.new(:name)
|
12
|
+
objects = (1..50).inject([]) do |people,|
|
13
|
+
p = klass.new
|
14
|
+
p.name = names.sort_by { rand }.first
|
15
|
+
people << p
|
16
|
+
end
|
17
|
+
|
18
|
+
grouped = objects.group_by { |object| object.name }
|
19
|
+
|
20
|
+
grouped.each do |name, group|
|
21
|
+
assert group.all? { |person| person.name == name }
|
22
|
+
end
|
23
|
+
|
24
|
+
assert_equal objects.uniq.map(&:name), grouped.keys
|
25
|
+
assert({}.merge(grouped), "Could not convert ActiveSupport::OrderedHash into Hash")
|
26
|
+
end
|
27
|
+
|
28
|
+
def test_sums
|
29
|
+
assert_equal 30, [5, 15, 10].sum
|
30
|
+
assert_equal 30, [5, 15, 10].sum { |i| i }
|
31
|
+
|
32
|
+
assert_equal 'abc', %w(a b c).sum
|
33
|
+
assert_equal 'abc', %w(a b c).sum { |i| i }
|
34
|
+
|
35
|
+
payments = [ Payment.new(5), Payment.new(15), Payment.new(10) ]
|
36
|
+
assert_equal 30, payments.sum(&:price)
|
37
|
+
assert_equal 60, payments.sum { |p| p.price * 2 }
|
38
|
+
|
39
|
+
payments = [ SummablePayment.new(5), SummablePayment.new(15) ]
|
40
|
+
assert_equal SummablePayment.new(20), payments.sum
|
41
|
+
assert_equal SummablePayment.new(20), payments.sum { |p| p }
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_nil_sums
|
45
|
+
expected_raise = TypeError
|
46
|
+
|
47
|
+
assert_raise(expected_raise) { [5, 15, nil].sum }
|
48
|
+
|
49
|
+
payments = [ Payment.new(5), Payment.new(15), Payment.new(10), Payment.new(nil) ]
|
50
|
+
assert_raise(expected_raise) { payments.sum(&:price) }
|
51
|
+
|
52
|
+
assert_equal 60, payments.sum { |p| p.price.to_i * 2 }
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_empty_sums
|
56
|
+
assert_equal 0, [].sum
|
57
|
+
assert_equal 0, [].sum { |i| i }
|
58
|
+
assert_equal Payment.new(0), [].sum(Payment.new(0))
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_enumerable_sums
|
62
|
+
assert_equal 10, (1..4).sum
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_each_with_object
|
66
|
+
result = %w(foo bar).each_with_object({}) { |str, hsh| hsh[str] = str.upcase }
|
67
|
+
assert_equal({'foo' => 'FOO', 'bar' => 'BAR'}, result)
|
68
|
+
end
|
69
|
+
|
70
|
+
def test_index_by
|
71
|
+
payments = [ Payment.new(5), Payment.new(15), Payment.new(10) ]
|
72
|
+
assert_equal({ 5 => payments[0], 15 => payments[1], 10 => payments[2] },
|
73
|
+
payments.index_by { |p| p.price })
|
74
|
+
end
|
75
|
+
|
76
|
+
def test_many
|
77
|
+
assert ![].many?
|
78
|
+
assert ![ 1 ].many?
|
79
|
+
assert [ 1, 2 ].many?
|
80
|
+
|
81
|
+
assert ![].many? {|x| x > 1 }
|
82
|
+
assert ![ 2 ].many? {|x| x > 1 }
|
83
|
+
assert ![ 1, 2 ].many? {|x| x > 1 }
|
84
|
+
assert [ 1, 2, 2 ].many? {|x| x > 1 }
|
85
|
+
end
|
86
|
+
|
87
|
+
def test_none
|
88
|
+
assert [].none?
|
89
|
+
assert [nil, false].none?
|
90
|
+
assert ![1].none?
|
91
|
+
|
92
|
+
assert [].none? {|x| x > 1 }
|
93
|
+
assert ![ 2 ].none? {|x| x > 1 }
|
94
|
+
assert ![ 1, 2 ].none? {|x| x > 1 }
|
95
|
+
assert [ 1, 1 ].none? {|x| x > 1 }
|
96
|
+
end
|
97
|
+
end
|
@@ -0,0 +1,68 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class ExceptionExtTests < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def get_exception(cls = RuntimeError, msg = nil, trace = nil)
|
6
|
+
begin raise cls, msg, (trace || caller)
|
7
|
+
rescue Exception => e # passed Exception
|
8
|
+
return e
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
def setup
|
13
|
+
Exception::TraceSubstitutions.clear
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_clean_backtrace
|
17
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
18
|
+
e = get_exception RuntimeError, 'RAWR', ['bhal.rb', 'rawh hid den stuff is not here', 'almost all']
|
19
|
+
assert_kind_of Exception, e
|
20
|
+
assert_equal ['bhal.rb', 'rawh hid den stuff is not here', 'almost all'], e.clean_backtrace
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_app_backtrace
|
24
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
25
|
+
e = get_exception RuntimeError, 'RAWR', ['bhal.rb', ' vendor/file.rb some stuff', 'almost all']
|
26
|
+
assert_kind_of Exception, e
|
27
|
+
assert_equal ['bhal.rb', 'almost all'], e.application_backtrace
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_app_backtrace_with_before
|
31
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
32
|
+
e = get_exception RuntimeError, 'RAWR', ['vendor/file.rb some stuff', 'bhal.rb', ' vendor/file.rb some stuff', 'almost all']
|
33
|
+
assert_kind_of Exception, e
|
34
|
+
assert_equal ['vendor/file.rb some stuff', 'bhal.rb', 'almost all'], e.application_backtrace
|
35
|
+
end
|
36
|
+
|
37
|
+
def test_framework_backtrace_with_before
|
38
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
39
|
+
e = get_exception RuntimeError, 'RAWR', ['vendor/file.rb some stuff', 'bhal.rb', ' vendor/file.rb some stuff', 'almost all']
|
40
|
+
assert_kind_of Exception, e
|
41
|
+
assert_equal ['vendor/file.rb some stuff', ' vendor/file.rb some stuff'], e.framework_backtrace
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_backtrace_should_clean_paths
|
45
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
46
|
+
e = get_exception RuntimeError, 'RAWR', ['a/b/c/../d/../../../bhal.rb', 'rawh hid den stuff is not here', 'almost all']
|
47
|
+
assert_kind_of Exception, e
|
48
|
+
assert_equal ['bhal.rb', 'rawh hid den stuff is not here', 'almost all'], e.clean_backtrace
|
49
|
+
end
|
50
|
+
|
51
|
+
def test_clean_message_should_clean_paths
|
52
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
53
|
+
e = get_exception RuntimeError, "I dislike a/z/x/../../b/y/../c", ['a/b/c/../d/../../../bhal.rb', 'rawh hid den stuff is not here', 'almost all']
|
54
|
+
assert_kind_of Exception, e
|
55
|
+
assert_equal "I dislike a/b/c", e.clean_message
|
56
|
+
end
|
57
|
+
|
58
|
+
def test_app_trace_should_be_empty_when_no_app_frames
|
59
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
60
|
+
e = get_exception RuntimeError, 'RAWR', ['vendor/file.rb some stuff', 'generated/bhal.rb', ' vendor/file.rb some stuff', 'generated/almost all']
|
61
|
+
assert_kind_of Exception, e
|
62
|
+
assert_equal [], e.application_backtrace
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_frozen_error
|
66
|
+
assert_raise(ActiveSupport::FrozenObjectError) { "foo".freeze.gsub!(/oo/,'aa') }
|
67
|
+
end
|
68
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class AtomicWriteTest < Test::Unit::TestCase
|
4
|
+
def test_atomic_write_without_errors
|
5
|
+
contents = "Atomic Text"
|
6
|
+
File.atomic_write(file_name, Dir.pwd) do |file|
|
7
|
+
file.write(contents)
|
8
|
+
assert !File.exist?(file_name)
|
9
|
+
end
|
10
|
+
assert File.exist?(file_name)
|
11
|
+
assert_equal contents, File.read(file_name)
|
12
|
+
ensure
|
13
|
+
File.unlink(file_name) rescue nil
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_atomic_write_doesnt_write_when_block_raises
|
17
|
+
File.atomic_write(file_name) do |file|
|
18
|
+
file.write("testing")
|
19
|
+
raise "something bad"
|
20
|
+
end
|
21
|
+
rescue
|
22
|
+
assert !File.exist?(file_name)
|
23
|
+
end
|
24
|
+
|
25
|
+
def test_atomic_write_preserves_file_permissions
|
26
|
+
contents = "Atomic Text"
|
27
|
+
File.open(file_name, "w", 0755) do |file|
|
28
|
+
file.write(contents)
|
29
|
+
assert File.exist?(file_name)
|
30
|
+
end
|
31
|
+
assert File.exist?(file_name)
|
32
|
+
assert_equal 0100755, file_mode
|
33
|
+
assert_equal contents, File.read(file_name)
|
34
|
+
|
35
|
+
File.atomic_write(file_name, Dir.pwd) do |file|
|
36
|
+
file.write(contents)
|
37
|
+
assert File.exist?(file_name)
|
38
|
+
end
|
39
|
+
assert File.exist?(file_name)
|
40
|
+
assert_equal 0100755, file_mode
|
41
|
+
assert_equal contents, File.read(file_name)
|
42
|
+
ensure
|
43
|
+
File.unlink(file_name) rescue nil
|
44
|
+
end
|
45
|
+
|
46
|
+
def test_atomic_write_preserves_default_file_permissions
|
47
|
+
contents = "Atomic Text"
|
48
|
+
File.atomic_write(file_name, Dir.pwd) do |file|
|
49
|
+
file.write(contents)
|
50
|
+
assert !File.exist?(file_name)
|
51
|
+
end
|
52
|
+
assert File.exist?(file_name)
|
53
|
+
assert_equal 0100666 ^ File.umask, file_mode
|
54
|
+
assert_equal contents, File.read(file_name)
|
55
|
+
ensure
|
56
|
+
File.unlink(file_name) rescue nil
|
57
|
+
end
|
58
|
+
|
59
|
+
private
|
60
|
+
def file_name
|
61
|
+
"atomic.file"
|
62
|
+
end
|
63
|
+
|
64
|
+
def file_mode
|
65
|
+
File.stat(file_name).mode
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class FloatExtRoundingTests < Test::Unit::TestCase
|
4
|
+
def test_round_for_positive_number
|
5
|
+
assert_equal 1, 1.4.round
|
6
|
+
assert_equal 2, 1.6.round
|
7
|
+
assert_equal 2, 1.6.round(0)
|
8
|
+
assert_equal 1.4, 1.4.round(1)
|
9
|
+
assert_equal 1.4, 1.4.round(3)
|
10
|
+
assert_equal 1.5, 1.45.round(1)
|
11
|
+
assert_equal 1.45, 1.445.round(2)
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_round_for_negative_number
|
15
|
+
assert_equal( -1, -1.4.round )
|
16
|
+
assert_equal( -2, -1.6.round )
|
17
|
+
assert_equal( -1.4, -1.4.round(1) )
|
18
|
+
assert_equal( -1.5, -1.45.round(1) )
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_round_with_negative_precision
|
22
|
+
assert_equal 123460.0, 123456.0.round(-1)
|
23
|
+
assert_equal 123500.0, 123456.0.round(-2)
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,1014 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
require 'builder'
|
3
|
+
|
4
|
+
class HashExtTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@strings = { 'a' => 1, 'b' => 2 }
|
7
|
+
@symbols = { :a => 1, :b => 2 }
|
8
|
+
@mixed = { :a => 1, 'b' => 2 }
|
9
|
+
@fixnums = { 0 => 1, 1 => 2 }
|
10
|
+
if RUBY_VERSION < '1.9.0'
|
11
|
+
@illegal_symbols = { "\0" => 1, "" => 2, [] => 3 }
|
12
|
+
else
|
13
|
+
@illegal_symbols = { [] => 3 }
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
def test_methods
|
18
|
+
h = {}
|
19
|
+
assert_respond_to h, :symbolize_keys
|
20
|
+
assert_respond_to h, :symbolize_keys!
|
21
|
+
assert_respond_to h, :stringify_keys
|
22
|
+
assert_respond_to h, :stringify_keys!
|
23
|
+
assert_respond_to h, :to_options
|
24
|
+
assert_respond_to h, :to_options!
|
25
|
+
end
|
26
|
+
|
27
|
+
def test_symbolize_keys
|
28
|
+
assert_equal @symbols, @symbols.symbolize_keys
|
29
|
+
assert_equal @symbols, @strings.symbolize_keys
|
30
|
+
assert_equal @symbols, @mixed.symbolize_keys
|
31
|
+
end
|
32
|
+
|
33
|
+
def test_symbolize_keys!
|
34
|
+
assert_equal @symbols, @symbols.dup.symbolize_keys!
|
35
|
+
assert_equal @symbols, @strings.dup.symbolize_keys!
|
36
|
+
assert_equal @symbols, @mixed.dup.symbolize_keys!
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_symbolize_keys_preserves_keys_that_cant_be_symbolized
|
40
|
+
assert_equal @illegal_symbols, @illegal_symbols.symbolize_keys
|
41
|
+
assert_equal @illegal_symbols, @illegal_symbols.dup.symbolize_keys!
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_symbolize_keys_preserves_fixnum_keys
|
45
|
+
assert_equal @fixnums, @fixnums.symbolize_keys
|
46
|
+
assert_equal @fixnums, @fixnums.dup.symbolize_keys!
|
47
|
+
end
|
48
|
+
|
49
|
+
def test_stringify_keys
|
50
|
+
assert_equal @strings, @symbols.stringify_keys
|
51
|
+
assert_equal @strings, @strings.stringify_keys
|
52
|
+
assert_equal @strings, @mixed.stringify_keys
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_stringify_keys!
|
56
|
+
assert_equal @strings, @symbols.dup.stringify_keys!
|
57
|
+
assert_equal @strings, @strings.dup.stringify_keys!
|
58
|
+
assert_equal @strings, @mixed.dup.stringify_keys!
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_indifferent_assorted
|
62
|
+
@strings = @strings.with_indifferent_access
|
63
|
+
@symbols = @symbols.with_indifferent_access
|
64
|
+
@mixed = @mixed.with_indifferent_access
|
65
|
+
|
66
|
+
assert_equal 'a', @strings.__send__(:convert_key, :a)
|
67
|
+
|
68
|
+
assert_equal 1, @strings.fetch('a')
|
69
|
+
assert_equal 1, @strings.fetch(:a.to_s)
|
70
|
+
assert_equal 1, @strings.fetch(:a)
|
71
|
+
|
72
|
+
hashes = { :@strings => @strings, :@symbols => @symbols, :@mixed => @mixed }
|
73
|
+
method_map = { :'[]' => 1, :fetch => 1, :values_at => [1],
|
74
|
+
:has_key? => true, :include? => true, :key? => true,
|
75
|
+
:member? => true }
|
76
|
+
|
77
|
+
hashes.each do |name, hash|
|
78
|
+
method_map.sort_by { |m| m.to_s }.each do |meth, expected|
|
79
|
+
assert_equal(expected, hash.__send__(meth, 'a'),
|
80
|
+
"Calling #{name}.#{meth} 'a'")
|
81
|
+
assert_equal(expected, hash.__send__(meth, :a),
|
82
|
+
"Calling #{name}.#{meth} :a")
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
assert_equal [1, 2], @strings.values_at('a', 'b')
|
87
|
+
assert_equal [1, 2], @strings.values_at(:a, :b)
|
88
|
+
assert_equal [1, 2], @symbols.values_at('a', 'b')
|
89
|
+
assert_equal [1, 2], @symbols.values_at(:a, :b)
|
90
|
+
assert_equal [1, 2], @mixed.values_at('a', 'b')
|
91
|
+
assert_equal [1, 2], @mixed.values_at(:a, :b)
|
92
|
+
end
|
93
|
+
|
94
|
+
def test_indifferent_reading
|
95
|
+
hash = HashWithIndifferentAccess.new
|
96
|
+
hash["a"] = 1
|
97
|
+
hash["b"] = true
|
98
|
+
hash["c"] = false
|
99
|
+
hash["d"] = nil
|
100
|
+
|
101
|
+
assert_equal 1, hash[:a]
|
102
|
+
assert_equal true, hash[:b]
|
103
|
+
assert_equal false, hash[:c]
|
104
|
+
assert_equal nil, hash[:d]
|
105
|
+
assert_equal nil, hash[:e]
|
106
|
+
end
|
107
|
+
|
108
|
+
def test_indifferent_reading_with_nonnil_default
|
109
|
+
hash = HashWithIndifferentAccess.new(1)
|
110
|
+
hash["a"] = 1
|
111
|
+
hash["b"] = true
|
112
|
+
hash["c"] = false
|
113
|
+
hash["d"] = nil
|
114
|
+
|
115
|
+
assert_equal 1, hash[:a]
|
116
|
+
assert_equal true, hash[:b]
|
117
|
+
assert_equal false, hash[:c]
|
118
|
+
assert_equal nil, hash[:d]
|
119
|
+
assert_equal 1, hash[:e]
|
120
|
+
end
|
121
|
+
|
122
|
+
def test_indifferent_writing
|
123
|
+
hash = HashWithIndifferentAccess.new
|
124
|
+
hash[:a] = 1
|
125
|
+
hash['b'] = 2
|
126
|
+
hash[3] = 3
|
127
|
+
|
128
|
+
assert_equal hash['a'], 1
|
129
|
+
assert_equal hash['b'], 2
|
130
|
+
assert_equal hash[:a], 1
|
131
|
+
assert_equal hash[:b], 2
|
132
|
+
assert_equal hash[3], 3
|
133
|
+
end
|
134
|
+
|
135
|
+
def test_indifferent_update
|
136
|
+
hash = HashWithIndifferentAccess.new
|
137
|
+
hash[:a] = 'a'
|
138
|
+
hash['b'] = 'b'
|
139
|
+
|
140
|
+
updated_with_strings = hash.update(@strings)
|
141
|
+
updated_with_symbols = hash.update(@symbols)
|
142
|
+
updated_with_mixed = hash.update(@mixed)
|
143
|
+
|
144
|
+
assert_equal updated_with_strings[:a], 1
|
145
|
+
assert_equal updated_with_strings['a'], 1
|
146
|
+
assert_equal updated_with_strings['b'], 2
|
147
|
+
|
148
|
+
assert_equal updated_with_symbols[:a], 1
|
149
|
+
assert_equal updated_with_symbols['b'], 2
|
150
|
+
assert_equal updated_with_symbols[:b], 2
|
151
|
+
|
152
|
+
assert_equal updated_with_mixed[:a], 1
|
153
|
+
assert_equal updated_with_mixed['b'], 2
|
154
|
+
|
155
|
+
assert [updated_with_strings, updated_with_symbols, updated_with_mixed].all? { |h| h.keys.size == 2 }
|
156
|
+
end
|
157
|
+
|
158
|
+
def test_indifferent_merging
|
159
|
+
hash = HashWithIndifferentAccess.new
|
160
|
+
hash[:a] = 'failure'
|
161
|
+
hash['b'] = 'failure'
|
162
|
+
|
163
|
+
other = { 'a' => 1, :b => 2 }
|
164
|
+
|
165
|
+
merged = hash.merge(other)
|
166
|
+
|
167
|
+
assert_equal HashWithIndifferentAccess, merged.class
|
168
|
+
assert_equal 1, merged[:a]
|
169
|
+
assert_equal 2, merged['b']
|
170
|
+
|
171
|
+
hash.update(other)
|
172
|
+
|
173
|
+
assert_equal 1, hash[:a]
|
174
|
+
assert_equal 2, hash['b']
|
175
|
+
end
|
176
|
+
|
177
|
+
def test_indifferent_reverse_merging
|
178
|
+
hash = HashWithIndifferentAccess.new('some' => 'value', 'other' => 'value')
|
179
|
+
hash.reverse_merge!(:some => 'noclobber', :another => 'clobber')
|
180
|
+
assert_equal 'value', hash[:some]
|
181
|
+
assert_equal 'clobber', hash[:another]
|
182
|
+
end
|
183
|
+
|
184
|
+
def test_indifferent_deleting
|
185
|
+
get_hash = proc{ { :a => 'foo' }.with_indifferent_access }
|
186
|
+
hash = get_hash.call
|
187
|
+
assert_equal hash.delete(:a), 'foo'
|
188
|
+
assert_equal hash.delete(:a), nil
|
189
|
+
hash = get_hash.call
|
190
|
+
assert_equal hash.delete('a'), 'foo'
|
191
|
+
assert_equal hash.delete('a'), nil
|
192
|
+
end
|
193
|
+
|
194
|
+
def test_indifferent_to_hash
|
195
|
+
# Should convert to a Hash with String keys.
|
196
|
+
assert_equal @strings, @mixed.with_indifferent_access.to_hash
|
197
|
+
|
198
|
+
# Should preserve the default value.
|
199
|
+
mixed_with_default = @mixed.dup
|
200
|
+
mixed_with_default.default = '1234'
|
201
|
+
roundtrip = mixed_with_default.with_indifferent_access.to_hash
|
202
|
+
assert_equal @strings, roundtrip
|
203
|
+
assert_equal '1234', roundtrip.default
|
204
|
+
end
|
205
|
+
|
206
|
+
def test_indifferent_hash_with_array_of_hashes
|
207
|
+
hash = { "urls" => { "url" => [ { "address" => "1" }, { "address" => "2" } ] }}.with_indifferent_access
|
208
|
+
assert_equal "1", hash[:urls][:url].first[:address]
|
209
|
+
end
|
210
|
+
|
211
|
+
def test_stringify_and_symbolize_keys_on_indifferent_preserves_hash
|
212
|
+
h = HashWithIndifferentAccess.new
|
213
|
+
h[:first] = 1
|
214
|
+
h.stringify_keys!
|
215
|
+
assert_equal 1, h['first']
|
216
|
+
h = HashWithIndifferentAccess.new
|
217
|
+
h['first'] = 1
|
218
|
+
h.symbolize_keys!
|
219
|
+
assert_equal 1, h[:first]
|
220
|
+
end
|
221
|
+
|
222
|
+
def test_to_options_on_indifferent_preserves_hash
|
223
|
+
h = HashWithIndifferentAccess.new
|
224
|
+
h['first'] = 1
|
225
|
+
h.to_options!
|
226
|
+
assert_equal 1, h['first']
|
227
|
+
end
|
228
|
+
|
229
|
+
|
230
|
+
def test_indifferent_subhashes
|
231
|
+
h = {'user' => {'id' => 5}}.with_indifferent_access
|
232
|
+
['user', :user].each {|user| [:id, 'id'].each {|id| assert_equal 5, h[user][id], "h[#{user.inspect}][#{id.inspect}] should be 5"}}
|
233
|
+
|
234
|
+
h = {:user => {:id => 5}}.with_indifferent_access
|
235
|
+
['user', :user].each {|user| [:id, 'id'].each {|id| assert_equal 5, h[user][id], "h[#{user.inspect}][#{id.inspect}] should be 5"}}
|
236
|
+
end
|
237
|
+
|
238
|
+
def test_assert_valid_keys
|
239
|
+
assert_nothing_raised do
|
240
|
+
{ :failure => "stuff", :funny => "business" }.assert_valid_keys([ :failure, :funny ])
|
241
|
+
{ :failure => "stuff", :funny => "business" }.assert_valid_keys(:failure, :funny)
|
242
|
+
end
|
243
|
+
|
244
|
+
assert_raise(ArgumentError, "Unknown key(s): failore") do
|
245
|
+
{ :failore => "stuff", :funny => "business" }.assert_valid_keys([ :failure, :funny ])
|
246
|
+
{ :failore => "stuff", :funny => "business" }.assert_valid_keys(:failure, :funny)
|
247
|
+
end
|
248
|
+
end
|
249
|
+
|
250
|
+
def test_assorted_keys_not_stringified
|
251
|
+
original = {Object.new => 2, 1 => 2, [] => true}
|
252
|
+
indiff = original.with_indifferent_access
|
253
|
+
assert(!indiff.keys.any? {|k| k.kind_of? String}, "A key was converted to a string!")
|
254
|
+
end
|
255
|
+
|
256
|
+
def test_deep_merge
|
257
|
+
hash_1 = { :a => "a", :b => "b", :c => { :c1 => "c1", :c2 => "c2", :c3 => { :d1 => "d1" } } }
|
258
|
+
hash_2 = { :a => 1, :c => { :c1 => 2, :c3 => { :d2 => "d2" } } }
|
259
|
+
expected = { :a => 1, :b => "b", :c => { :c1 => 2, :c2 => "c2", :c3 => { :d1 => "d1", :d2 => "d2" } } }
|
260
|
+
assert_equal expected, hash_1.deep_merge(hash_2)
|
261
|
+
|
262
|
+
hash_1.deep_merge!(hash_2)
|
263
|
+
assert_equal expected, hash_1
|
264
|
+
end
|
265
|
+
|
266
|
+
def test_reverse_merge
|
267
|
+
defaults = { :a => "x", :b => "y", :c => 10 }.freeze
|
268
|
+
options = { :a => 1, :b => 2 }
|
269
|
+
expected = { :a => 1, :b => 2, :c => 10 }
|
270
|
+
|
271
|
+
# Should merge defaults into options, creating a new hash.
|
272
|
+
assert_equal expected, options.reverse_merge(defaults)
|
273
|
+
assert_not_equal expected, options
|
274
|
+
|
275
|
+
# Should merge! defaults into options, replacing options.
|
276
|
+
merged = options.dup
|
277
|
+
assert_equal expected, merged.reverse_merge!(defaults)
|
278
|
+
assert_equal expected, merged
|
279
|
+
|
280
|
+
# Should be an alias for reverse_merge!
|
281
|
+
merged = options.dup
|
282
|
+
assert_equal expected, merged.reverse_update(defaults)
|
283
|
+
assert_equal expected, merged
|
284
|
+
end
|
285
|
+
|
286
|
+
def test_diff
|
287
|
+
assert_equal({ :a => 2 }, { :a => 2, :b => 5 }.diff({ :a => 1, :b => 5 }))
|
288
|
+
end
|
289
|
+
|
290
|
+
def test_slice
|
291
|
+
original = { :a => 'x', :b => 'y', :c => 10 }
|
292
|
+
expected = { :a => 'x', :b => 'y' }
|
293
|
+
|
294
|
+
# Should return a new hash with only the given keys.
|
295
|
+
assert_equal expected, original.slice(:a, :b)
|
296
|
+
assert_not_equal expected, original
|
297
|
+
end
|
298
|
+
|
299
|
+
def test_slice_inplace
|
300
|
+
original = { :a => 'x', :b => 'y', :c => 10 }
|
301
|
+
expected = { :c => 10 }
|
302
|
+
|
303
|
+
# Should replace the hash with only the given keys.
|
304
|
+
assert_equal expected, original.slice!(:a, :b)
|
305
|
+
end
|
306
|
+
|
307
|
+
def test_slice_with_an_array_key
|
308
|
+
original = { :a => 'x', :b => 'y', :c => 10, [:a, :b] => "an array key" }
|
309
|
+
expected = { [:a, :b] => "an array key", :c => 10 }
|
310
|
+
|
311
|
+
# Should return a new hash with only the given keys when given an array key.
|
312
|
+
assert_equal expected, original.slice([:a, :b], :c)
|
313
|
+
assert_not_equal expected, original
|
314
|
+
end
|
315
|
+
|
316
|
+
def test_slice_inplace_with_an_array_key
|
317
|
+
original = { :a => 'x', :b => 'y', :c => 10, [:a, :b] => "an array key" }
|
318
|
+
expected = { :a => 'x', :b => 'y' }
|
319
|
+
|
320
|
+
# Should replace the hash with only the given keys when given an array key.
|
321
|
+
assert_equal expected, original.slice!([:a, :b], :c)
|
322
|
+
end
|
323
|
+
|
324
|
+
def test_slice_with_splatted_keys
|
325
|
+
original = { :a => 'x', :b => 'y', :c => 10, [:a, :b] => "an array key" }
|
326
|
+
expected = { :a => 'x', :b => "y" }
|
327
|
+
|
328
|
+
# Should grab each of the splatted keys.
|
329
|
+
assert_equal expected, original.slice(*[:a, :b])
|
330
|
+
end
|
331
|
+
|
332
|
+
def test_indifferent_slice
|
333
|
+
original = { :a => 'x', :b => 'y', :c => 10 }.with_indifferent_access
|
334
|
+
expected = { :a => 'x', :b => 'y' }.with_indifferent_access
|
335
|
+
|
336
|
+
[['a', 'b'], [:a, :b]].each do |keys|
|
337
|
+
# Should return a new hash with only the given keys.
|
338
|
+
assert_equal expected, original.slice(*keys), keys.inspect
|
339
|
+
assert_not_equal expected, original
|
340
|
+
end
|
341
|
+
end
|
342
|
+
|
343
|
+
def test_indifferent_slice_inplace
|
344
|
+
original = { :a => 'x', :b => 'y', :c => 10 }.with_indifferent_access
|
345
|
+
expected = { :c => 10 }.with_indifferent_access
|
346
|
+
|
347
|
+
[['a', 'b'], [:a, :b]].each do |keys|
|
348
|
+
# Should replace the hash with only the given keys.
|
349
|
+
copy = original.dup
|
350
|
+
assert_equal expected, copy.slice!(*keys)
|
351
|
+
end
|
352
|
+
end
|
353
|
+
|
354
|
+
def test_indifferent_slice_access_with_symbols
|
355
|
+
original = {'login' => 'bender', 'password' => 'shiny', 'stuff' => 'foo'}
|
356
|
+
original = original.with_indifferent_access
|
357
|
+
|
358
|
+
slice = original.slice(:login, :password)
|
359
|
+
|
360
|
+
assert_equal 'bender', slice[:login]
|
361
|
+
assert_equal 'bender', slice['login']
|
362
|
+
end
|
363
|
+
|
364
|
+
def test_except
|
365
|
+
original = { :a => 'x', :b => 'y', :c => 10 }
|
366
|
+
expected = { :a => 'x', :b => 'y' }
|
367
|
+
|
368
|
+
# Should return a new hash with only the given keys.
|
369
|
+
assert_equal expected, original.except(:c)
|
370
|
+
assert_not_equal expected, original
|
371
|
+
|
372
|
+
# Should replace the hash with only the given keys.
|
373
|
+
assert_equal expected, original.except!(:c)
|
374
|
+
assert_equal expected, original
|
375
|
+
end
|
376
|
+
|
377
|
+
def test_except_with_original_frozen
|
378
|
+
original = { :a => 'x', :b => 'y' }
|
379
|
+
original.freeze
|
380
|
+
assert_nothing_raised { original.except(:a) }
|
381
|
+
end
|
382
|
+
|
383
|
+
def test_except_with_mocha_expectation_on_original
|
384
|
+
original = { :a => 'x', :b => 'y' }
|
385
|
+
original.expects(:delete).never
|
386
|
+
original.except(:a)
|
387
|
+
end
|
388
|
+
end
|
389
|
+
|
390
|
+
class IWriteMyOwnXML
|
391
|
+
def to_xml(options = {})
|
392
|
+
options[:indent] ||= 2
|
393
|
+
xml = options[:builder] ||= Builder::XmlMarkup.new(:indent => options[:indent])
|
394
|
+
xml.instruct! unless options[:skip_instruct]
|
395
|
+
xml.level_one do
|
396
|
+
xml.tag!(:second_level, 'content')
|
397
|
+
end
|
398
|
+
end
|
399
|
+
end
|
400
|
+
|
401
|
+
class HashToXmlTest < Test::Unit::TestCase
|
402
|
+
def setup
|
403
|
+
@xml_options = { :root => :person, :skip_instruct => true, :indent => 0 }
|
404
|
+
end
|
405
|
+
|
406
|
+
def test_default_values_for_rename_keys
|
407
|
+
assert_equal true,ActiveSupport.dasherize_xml
|
408
|
+
assert_equal false,ActiveSupport.camelize_xml
|
409
|
+
end
|
410
|
+
|
411
|
+
def test_one_level
|
412
|
+
xml = { :name => "David", :street => "Paulina" }.to_xml(@xml_options)
|
413
|
+
assert_equal "<person>", xml.first(8)
|
414
|
+
assert xml.include?(%(<street>Paulina</street>))
|
415
|
+
assert xml.include?(%(<name>David</name>))
|
416
|
+
end
|
417
|
+
# we add :camelize => false because otherwise we'd be accidentally testing the default value for :camelize
|
418
|
+
def test_one_level_dasherize_false
|
419
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => false,:camelize=>false))
|
420
|
+
assert_equal "<person>", xml.first(8)
|
421
|
+
assert xml.include?(%(<street_name>Paulina</street_name>))
|
422
|
+
assert xml.include?(%(<name>David</name>))
|
423
|
+
end
|
424
|
+
|
425
|
+
def test_one_level_dasherize_true
|
426
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => true,:camelize=>false))
|
427
|
+
assert_equal "<person>", xml.first(8)
|
428
|
+
assert xml.include?(%(<street-name>Paulina</street-name>))
|
429
|
+
assert xml.include?(%(<name>David</name>))
|
430
|
+
end
|
431
|
+
|
432
|
+
def test_one_level_dasherize_default_false
|
433
|
+
current_default = ActiveSupport.dasherize_xml
|
434
|
+
ActiveSupport.dasherize_xml = false
|
435
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:camelize=>false))
|
436
|
+
assert_equal "<person>", xml.first(8)
|
437
|
+
assert xml.include?(%(<street_name>Paulina</street_name>))
|
438
|
+
assert xml.include?(%(<name>David</name>))
|
439
|
+
ensure
|
440
|
+
ActiveSupport.dasherize_xml = current_default
|
441
|
+
end
|
442
|
+
|
443
|
+
def test_one_level_dasherize_default_true
|
444
|
+
current_default = ActiveSupport.dasherize_xml
|
445
|
+
ActiveSupport.dasherize_xml = true
|
446
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:camelize=>false))
|
447
|
+
assert_equal "<person>", xml.first(8)
|
448
|
+
assert xml.include?(%(<street-name>Paulina</street-name>))
|
449
|
+
assert xml.include?(%(<name>David</name>))
|
450
|
+
ensure
|
451
|
+
ActiveSupport.dasherize_xml = current_default
|
452
|
+
end
|
453
|
+
|
454
|
+
def test_one_level_camelize_true
|
455
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:camelize => true,:dasherize => false))
|
456
|
+
assert_equal "<Person>", xml.first(8)
|
457
|
+
assert xml.include?(%(<StreetName>Paulina</StreetName>))
|
458
|
+
assert xml.include?(%(<Name>David</Name>))
|
459
|
+
end
|
460
|
+
|
461
|
+
#camelize=>false is already tested above
|
462
|
+
|
463
|
+
def test_one_level_camelize_default_false
|
464
|
+
current_default = ActiveSupport.camelize_xml
|
465
|
+
ActiveSupport.camelize_xml = false
|
466
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => false))
|
467
|
+
assert_equal "<person>", xml.first(8)
|
468
|
+
assert xml.include?(%(<street_name>Paulina</street_name>))
|
469
|
+
assert xml.include?(%(<name>David</name>))
|
470
|
+
ensure
|
471
|
+
ActiveSupport.camelize_xml = current_default
|
472
|
+
end
|
473
|
+
|
474
|
+
def test_one_level_camelize_default_true
|
475
|
+
current_default = ActiveSupport.camelize_xml
|
476
|
+
ActiveSupport.camelize_xml = true
|
477
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => false))
|
478
|
+
assert_equal "<Person>", xml.first(8)
|
479
|
+
assert xml.include?(%(<StreetName>Paulina</StreetName>))
|
480
|
+
assert xml.include?(%(<Name>David</Name>))
|
481
|
+
ensure
|
482
|
+
ActiveSupport.camelize_xml = current_default
|
483
|
+
end
|
484
|
+
|
485
|
+
def test_one_level_camelize_true_dasherize_true
|
486
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => true,:camelize=>true))
|
487
|
+
assert_equal "<Person>", xml.first(8)
|
488
|
+
assert xml.include?(%(<StreetName>Paulina</StreetName>))
|
489
|
+
assert xml.include?(%(<Name>David</Name>))
|
490
|
+
end
|
491
|
+
|
492
|
+
def test_one_level_with_types
|
493
|
+
xml = { :name => "David", :street => "Paulina", :age => 26, :age_in_millis => 820497600000, :moved_on => Date.new(2005, 11, 15), :resident => :yes }.to_xml(@xml_options)
|
494
|
+
assert_equal "<person>", xml.first(8)
|
495
|
+
assert xml.include?(%(<street>Paulina</street>))
|
496
|
+
assert xml.include?(%(<name>David</name>))
|
497
|
+
assert xml.include?(%(<age type="integer">26</age>))
|
498
|
+
assert xml.include?(%(<age-in-millis type="integer">820497600000</age-in-millis>))
|
499
|
+
assert xml.include?(%(<moved-on type="date">2005-11-15</moved-on>))
|
500
|
+
assert xml.include?(%(<resident type="symbol">yes</resident>))
|
501
|
+
end
|
502
|
+
|
503
|
+
def test_one_level_with_nils
|
504
|
+
xml = { :name => "David", :street => "Paulina", :age => nil }.to_xml(@xml_options)
|
505
|
+
assert_equal "<person>", xml.first(8)
|
506
|
+
assert xml.include?(%(<street>Paulina</street>))
|
507
|
+
assert xml.include?(%(<name>David</name>))
|
508
|
+
assert xml.include?(%(<age nil="true"></age>))
|
509
|
+
end
|
510
|
+
|
511
|
+
def test_one_level_with_skipping_types
|
512
|
+
xml = { :name => "David", :street => "Paulina", :age => nil }.to_xml(@xml_options.merge(:skip_types => true))
|
513
|
+
assert_equal "<person>", xml.first(8)
|
514
|
+
assert xml.include?(%(<street>Paulina</street>))
|
515
|
+
assert xml.include?(%(<name>David</name>))
|
516
|
+
assert xml.include?(%(<age nil="true"></age>))
|
517
|
+
end
|
518
|
+
|
519
|
+
def test_one_level_with_yielding
|
520
|
+
xml = { :name => "David", :street => "Paulina" }.to_xml(@xml_options) do |x|
|
521
|
+
x.creator("Rails")
|
522
|
+
end
|
523
|
+
|
524
|
+
assert_equal "<person>", xml.first(8)
|
525
|
+
assert xml.include?(%(<street>Paulina</street>))
|
526
|
+
assert xml.include?(%(<name>David</name>))
|
527
|
+
assert xml.include?(%(<creator>Rails</creator>))
|
528
|
+
end
|
529
|
+
|
530
|
+
def test_two_levels
|
531
|
+
xml = { :name => "David", :address => { :street => "Paulina" } }.to_xml(@xml_options)
|
532
|
+
assert_equal "<person>", xml.first(8)
|
533
|
+
assert xml.include?(%(<address><street>Paulina</street></address>))
|
534
|
+
assert xml.include?(%(<name>David</name>))
|
535
|
+
end
|
536
|
+
|
537
|
+
def test_two_levels_with_second_level_overriding_to_xml
|
538
|
+
xml = { :name => "David", :address => { :street => "Paulina" }, :child => IWriteMyOwnXML.new }.to_xml(@xml_options)
|
539
|
+
assert_equal "<person>", xml.first(8)
|
540
|
+
assert xml.include?(%(<address><street>Paulina</street></address>))
|
541
|
+
assert xml.include?(%(<level_one><second_level>content</second_level></level_one>))
|
542
|
+
end
|
543
|
+
|
544
|
+
def test_two_levels_with_array
|
545
|
+
xml = { :name => "David", :addresses => [{ :street => "Paulina" }, { :street => "Evergreen" }] }.to_xml(@xml_options)
|
546
|
+
assert_equal "<person>", xml.first(8)
|
547
|
+
assert xml.include?(%(<addresses type="array"><address>))
|
548
|
+
assert xml.include?(%(<address><street>Paulina</street></address>))
|
549
|
+
assert xml.include?(%(<address><street>Evergreen</street></address>))
|
550
|
+
assert xml.include?(%(<name>David</name>))
|
551
|
+
end
|
552
|
+
|
553
|
+
def test_three_levels_with_array
|
554
|
+
xml = { :name => "David", :addresses => [{ :streets => [ { :name => "Paulina" }, { :name => "Paulina" } ] } ] }.to_xml(@xml_options)
|
555
|
+
assert xml.include?(%(<addresses type="array"><address><streets type="array"><street><name>))
|
556
|
+
end
|
557
|
+
|
558
|
+
def test_timezoned_attributes
|
559
|
+
xml = {
|
560
|
+
:created_at => Time.utc(1999,2,2),
|
561
|
+
:local_created_at => Time.utc(1999,2,2).in_time_zone('Eastern Time (US & Canada)')
|
562
|
+
}.to_xml(@xml_options)
|
563
|
+
assert_match %r{<created-at type=\"datetime\">1999-02-02T00:00:00Z</created-at>}, xml
|
564
|
+
assert_match %r{<local-created-at type=\"datetime\">1999-02-01T19:00:00-05:00</local-created-at>}, xml
|
565
|
+
end
|
566
|
+
|
567
|
+
def test_single_record_from_xml
|
568
|
+
topic_xml = <<-EOT
|
569
|
+
<topic>
|
570
|
+
<title>The First Topic</title>
|
571
|
+
<author-name>David</author-name>
|
572
|
+
<id type="integer">1</id>
|
573
|
+
<approved type="boolean"> true </approved>
|
574
|
+
<replies-count type="integer">0</replies-count>
|
575
|
+
<replies-close-in type="integer">2592000000</replies-close-in>
|
576
|
+
<written-on type="date">2003-07-16</written-on>
|
577
|
+
<viewed-at type="datetime">2003-07-16T09:28:00+0000</viewed-at>
|
578
|
+
<content type="yaml">--- \n1: should be an integer\n:message: Have a nice day\narray: \n- should-have-dashes: true\n should_have_underscores: true\n</content>
|
579
|
+
<author-email-address>david@loudthinking.com</author-email-address>
|
580
|
+
<parent-id></parent-id>
|
581
|
+
<ad-revenue type="decimal">1.5</ad-revenue>
|
582
|
+
<optimum-viewing-angle type="float">135</optimum-viewing-angle>
|
583
|
+
<resident type="symbol">yes</resident>
|
584
|
+
</topic>
|
585
|
+
EOT
|
586
|
+
|
587
|
+
expected_topic_hash = {
|
588
|
+
:title => "The First Topic",
|
589
|
+
:author_name => "David",
|
590
|
+
:id => 1,
|
591
|
+
:approved => true,
|
592
|
+
:replies_count => 0,
|
593
|
+
:replies_close_in => 2592000000,
|
594
|
+
:written_on => Date.new(2003, 7, 16),
|
595
|
+
:viewed_at => Time.utc(2003, 7, 16, 9, 28),
|
596
|
+
:content => { :message => "Have a nice day", 1 => "should be an integer", "array" => [{ "should-have-dashes" => true, "should_have_underscores" => true }] },
|
597
|
+
:author_email_address => "david@loudthinking.com",
|
598
|
+
:parent_id => nil,
|
599
|
+
:ad_revenue => BigDecimal("1.50"),
|
600
|
+
:optimum_viewing_angle => 135.0,
|
601
|
+
:resident => :yes
|
602
|
+
}.stringify_keys
|
603
|
+
|
604
|
+
assert_equal expected_topic_hash, Hash.from_xml(topic_xml)["topic"]
|
605
|
+
end
|
606
|
+
|
607
|
+
def test_single_record_from_xml_with_nil_values
|
608
|
+
topic_xml = <<-EOT
|
609
|
+
<topic>
|
610
|
+
<title></title>
|
611
|
+
<id type="integer"></id>
|
612
|
+
<approved type="boolean"></approved>
|
613
|
+
<written-on type="date"></written-on>
|
614
|
+
<viewed-at type="datetime"></viewed-at>
|
615
|
+
<content type="yaml"></content>
|
616
|
+
<parent-id></parent-id>
|
617
|
+
</topic>
|
618
|
+
EOT
|
619
|
+
|
620
|
+
expected_topic_hash = {
|
621
|
+
:title => nil,
|
622
|
+
:id => nil,
|
623
|
+
:approved => nil,
|
624
|
+
:written_on => nil,
|
625
|
+
:viewed_at => nil,
|
626
|
+
:content => nil,
|
627
|
+
:parent_id => nil
|
628
|
+
}.stringify_keys
|
629
|
+
|
630
|
+
assert_equal expected_topic_hash, Hash.from_xml(topic_xml)["topic"]
|
631
|
+
end
|
632
|
+
|
633
|
+
def test_multiple_records_from_xml
|
634
|
+
topics_xml = <<-EOT
|
635
|
+
<topics type="array">
|
636
|
+
<topic>
|
637
|
+
<title>The First Topic</title>
|
638
|
+
<author-name>David</author-name>
|
639
|
+
<id type="integer">1</id>
|
640
|
+
<approved type="boolean">false</approved>
|
641
|
+
<replies-count type="integer">0</replies-count>
|
642
|
+
<replies-close-in type="integer">2592000000</replies-close-in>
|
643
|
+
<written-on type="date">2003-07-16</written-on>
|
644
|
+
<viewed-at type="datetime">2003-07-16T09:28:00+0000</viewed-at>
|
645
|
+
<content>Have a nice day</content>
|
646
|
+
<author-email-address>david@loudthinking.com</author-email-address>
|
647
|
+
<parent-id nil="true"></parent-id>
|
648
|
+
</topic>
|
649
|
+
<topic>
|
650
|
+
<title>The Second Topic</title>
|
651
|
+
<author-name>Jason</author-name>
|
652
|
+
<id type="integer">1</id>
|
653
|
+
<approved type="boolean">false</approved>
|
654
|
+
<replies-count type="integer">0</replies-count>
|
655
|
+
<replies-close-in type="integer">2592000000</replies-close-in>
|
656
|
+
<written-on type="date">2003-07-16</written-on>
|
657
|
+
<viewed-at type="datetime">2003-07-16T09:28:00+0000</viewed-at>
|
658
|
+
<content>Have a nice day</content>
|
659
|
+
<author-email-address>david@loudthinking.com</author-email-address>
|
660
|
+
<parent-id></parent-id>
|
661
|
+
</topic>
|
662
|
+
</topics>
|
663
|
+
EOT
|
664
|
+
|
665
|
+
expected_topic_hash = {
|
666
|
+
:title => "The First Topic",
|
667
|
+
:author_name => "David",
|
668
|
+
:id => 1,
|
669
|
+
:approved => false,
|
670
|
+
:replies_count => 0,
|
671
|
+
:replies_close_in => 2592000000,
|
672
|
+
:written_on => Date.new(2003, 7, 16),
|
673
|
+
:viewed_at => Time.utc(2003, 7, 16, 9, 28),
|
674
|
+
:content => "Have a nice day",
|
675
|
+
:author_email_address => "david@loudthinking.com",
|
676
|
+
:parent_id => nil
|
677
|
+
}.stringify_keys
|
678
|
+
|
679
|
+
assert_equal expected_topic_hash, Hash.from_xml(topics_xml)["topics"].first
|
680
|
+
end
|
681
|
+
|
682
|
+
def test_single_record_from_xml_with_attributes_other_than_type
|
683
|
+
topic_xml = <<-EOT
|
684
|
+
<rsp stat="ok">
|
685
|
+
<photos page="1" pages="1" perpage="100" total="16">
|
686
|
+
<photo id="175756086" owner="55569174@N00" secret="0279bf37a1" server="76" title="Colored Pencil PhotoBooth Fun" ispublic="1" isfriend="0" isfamily="0"/>
|
687
|
+
</photos>
|
688
|
+
</rsp>
|
689
|
+
EOT
|
690
|
+
|
691
|
+
expected_topic_hash = {
|
692
|
+
:id => "175756086",
|
693
|
+
:owner => "55569174@N00",
|
694
|
+
:secret => "0279bf37a1",
|
695
|
+
:server => "76",
|
696
|
+
:title => "Colored Pencil PhotoBooth Fun",
|
697
|
+
:ispublic => "1",
|
698
|
+
:isfriend => "0",
|
699
|
+
:isfamily => "0",
|
700
|
+
}.stringify_keys
|
701
|
+
|
702
|
+
assert_equal expected_topic_hash, Hash.from_xml(topic_xml)["rsp"]["photos"]["photo"]
|
703
|
+
end
|
704
|
+
|
705
|
+
def test_empty_array_from_xml
|
706
|
+
blog_xml = <<-XML
|
707
|
+
<blog>
|
708
|
+
<posts type="array"></posts>
|
709
|
+
</blog>
|
710
|
+
XML
|
711
|
+
expected_blog_hash = {"blog" => {"posts" => []}}
|
712
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
713
|
+
end
|
714
|
+
|
715
|
+
def test_all_caps_key_from_xml
|
716
|
+
test_xml = <<-EOT
|
717
|
+
<ABC3XYZ>
|
718
|
+
<TEST>Lorem Ipsum</TEST>
|
719
|
+
</ABC3XYZ>
|
720
|
+
EOT
|
721
|
+
|
722
|
+
expected_hash = {
|
723
|
+
"ABC3XYZ" => {
|
724
|
+
"TEST" => "Lorem Ipsum"
|
725
|
+
}
|
726
|
+
}
|
727
|
+
|
728
|
+
assert_equal expected_hash, Hash.from_xml(test_xml)
|
729
|
+
end
|
730
|
+
|
731
|
+
def test_empty_array_with_whitespace_from_xml
|
732
|
+
blog_xml = <<-XML
|
733
|
+
<blog>
|
734
|
+
<posts type="array">
|
735
|
+
</posts>
|
736
|
+
</blog>
|
737
|
+
XML
|
738
|
+
expected_blog_hash = {"blog" => {"posts" => []}}
|
739
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
740
|
+
end
|
741
|
+
|
742
|
+
def test_array_with_one_entry_from_xml
|
743
|
+
blog_xml = <<-XML
|
744
|
+
<blog>
|
745
|
+
<posts type="array">
|
746
|
+
<post>a post</post>
|
747
|
+
</posts>
|
748
|
+
</blog>
|
749
|
+
XML
|
750
|
+
expected_blog_hash = {"blog" => {"posts" => ["a post"]}}
|
751
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
752
|
+
end
|
753
|
+
|
754
|
+
def test_array_with_multiple_entries_from_xml
|
755
|
+
blog_xml = <<-XML
|
756
|
+
<blog>
|
757
|
+
<posts type="array">
|
758
|
+
<post>a post</post>
|
759
|
+
<post>another post</post>
|
760
|
+
</posts>
|
761
|
+
</blog>
|
762
|
+
XML
|
763
|
+
expected_blog_hash = {"blog" => {"posts" => ["a post", "another post"]}}
|
764
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
765
|
+
end
|
766
|
+
|
767
|
+
def test_file_from_xml
|
768
|
+
blog_xml = <<-XML
|
769
|
+
<blog>
|
770
|
+
<logo type="file" name="logo.png" content_type="image/png">
|
771
|
+
</logo>
|
772
|
+
</blog>
|
773
|
+
XML
|
774
|
+
hash = Hash.from_xml(blog_xml)
|
775
|
+
assert hash.has_key?('blog')
|
776
|
+
assert hash['blog'].has_key?('logo')
|
777
|
+
|
778
|
+
file = hash['blog']['logo']
|
779
|
+
assert_equal 'logo.png', file.original_filename
|
780
|
+
assert_equal 'image/png', file.content_type
|
781
|
+
end
|
782
|
+
|
783
|
+
def test_file_from_xml_with_defaults
|
784
|
+
blog_xml = <<-XML
|
785
|
+
<blog>
|
786
|
+
<logo type="file">
|
787
|
+
</logo>
|
788
|
+
</blog>
|
789
|
+
XML
|
790
|
+
file = Hash.from_xml(blog_xml)['blog']['logo']
|
791
|
+
assert_equal 'untitled', file.original_filename
|
792
|
+
assert_equal 'application/octet-stream', file.content_type
|
793
|
+
end
|
794
|
+
|
795
|
+
def test_xsd_like_types_from_xml
|
796
|
+
bacon_xml = <<-EOT
|
797
|
+
<bacon>
|
798
|
+
<weight type="double">0.5</weight>
|
799
|
+
<price type="decimal">12.50</price>
|
800
|
+
<chunky type="boolean"> 1 </chunky>
|
801
|
+
<expires-at type="dateTime">2007-12-25T12:34:56+0000</expires-at>
|
802
|
+
<notes type="string"></notes>
|
803
|
+
<illustration type="base64Binary">YmFiZS5wbmc=</illustration>
|
804
|
+
</bacon>
|
805
|
+
EOT
|
806
|
+
|
807
|
+
expected_bacon_hash = {
|
808
|
+
:weight => 0.5,
|
809
|
+
:chunky => true,
|
810
|
+
:price => BigDecimal("12.50"),
|
811
|
+
:expires_at => Time.utc(2007,12,25,12,34,56),
|
812
|
+
:notes => "",
|
813
|
+
:illustration => "babe.png"
|
814
|
+
}.stringify_keys
|
815
|
+
|
816
|
+
assert_equal expected_bacon_hash, Hash.from_xml(bacon_xml)["bacon"]
|
817
|
+
end
|
818
|
+
|
819
|
+
def test_type_trickles_through_when_unknown
|
820
|
+
product_xml = <<-EOT
|
821
|
+
<product>
|
822
|
+
<weight type="double">0.5</weight>
|
823
|
+
<image type="ProductImage"><filename>image.gif</filename></image>
|
824
|
+
|
825
|
+
</product>
|
826
|
+
EOT
|
827
|
+
|
828
|
+
expected_product_hash = {
|
829
|
+
:weight => 0.5,
|
830
|
+
:image => {'type' => 'ProductImage', 'filename' => 'image.gif' },
|
831
|
+
}.stringify_keys
|
832
|
+
|
833
|
+
assert_equal expected_product_hash, Hash.from_xml(product_xml)["product"]
|
834
|
+
end
|
835
|
+
|
836
|
+
def test_should_use_default_value_for_unknown_key
|
837
|
+
hash_wia = HashWithIndifferentAccess.new(3)
|
838
|
+
assert_equal 3, hash_wia[:new_key]
|
839
|
+
end
|
840
|
+
|
841
|
+
def test_should_use_default_value_if_no_key_is_supplied
|
842
|
+
hash_wia = HashWithIndifferentAccess.new(3)
|
843
|
+
assert_equal 3, hash_wia.default
|
844
|
+
end
|
845
|
+
|
846
|
+
def test_should_nil_if_no_default_value_is_supplied
|
847
|
+
hash_wia = HashWithIndifferentAccess.new
|
848
|
+
assert_nil hash_wia.default
|
849
|
+
end
|
850
|
+
|
851
|
+
def test_should_copy_the_default_value_when_converting_to_hash_with_indifferent_access
|
852
|
+
hash = Hash.new(3)
|
853
|
+
hash_wia = hash.with_indifferent_access
|
854
|
+
assert_equal 3, hash_wia.default
|
855
|
+
end
|
856
|
+
|
857
|
+
# The XML builder seems to fail miserably when trying to tag something
|
858
|
+
# with the same name as a Kernel method (throw, test, loop, select ...)
|
859
|
+
def test_kernel_method_names_to_xml
|
860
|
+
hash = { :throw => { :ball => 'red' } }
|
861
|
+
expected = '<person><throw><ball>red</ball></throw></person>'
|
862
|
+
|
863
|
+
assert_nothing_raised do
|
864
|
+
assert_equal expected, hash.to_xml(@xml_options)
|
865
|
+
end
|
866
|
+
end
|
867
|
+
|
868
|
+
def test_empty_string_works_for_typecast_xml_value
|
869
|
+
assert_nothing_raised do
|
870
|
+
Hash.__send__(:typecast_xml_value, "")
|
871
|
+
end
|
872
|
+
end
|
873
|
+
|
874
|
+
def test_escaping_to_xml
|
875
|
+
hash = {
|
876
|
+
:bare_string => 'First & Last Name',
|
877
|
+
:pre_escaped_string => 'First & Last Name'
|
878
|
+
}.stringify_keys
|
879
|
+
|
880
|
+
expected_xml = '<person><bare-string>First & Last Name</bare-string><pre-escaped-string>First &amp; Last Name</pre-escaped-string></person>'
|
881
|
+
assert_equal expected_xml, hash.to_xml(@xml_options)
|
882
|
+
end
|
883
|
+
|
884
|
+
def test_unescaping_from_xml
|
885
|
+
xml_string = '<person><bare-string>First & Last Name</bare-string><pre-escaped-string>First &amp; Last Name</pre-escaped-string></person>'
|
886
|
+
expected_hash = {
|
887
|
+
:bare_string => 'First & Last Name',
|
888
|
+
:pre_escaped_string => 'First & Last Name'
|
889
|
+
}.stringify_keys
|
890
|
+
assert_equal expected_hash, Hash.from_xml(xml_string)['person']
|
891
|
+
end
|
892
|
+
|
893
|
+
def test_roundtrip_to_xml_from_xml
|
894
|
+
hash = {
|
895
|
+
:bare_string => 'First & Last Name',
|
896
|
+
:pre_escaped_string => 'First & Last Name'
|
897
|
+
}.stringify_keys
|
898
|
+
|
899
|
+
assert_equal hash, Hash.from_xml(hash.to_xml(@xml_options))['person']
|
900
|
+
end
|
901
|
+
|
902
|
+
def test_to_xml_dups_options
|
903
|
+
options = {:skip_instruct => true}
|
904
|
+
{}.to_xml(options)
|
905
|
+
# :builder, etc, shouldn't be added to options
|
906
|
+
assert_equal({:skip_instruct => true}, options)
|
907
|
+
end
|
908
|
+
|
909
|
+
def test_datetime_xml_type_with_utc_time
|
910
|
+
alert_xml = <<-XML
|
911
|
+
<alert>
|
912
|
+
<alert_at type="datetime">2008-02-10T15:30:45Z</alert_at>
|
913
|
+
</alert>
|
914
|
+
XML
|
915
|
+
alert_at = Hash.from_xml(alert_xml)['alert']['alert_at']
|
916
|
+
assert alert_at.utc?
|
917
|
+
assert_equal Time.utc(2008, 2, 10, 15, 30, 45), alert_at
|
918
|
+
end
|
919
|
+
|
920
|
+
def test_datetime_xml_type_with_non_utc_time
|
921
|
+
alert_xml = <<-XML
|
922
|
+
<alert>
|
923
|
+
<alert_at type="datetime">2008-02-10T10:30:45-05:00</alert_at>
|
924
|
+
</alert>
|
925
|
+
XML
|
926
|
+
alert_at = Hash.from_xml(alert_xml)['alert']['alert_at']
|
927
|
+
assert alert_at.utc?
|
928
|
+
assert_equal Time.utc(2008, 2, 10, 15, 30, 45), alert_at
|
929
|
+
end
|
930
|
+
|
931
|
+
def test_datetime_xml_type_with_far_future_date
|
932
|
+
alert_xml = <<-XML
|
933
|
+
<alert>
|
934
|
+
<alert_at type="datetime">2050-02-10T15:30:45Z</alert_at>
|
935
|
+
</alert>
|
936
|
+
XML
|
937
|
+
alert_at = Hash.from_xml(alert_xml)['alert']['alert_at']
|
938
|
+
assert alert_at.utc?
|
939
|
+
assert_equal 2050, alert_at.year
|
940
|
+
assert_equal 2, alert_at.month
|
941
|
+
assert_equal 10, alert_at.day
|
942
|
+
assert_equal 15, alert_at.hour
|
943
|
+
assert_equal 30, alert_at.min
|
944
|
+
assert_equal 45, alert_at.sec
|
945
|
+
end
|
946
|
+
end
|
947
|
+
|
948
|
+
class QueryTest < Test::Unit::TestCase
|
949
|
+
def test_simple_conversion
|
950
|
+
assert_query_equal 'a=10', :a => 10
|
951
|
+
end
|
952
|
+
|
953
|
+
def test_cgi_escaping
|
954
|
+
assert_query_equal 'a%3Ab=c+d', 'a:b' => 'c d'
|
955
|
+
end
|
956
|
+
|
957
|
+
def test_nil_parameter_value
|
958
|
+
empty = Object.new
|
959
|
+
def empty.to_param; nil end
|
960
|
+
assert_query_equal 'a=', 'a' => empty
|
961
|
+
end
|
962
|
+
|
963
|
+
def test_nested_conversion
|
964
|
+
assert_query_equal 'person%5Blogin%5D=seckar&person%5Bname%5D=Nicholas',
|
965
|
+
:person => {:name => 'Nicholas', :login => 'seckar'}
|
966
|
+
end
|
967
|
+
|
968
|
+
def test_multiple_nested
|
969
|
+
assert_query_equal 'account%5Bperson%5D%5Bid%5D=20&person%5Bid%5D=10',
|
970
|
+
:person => {:id => 10}, :account => {:person => {:id => 20}}
|
971
|
+
end
|
972
|
+
|
973
|
+
def test_array_values
|
974
|
+
assert_query_equal 'person%5Bid%5D%5B%5D=10&person%5Bid%5D%5B%5D=20',
|
975
|
+
:person => {:id => [10, 20]}
|
976
|
+
end
|
977
|
+
|
978
|
+
def test_array_values_are_not_sorted
|
979
|
+
assert_query_equal 'person%5Bid%5D%5B%5D=20&person%5Bid%5D%5B%5D=10',
|
980
|
+
:person => {:id => [20, 10]}
|
981
|
+
end
|
982
|
+
|
983
|
+
def test_expansion_count_is_limited
|
984
|
+
expected = {
|
985
|
+
'ActiveSupport::XmlMini_REXML' => 'RuntimeError',
|
986
|
+
'ActiveSupport::XmlMini_Nokogiri' => 'Nokogiri::XML::SyntaxError',
|
987
|
+
'ActiveSupport::XmlMini_LibXML' => 'LibXML::XML::Error',
|
988
|
+
}[ActiveSupport::XmlMini.backend.name].constantize
|
989
|
+
|
990
|
+
assert_raise expected do
|
991
|
+
attack_xml = <<-EOT
|
992
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
993
|
+
<!DOCTYPE member [
|
994
|
+
<!ENTITY a "&b;&b;&b;&b;&b;&b;&b;&b;&b;&b;">
|
995
|
+
<!ENTITY b "&c;&c;&c;&c;&c;&c;&c;&c;&c;&c;">
|
996
|
+
<!ENTITY c "&d;&d;&d;&d;&d;&d;&d;&d;&d;&d;">
|
997
|
+
<!ENTITY d "&e;&e;&e;&e;&e;&e;&e;&e;&e;&e;">
|
998
|
+
<!ENTITY e "&f;&f;&f;&f;&f;&f;&f;&f;&f;&f;">
|
999
|
+
<!ENTITY f "&g;&g;&g;&g;&g;&g;&g;&g;&g;&g;">
|
1000
|
+
<!ENTITY g "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx">
|
1001
|
+
]>
|
1002
|
+
<member>
|
1003
|
+
&a;
|
1004
|
+
</member>
|
1005
|
+
EOT
|
1006
|
+
Hash.from_xml(attack_xml)
|
1007
|
+
end
|
1008
|
+
end
|
1009
|
+
|
1010
|
+
private
|
1011
|
+
def assert_query_equal(expected, actual, message = nil)
|
1012
|
+
assert_equal expected.split('&'), actual.to_query.split('&')
|
1013
|
+
end
|
1014
|
+
end
|