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,845 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class TimeWithZoneTest < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def setup
|
6
|
+
@utc = Time.utc(2000, 1, 1, 0)
|
7
|
+
@time_zone = ActiveSupport::TimeZone['Eastern Time (US & Canada)']
|
8
|
+
@twz = ActiveSupport::TimeWithZone.new(@utc, @time_zone)
|
9
|
+
end
|
10
|
+
|
11
|
+
def test_utc
|
12
|
+
assert_equal @utc, @twz.utc
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_time
|
16
|
+
assert_equal Time.utc(1999, 12, 31, 19), @twz.time
|
17
|
+
end
|
18
|
+
|
19
|
+
def test_time_zone
|
20
|
+
assert_equal @time_zone, @twz.time_zone
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_in_time_zone
|
24
|
+
Time.use_zone 'Alaska' do
|
25
|
+
assert_equal ActiveSupport::TimeWithZone.new(@utc, ActiveSupport::TimeZone['Alaska']), @twz.in_time_zone
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def test_in_time_zone_with_argument
|
30
|
+
assert_equal ActiveSupport::TimeWithZone.new(@utc, ActiveSupport::TimeZone['Alaska']), @twz.in_time_zone('Alaska')
|
31
|
+
end
|
32
|
+
|
33
|
+
def test_in_time_zone_with_new_zone_equal_to_old_zone_does_not_create_new_object
|
34
|
+
assert_equal @twz.object_id, @twz.in_time_zone(ActiveSupport::TimeZone['Eastern Time (US & Canada)']).object_id
|
35
|
+
end
|
36
|
+
|
37
|
+
def test_utc?
|
38
|
+
assert_equal false, @twz.utc?
|
39
|
+
assert_equal true, ActiveSupport::TimeWithZone.new(Time.utc(2000), ActiveSupport::TimeZone['UTC']).utc?
|
40
|
+
end
|
41
|
+
|
42
|
+
def test_formatted_offset
|
43
|
+
assert_equal '-05:00', @twz.formatted_offset
|
44
|
+
assert_equal '-04:00', ActiveSupport::TimeWithZone.new(Time.utc(2000, 6), @time_zone).formatted_offset #dst
|
45
|
+
end
|
46
|
+
|
47
|
+
def test_dst?
|
48
|
+
assert_equal false, @twz.dst?
|
49
|
+
assert_equal true, ActiveSupport::TimeWithZone.new(Time.utc(2000, 6), @time_zone).dst?
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_zone
|
53
|
+
assert_equal 'EST', @twz.zone
|
54
|
+
assert_equal 'EDT', ActiveSupport::TimeWithZone.new(Time.utc(2000, 6), @time_zone).zone #dst
|
55
|
+
end
|
56
|
+
|
57
|
+
def test_to_json
|
58
|
+
assert_equal "\"1999/12/31 19:00:00 -0500\"", ActiveSupport::JSON.encode(@twz)
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_to_json_with_use_standard_json_time_format_config_set_to_true
|
62
|
+
old, ActiveSupport.use_standard_json_time_format = ActiveSupport.use_standard_json_time_format, true
|
63
|
+
assert_equal "\"1999-12-31T19:00:00-05:00\"", ActiveSupport::JSON.encode(@twz)
|
64
|
+
ensure
|
65
|
+
ActiveSupport.use_standard_json_time_format = old
|
66
|
+
end
|
67
|
+
|
68
|
+
def test_strftime
|
69
|
+
assert_equal '1999-12-31 19:00:00 EST -0500', @twz.strftime('%Y-%m-%d %H:%M:%S %Z %z')
|
70
|
+
end
|
71
|
+
|
72
|
+
def test_inspect
|
73
|
+
assert_equal 'Fri, 31 Dec 1999 19:00:00 EST -05:00', @twz.inspect
|
74
|
+
end
|
75
|
+
|
76
|
+
def test_to_s
|
77
|
+
assert_equal '1999-12-31 19:00:00 -0500', @twz.to_s
|
78
|
+
end
|
79
|
+
|
80
|
+
def test_to_formatted_s
|
81
|
+
assert_equal '1999-12-31 19:00:00 -0500', @twz.to_formatted_s
|
82
|
+
end
|
83
|
+
|
84
|
+
def test_to_s_db
|
85
|
+
assert_equal '2000-01-01 00:00:00', @twz.to_s(:db)
|
86
|
+
end
|
87
|
+
|
88
|
+
def test_xmlschema
|
89
|
+
assert_equal "1999-12-31T19:00:00-05:00", @twz.xmlschema
|
90
|
+
end
|
91
|
+
|
92
|
+
def test_xmlschema_with_fractional_seconds
|
93
|
+
@twz += 0.1234560001 # advance the time by a fraction of a second
|
94
|
+
assert_equal "1999-12-31T19:00:00.123-05:00", @twz.xmlschema(3)
|
95
|
+
assert_equal "1999-12-31T19:00:00.123456-05:00", @twz.xmlschema(6)
|
96
|
+
assert_equal "1999-12-31T19:00:00.123456-05:00", @twz.xmlschema(12)
|
97
|
+
end
|
98
|
+
|
99
|
+
def test_to_yaml
|
100
|
+
assert_equal "--- 1999-12-31 19:00:00 -05:00\n", @twz.to_yaml
|
101
|
+
end
|
102
|
+
|
103
|
+
def test_ruby_to_yaml
|
104
|
+
assert_equal "--- \n:twz: 2000-01-01 00:00:00 Z\n", {:twz => @twz}.to_yaml
|
105
|
+
end
|
106
|
+
|
107
|
+
def test_httpdate
|
108
|
+
assert_equal 'Sat, 01 Jan 2000 00:00:00 GMT', @twz.httpdate
|
109
|
+
end
|
110
|
+
|
111
|
+
def test_rfc2822
|
112
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 -0500", @twz.rfc2822
|
113
|
+
end
|
114
|
+
|
115
|
+
def test_compare_with_time
|
116
|
+
assert_equal 1, @twz <=> Time.utc(1999, 12, 31, 23, 59, 59)
|
117
|
+
assert_equal 0, @twz <=> Time.utc(2000, 1, 1, 0, 0, 0)
|
118
|
+
assert_equal(-1, @twz <=> Time.utc(2000, 1, 1, 0, 0, 1))
|
119
|
+
end
|
120
|
+
|
121
|
+
def test_compare_with_datetime
|
122
|
+
assert_equal 1, @twz <=> DateTime.civil(1999, 12, 31, 23, 59, 59)
|
123
|
+
assert_equal 0, @twz <=> DateTime.civil(2000, 1, 1, 0, 0, 0)
|
124
|
+
assert_equal(-1, @twz <=> DateTime.civil(2000, 1, 1, 0, 0, 1))
|
125
|
+
end
|
126
|
+
|
127
|
+
def test_compare_with_time_with_zone
|
128
|
+
assert_equal 1, @twz <=> ActiveSupport::TimeWithZone.new( Time.utc(1999, 12, 31, 23, 59, 59), ActiveSupport::TimeZone['UTC'] )
|
129
|
+
assert_equal 0, @twz <=> ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1, 0, 0, 0), ActiveSupport::TimeZone['UTC'] )
|
130
|
+
assert_equal(-1, @twz <=> ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1, 0, 0, 1), ActiveSupport::TimeZone['UTC'] ))
|
131
|
+
end
|
132
|
+
|
133
|
+
def test_between?
|
134
|
+
assert @twz.between?(Time.utc(1999,12,31,23,59,59), Time.utc(2000,1,1,0,0,1))
|
135
|
+
assert_equal false, @twz.between?(Time.utc(2000,1,1,0,0,1), Time.utc(2000,1,1,0,0,2))
|
136
|
+
end
|
137
|
+
|
138
|
+
def test_today
|
139
|
+
Date.stubs(:current).returns(Date.new(2000, 1, 1))
|
140
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.utc(1999,12,31,23,59,59) ).today?
|
141
|
+
assert_equal true, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.utc(2000,1,1,0) ).today?
|
142
|
+
assert_equal true, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.utc(2000,1,1,23,59,59) ).today?
|
143
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.utc(2000,1,2,0) ).today?
|
144
|
+
end
|
145
|
+
|
146
|
+
def test_past_with_time_current_as_time_local
|
147
|
+
with_env_tz 'US/Eastern' do
|
148
|
+
Time.stubs(:current).returns(Time.local(2005,2,10,15,30,45))
|
149
|
+
assert_equal true, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,44)).past?
|
150
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,45)).past?
|
151
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,46)).past?
|
152
|
+
end
|
153
|
+
end
|
154
|
+
|
155
|
+
def test_past_with_time_current_as_time_with_zone
|
156
|
+
twz = ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,45) )
|
157
|
+
Time.stubs(:current).returns(twz)
|
158
|
+
assert_equal true, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,44)).past?
|
159
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,45)).past?
|
160
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,46)).past?
|
161
|
+
end
|
162
|
+
|
163
|
+
def test_future_with_time_current_as_time_local
|
164
|
+
with_env_tz 'US/Eastern' do
|
165
|
+
Time.stubs(:current).returns(Time.local(2005,2,10,15,30,45))
|
166
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,44)).future?
|
167
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,45)).future?
|
168
|
+
assert_equal true, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,46)).future?
|
169
|
+
end
|
170
|
+
end
|
171
|
+
|
172
|
+
def future_with_time_current_as_time_with_zone
|
173
|
+
twz = ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,45) )
|
174
|
+
Time.stubs(:current).returns(twz)
|
175
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,44)).future?
|
176
|
+
assert_equal false, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,45)).future?
|
177
|
+
assert_equal true, ActiveSupport::TimeWithZone.new( nil, @time_zone, Time.local(2005,2,10,15,30,46)).future?
|
178
|
+
end
|
179
|
+
|
180
|
+
def test_eql?
|
181
|
+
assert @twz.eql?(Time.utc(2000))
|
182
|
+
assert @twz.eql?( ActiveSupport::TimeWithZone.new(Time.utc(2000), ActiveSupport::TimeZone["Hawaii"]) )
|
183
|
+
end
|
184
|
+
|
185
|
+
def test_plus_with_integer
|
186
|
+
assert_equal Time.utc(1999, 12, 31, 19, 0 ,5), (@twz + 5).time
|
187
|
+
end
|
188
|
+
|
189
|
+
def test_plus_with_integer_when_self_wraps_datetime
|
190
|
+
datetime = DateTime.civil(2000, 1, 1, 0)
|
191
|
+
twz = ActiveSupport::TimeWithZone.new(datetime, @time_zone)
|
192
|
+
assert_equal DateTime.civil(1999, 12, 31, 19, 0 ,5), (twz + 5).time
|
193
|
+
end
|
194
|
+
|
195
|
+
def test_plus_when_crossing_time_class_limit
|
196
|
+
twz = ActiveSupport::TimeWithZone.new(Time.utc(2038, 1, 19), @time_zone)
|
197
|
+
assert_equal [0, 0, 19, 19, 1, 2038], (twz + 86_400).to_a[0,6]
|
198
|
+
end
|
199
|
+
|
200
|
+
def test_plus_with_duration
|
201
|
+
assert_equal Time.utc(2000, 1, 5, 19, 0 ,0), (@twz + 5.days).time
|
202
|
+
end
|
203
|
+
|
204
|
+
def test_minus_with_integer
|
205
|
+
assert_equal Time.utc(1999, 12, 31, 18, 59 ,55), (@twz - 5).time
|
206
|
+
end
|
207
|
+
|
208
|
+
def test_minus_with_integer_when_self_wraps_datetime
|
209
|
+
datetime = DateTime.civil(2000, 1, 1, 0)
|
210
|
+
twz = ActiveSupport::TimeWithZone.new(datetime, @time_zone)
|
211
|
+
assert_equal DateTime.civil(1999, 12, 31, 18, 59 ,55), (twz - 5).time
|
212
|
+
end
|
213
|
+
|
214
|
+
def test_minus_with_duration
|
215
|
+
assert_equal Time.utc(1999, 12, 26, 19, 0 ,0), (@twz - 5.days).time
|
216
|
+
end
|
217
|
+
|
218
|
+
def test_minus_with_time
|
219
|
+
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), ActiveSupport::TimeZone['UTC'] ) - Time.utc(2000, 1, 1)
|
220
|
+
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), ActiveSupport::TimeZone['Hawaii'] ) - Time.utc(2000, 1, 1)
|
221
|
+
end
|
222
|
+
|
223
|
+
def test_minus_with_time_with_zone
|
224
|
+
twz1 = ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1), ActiveSupport::TimeZone['UTC'] )
|
225
|
+
twz2 = ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), ActiveSupport::TimeZone['UTC'] )
|
226
|
+
assert_equal 86_400.0, twz2 - twz1
|
227
|
+
end
|
228
|
+
|
229
|
+
def test_minus_with_datetime
|
230
|
+
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), ActiveSupport::TimeZone['UTC'] ) - DateTime.civil(2000, 1, 1)
|
231
|
+
end
|
232
|
+
|
233
|
+
def test_minus_with_wrapped_datetime
|
234
|
+
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( DateTime.civil(2000, 1, 2), ActiveSupport::TimeZone['UTC'] ) - Time.utc(2000, 1, 1)
|
235
|
+
assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( DateTime.civil(2000, 1, 2), ActiveSupport::TimeZone['UTC'] ) - DateTime.civil(2000, 1, 1)
|
236
|
+
end
|
237
|
+
|
238
|
+
def test_plus_and_minus_enforce_spring_dst_rules
|
239
|
+
utc = Time.utc(2006,4,2,6,59,59) # == Apr 2 2006 01:59:59 EST; i.e., 1 second before daylight savings start
|
240
|
+
twz = ActiveSupport::TimeWithZone.new(utc, @time_zone)
|
241
|
+
assert_equal Time.utc(2006,4,2,1,59,59), twz.time
|
242
|
+
assert_equal false, twz.dst?
|
243
|
+
assert_equal 'EST', twz.zone
|
244
|
+
twz = twz + 1
|
245
|
+
assert_equal Time.utc(2006,4,2,3), twz.time # adding 1 sec springs forward to 3:00AM EDT
|
246
|
+
assert_equal true, twz.dst?
|
247
|
+
assert_equal 'EDT', twz.zone
|
248
|
+
twz = twz - 1 # subtracting 1 second takes goes back to 1:59:59AM EST
|
249
|
+
assert_equal Time.utc(2006,4,2,1,59,59), twz.time
|
250
|
+
assert_equal false, twz.dst?
|
251
|
+
assert_equal 'EST', twz.zone
|
252
|
+
end
|
253
|
+
|
254
|
+
def test_plus_and_minus_enforce_fall_dst_rules
|
255
|
+
utc = Time.utc(2006,10,29,5,59,59) # == Oct 29 2006 01:59:59 EST; i.e., 1 second before daylight savings end
|
256
|
+
twz = ActiveSupport::TimeWithZone.new(utc, @time_zone)
|
257
|
+
assert_equal Time.utc(2006,10,29,1,59,59), twz.time
|
258
|
+
assert_equal true, twz.dst?
|
259
|
+
assert_equal 'EDT', twz.zone
|
260
|
+
twz = twz + 1
|
261
|
+
assert_equal Time.utc(2006,10,29,1), twz.time # adding 1 sec falls back from 1:59:59 EDT to 1:00AM EST
|
262
|
+
assert_equal false, twz.dst?
|
263
|
+
assert_equal 'EST', twz.zone
|
264
|
+
twz = twz - 1
|
265
|
+
assert_equal Time.utc(2006,10,29,1,59,59), twz.time # subtracting 1 sec goes back to 1:59:59AM EDT
|
266
|
+
assert_equal true, twz.dst?
|
267
|
+
assert_equal 'EDT', twz.zone
|
268
|
+
end
|
269
|
+
|
270
|
+
def test_to_a
|
271
|
+
assert_equal [45, 30, 5, 1, 2, 2000, 2, 32, false, "HST"], ActiveSupport::TimeWithZone.new( Time.utc(2000, 2, 1, 15, 30, 45), ActiveSupport::TimeZone['Hawaii'] ).to_a
|
272
|
+
end
|
273
|
+
|
274
|
+
def test_to_f
|
275
|
+
result = ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1), ActiveSupport::TimeZone['Hawaii'] ).to_f
|
276
|
+
assert_equal 946684800.0, result
|
277
|
+
assert result.is_a?(Float)
|
278
|
+
end
|
279
|
+
|
280
|
+
def test_to_i
|
281
|
+
result = ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1), ActiveSupport::TimeZone['Hawaii'] ).to_i
|
282
|
+
assert_equal 946684800, result
|
283
|
+
assert result.is_a?(Integer)
|
284
|
+
end
|
285
|
+
|
286
|
+
def test_to_time
|
287
|
+
assert_equal @twz, @twz.to_time
|
288
|
+
end
|
289
|
+
|
290
|
+
def test_to_date
|
291
|
+
# 1 sec before midnight Jan 1 EST
|
292
|
+
assert_equal Date.new(1999, 12, 31), ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1, 4, 59, 59), ActiveSupport::TimeZone['Eastern Time (US & Canada)'] ).to_date
|
293
|
+
# midnight Jan 1 EST
|
294
|
+
assert_equal Date.new(2000, 1, 1), ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 1, 5, 0, 0), ActiveSupport::TimeZone['Eastern Time (US & Canada)'] ).to_date
|
295
|
+
# 1 sec before midnight Jan 2 EST
|
296
|
+
assert_equal Date.new(2000, 1, 1), ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2, 4, 59, 59), ActiveSupport::TimeZone['Eastern Time (US & Canada)'] ).to_date
|
297
|
+
# midnight Jan 2 EST
|
298
|
+
assert_equal Date.new(2000, 1, 2), ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2, 5, 0, 0), ActiveSupport::TimeZone['Eastern Time (US & Canada)'] ).to_date
|
299
|
+
end
|
300
|
+
|
301
|
+
def test_to_datetime
|
302
|
+
assert_equal DateTime.civil(1999, 12, 31, 19, 0, 0, Rational(-18_000, 86_400)), @twz.to_datetime
|
303
|
+
end
|
304
|
+
|
305
|
+
def test_acts_like_time
|
306
|
+
assert @twz.acts_like?(:time)
|
307
|
+
assert ActiveSupport::TimeWithZone.new(DateTime.civil(2000), @time_zone).acts_like?(:time)
|
308
|
+
end
|
309
|
+
|
310
|
+
def test_acts_like_date
|
311
|
+
assert_equal false, @twz.acts_like?(:date)
|
312
|
+
assert_equal false, ActiveSupport::TimeWithZone.new(DateTime.civil(2000), @time_zone).acts_like?(:date)
|
313
|
+
end
|
314
|
+
|
315
|
+
def test_is_a
|
316
|
+
assert @twz.is_a?(Time)
|
317
|
+
assert @twz.kind_of?(Time)
|
318
|
+
assert @twz.is_a?(ActiveSupport::TimeWithZone)
|
319
|
+
end
|
320
|
+
|
321
|
+
def test_method_missing_with_time_return_value
|
322
|
+
assert_instance_of ActiveSupport::TimeWithZone, @twz.months_since(1)
|
323
|
+
assert_equal Time.utc(2000, 1, 31, 19, 0 ,0), @twz.months_since(1).time
|
324
|
+
end
|
325
|
+
|
326
|
+
def test_marshal_dump_and_load
|
327
|
+
marshal_str = Marshal.dump(@twz)
|
328
|
+
mtime = Marshal.load(marshal_str)
|
329
|
+
assert_equal Time.utc(2000, 1, 1, 0), mtime.utc
|
330
|
+
assert mtime.utc.utc?
|
331
|
+
assert_equal ActiveSupport::TimeZone['Eastern Time (US & Canada)'], mtime.time_zone
|
332
|
+
assert_equal Time.utc(1999, 12, 31, 19), mtime.time
|
333
|
+
assert mtime.time.utc?
|
334
|
+
assert_equal @twz.inspect, mtime.inspect
|
335
|
+
end
|
336
|
+
|
337
|
+
def test_marshal_dump_and_load_with_tzinfo_identifier
|
338
|
+
twz = ActiveSupport::TimeWithZone.new(@utc, TZInfo::Timezone.get('America/New_York'))
|
339
|
+
marshal_str = Marshal.dump(twz)
|
340
|
+
mtime = Marshal.load(marshal_str)
|
341
|
+
assert_equal Time.utc(2000, 1, 1, 0), mtime.utc
|
342
|
+
assert mtime.utc.utc?
|
343
|
+
assert_equal 'America/New_York', mtime.time_zone.name
|
344
|
+
assert_equal Time.utc(1999, 12, 31, 19), mtime.time
|
345
|
+
assert mtime.time.utc?
|
346
|
+
assert_equal @twz.inspect, mtime.inspect
|
347
|
+
end
|
348
|
+
|
349
|
+
def test_freeze
|
350
|
+
@twz.freeze
|
351
|
+
assert @twz.frozen?
|
352
|
+
end
|
353
|
+
|
354
|
+
def test_freeze_preloads_instance_variables
|
355
|
+
@twz.freeze
|
356
|
+
assert_nothing_raised do
|
357
|
+
@twz.period
|
358
|
+
@twz.time
|
359
|
+
end
|
360
|
+
end
|
361
|
+
|
362
|
+
def test_method_missing_with_non_time_return_value
|
363
|
+
@twz.time.expects(:foo).returns('bar')
|
364
|
+
assert_equal 'bar', @twz.foo
|
365
|
+
end
|
366
|
+
|
367
|
+
def test_date_part_value_methods
|
368
|
+
twz = ActiveSupport::TimeWithZone.new(Time.utc(1999,12,31,19,18,17,500), @time_zone)
|
369
|
+
twz.expects(:method_missing).never
|
370
|
+
assert_equal 1999, twz.year
|
371
|
+
assert_equal 12, twz.month
|
372
|
+
assert_equal 31, twz.day
|
373
|
+
assert_equal 14, twz.hour
|
374
|
+
assert_equal 18, twz.min
|
375
|
+
assert_equal 17, twz.sec
|
376
|
+
assert_equal 500, twz.usec
|
377
|
+
assert_equal 5, twz.wday
|
378
|
+
assert_equal 365, twz.yday
|
379
|
+
end
|
380
|
+
|
381
|
+
def test_usec_returns_0_when_datetime_is_wrapped
|
382
|
+
twz = ActiveSupport::TimeWithZone.new(DateTime.civil(2000), @time_zone)
|
383
|
+
assert_equal 0, twz.usec
|
384
|
+
end
|
385
|
+
|
386
|
+
def test_utc_to_local_conversion_saves_period_in_instance_variable
|
387
|
+
assert_nil @twz.instance_variable_get('@period')
|
388
|
+
@twz.time
|
389
|
+
assert_kind_of TZInfo::TimezonePeriod, @twz.instance_variable_get('@period')
|
390
|
+
end
|
391
|
+
|
392
|
+
def test_instance_created_with_local_time_returns_correct_utc_time
|
393
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(1999, 12, 31, 19))
|
394
|
+
assert_equal Time.utc(2000), twz.utc
|
395
|
+
end
|
396
|
+
|
397
|
+
def test_instance_created_with_local_time_enforces_spring_dst_rules
|
398
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,2,2)) # first second of DST
|
399
|
+
assert_equal Time.utc(2006,4,2,3), twz.time # springs forward to 3AM
|
400
|
+
assert_equal true, twz.dst?
|
401
|
+
assert_equal 'EDT', twz.zone
|
402
|
+
end
|
403
|
+
|
404
|
+
def test_instance_created_with_local_time_enforces_fall_dst_rules
|
405
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,10,29,1)) # 1AM can be either DST or non-DST; we'll pick DST
|
406
|
+
assert_equal Time.utc(2006,10,29,1), twz.time
|
407
|
+
assert_equal true, twz.dst?
|
408
|
+
assert_equal 'EDT', twz.zone
|
409
|
+
end
|
410
|
+
|
411
|
+
def test_ruby_19_weekday_name_query_methods
|
412
|
+
ruby_19_or_greater = RUBY_VERSION >= '1.9'
|
413
|
+
%w(sunday? monday? tuesday? wednesday? thursday? friday? saturday?).each do |name|
|
414
|
+
assert_equal ruby_19_or_greater, @twz.respond_to?(name)
|
415
|
+
end
|
416
|
+
end
|
417
|
+
|
418
|
+
def test_utc_to_local_conversion_with_far_future_datetime
|
419
|
+
assert_equal [0,0,19,31,12,2049], ActiveSupport::TimeWithZone.new(DateTime.civil(2050), @time_zone).to_a[0,6]
|
420
|
+
end
|
421
|
+
|
422
|
+
def test_local_to_utc_conversion_with_far_future_datetime
|
423
|
+
assert_equal DateTime.civil(2050).to_f, ActiveSupport::TimeWithZone.new(nil, @time_zone, DateTime.civil(2049,12,31,19)).to_f
|
424
|
+
end
|
425
|
+
|
426
|
+
def test_change
|
427
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
428
|
+
assert_equal "Mon, 31 Dec 2001 19:00:00 EST -05:00", @twz.change(:year => 2001).inspect
|
429
|
+
assert_equal "Wed, 31 Mar 1999 19:00:00 EST -05:00", @twz.change(:month => 3).inspect
|
430
|
+
assert_equal "Wed, 03 Mar 1999 19:00:00 EST -05:00", @twz.change(:month => 2).inspect
|
431
|
+
assert_equal "Wed, 15 Dec 1999 19:00:00 EST -05:00", @twz.change(:day => 15).inspect
|
432
|
+
assert_equal "Fri, 31 Dec 1999 06:00:00 EST -05:00", @twz.change(:hour => 6).inspect
|
433
|
+
assert_equal "Fri, 31 Dec 1999 19:15:00 EST -05:00", @twz.change(:min => 15).inspect
|
434
|
+
assert_equal "Fri, 31 Dec 1999 19:00:30 EST -05:00", @twz.change(:sec => 30).inspect
|
435
|
+
end
|
436
|
+
|
437
|
+
def test_advance
|
438
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
439
|
+
assert_equal "Mon, 31 Dec 2001 19:00:00 EST -05:00", @twz.advance(:years => 2).inspect
|
440
|
+
assert_equal "Fri, 31 Mar 2000 19:00:00 EST -05:00", @twz.advance(:months => 3).inspect
|
441
|
+
assert_equal "Tue, 04 Jan 2000 19:00:00 EST -05:00", @twz.advance(:days => 4).inspect
|
442
|
+
assert_equal "Sat, 01 Jan 2000 01:00:00 EST -05:00", @twz.advance(:hours => 6).inspect
|
443
|
+
assert_equal "Fri, 31 Dec 1999 19:15:00 EST -05:00", @twz.advance(:minutes => 15).inspect
|
444
|
+
assert_equal "Fri, 31 Dec 1999 19:00:30 EST -05:00", @twz.advance(:seconds => 30).inspect
|
445
|
+
end
|
446
|
+
|
447
|
+
def beginning_of_year
|
448
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
449
|
+
assert_equal "Fri, 01 Jan 1999 00:00:00 EST -05:00", @twz.beginning_of_year.inspect
|
450
|
+
end
|
451
|
+
|
452
|
+
def end_of_year
|
453
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
454
|
+
assert_equal "Fri, 31 Dec 1999 23:59:59 EST -05:00", @twz.end_of_year.inspect
|
455
|
+
end
|
456
|
+
|
457
|
+
def beginning_of_month
|
458
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
459
|
+
assert_equal "Fri, 01 Dec 1999 00:00:00 EST -05:00", @twz.beginning_of_month.inspect
|
460
|
+
end
|
461
|
+
|
462
|
+
def end_of_month
|
463
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
464
|
+
assert_equal "Fri, 31 Dec 1999 23:59:59 EST -05:00", @twz.end_of_month.inspect
|
465
|
+
end
|
466
|
+
|
467
|
+
def beginning_of_day
|
468
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
469
|
+
assert_equal "Fri, 31 Dec 1999 00:00:00 EST -05:00", @twz.beginning_of_day.inspect
|
470
|
+
end
|
471
|
+
|
472
|
+
def end_of_day
|
473
|
+
assert_equal "Fri, 31 Dec 1999 19:00:00 EST -05:00", @twz.inspect
|
474
|
+
assert_equal "Fri, 31 Dec 1999 23:59:59 EST -05:00", @twz.end_of_day.inspect
|
475
|
+
end
|
476
|
+
|
477
|
+
def test_since
|
478
|
+
assert_equal "Fri, 31 Dec 1999 19:00:01 EST -05:00", @twz.since(1).inspect
|
479
|
+
end
|
480
|
+
|
481
|
+
def test_ago
|
482
|
+
assert_equal "Fri, 31 Dec 1999 18:59:59 EST -05:00", @twz.ago(1).inspect
|
483
|
+
end
|
484
|
+
|
485
|
+
def test_seconds_since_midnight
|
486
|
+
assert_equal 19 * 60 * 60, @twz.seconds_since_midnight
|
487
|
+
end
|
488
|
+
|
489
|
+
def test_advance_1_year_from_leap_day
|
490
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2004,2,29))
|
491
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", twz.advance(:years => 1).inspect
|
492
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", twz.years_since(1).inspect
|
493
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", twz.since(1.year).inspect
|
494
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", (twz + 1.year).inspect
|
495
|
+
end
|
496
|
+
|
497
|
+
def test_advance_1_month_from_last_day_of_january
|
498
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2005,1,31))
|
499
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", twz.advance(:months => 1).inspect
|
500
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", twz.months_since(1).inspect
|
501
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", twz.since(1.month).inspect
|
502
|
+
assert_equal "Mon, 28 Feb 2005 00:00:00 EST -05:00", (twz + 1.month).inspect
|
503
|
+
end
|
504
|
+
|
505
|
+
def test_advance_1_month_from_last_day_of_january_during_leap_year
|
506
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2000,1,31))
|
507
|
+
assert_equal "Tue, 29 Feb 2000 00:00:00 EST -05:00", twz.advance(:months => 1).inspect
|
508
|
+
assert_equal "Tue, 29 Feb 2000 00:00:00 EST -05:00", twz.months_since(1).inspect
|
509
|
+
assert_equal "Tue, 29 Feb 2000 00:00:00 EST -05:00", twz.since(1.month).inspect
|
510
|
+
assert_equal "Tue, 29 Feb 2000 00:00:00 EST -05:00", (twz + 1.month).inspect
|
511
|
+
end
|
512
|
+
|
513
|
+
def test_advance_1_month_into_spring_dst_gap
|
514
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,3,2,2))
|
515
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", twz.advance(:months => 1).inspect
|
516
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", twz.months_since(1).inspect
|
517
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", twz.since(1.month).inspect
|
518
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", (twz + 1.month).inspect
|
519
|
+
end
|
520
|
+
|
521
|
+
def test_advance_1_second_into_spring_dst_gap
|
522
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,2,1,59,59))
|
523
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", twz.advance(:seconds => 1).inspect
|
524
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", (twz + 1).inspect
|
525
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", twz.since(1).inspect
|
526
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", twz.since(1.second).inspect
|
527
|
+
assert_equal "Sun, 02 Apr 2006 03:00:00 EDT -04:00", (twz + 1.second).inspect
|
528
|
+
end
|
529
|
+
|
530
|
+
def test_advance_1_day_across_spring_dst_transition
|
531
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,1,10,30))
|
532
|
+
# In 2006, spring DST transition occurred Apr 2 at 2AM; this day was only 23 hours long
|
533
|
+
# When we advance 1 day, we want to end up at the same time on the next day
|
534
|
+
assert_equal "Sun, 02 Apr 2006 10:30:00 EDT -04:00", twz.advance(:days => 1).inspect
|
535
|
+
assert_equal "Sun, 02 Apr 2006 10:30:00 EDT -04:00", twz.since(1.days).inspect
|
536
|
+
assert_equal "Sun, 02 Apr 2006 10:30:00 EDT -04:00", (twz + 1.days).inspect
|
537
|
+
assert_equal "Sun, 02 Apr 2006 10:30:01 EDT -04:00", twz.since(1.days + 1.second).inspect
|
538
|
+
assert_equal "Sun, 02 Apr 2006 10:30:01 EDT -04:00", (twz + 1.days + 1.second).inspect
|
539
|
+
end
|
540
|
+
|
541
|
+
def test_advance_1_day_across_spring_dst_transition_backwards
|
542
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,2,10,30))
|
543
|
+
# In 2006, spring DST transition occurred Apr 2 at 2AM; this day was only 23 hours long
|
544
|
+
# When we advance back 1 day, we want to end up at the same time on the previous day
|
545
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.advance(:days => -1).inspect
|
546
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.ago(1.days).inspect
|
547
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", (twz - 1.days).inspect
|
548
|
+
assert_equal "Sat, 01 Apr 2006 10:30:01 EST -05:00", twz.ago(1.days - 1.second).inspect
|
549
|
+
end
|
550
|
+
|
551
|
+
def test_advance_1_day_expressed_as_number_of_seconds_minutes_or_hours_across_spring_dst_transition
|
552
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,1,10,30))
|
553
|
+
# In 2006, spring DST transition occurred Apr 2 at 2AM; this day was only 23 hours long
|
554
|
+
# When we advance a specific number of hours, minutes or seconds, we want to advance exactly that amount
|
555
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", (twz + 86400).inspect
|
556
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", (twz + 86400.seconds).inspect
|
557
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.since(86400).inspect
|
558
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.since(86400.seconds).inspect
|
559
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.advance(:seconds => 86400).inspect
|
560
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", (twz + 1440.minutes).inspect
|
561
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.since(1440.minutes).inspect
|
562
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.advance(:minutes => 1440).inspect
|
563
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", (twz + 24.hours).inspect
|
564
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.since(24.hours).inspect
|
565
|
+
assert_equal "Sun, 02 Apr 2006 11:30:00 EDT -04:00", twz.advance(:hours => 24).inspect
|
566
|
+
end
|
567
|
+
|
568
|
+
def test_advance_1_day_expressed_as_number_of_seconds_minutes_or_hours_across_spring_dst_transition_backwards
|
569
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,2,11,30))
|
570
|
+
# In 2006, spring DST transition occurred Apr 2 at 2AM; this day was only 23 hours long
|
571
|
+
# When we advance a specific number of hours, minutes or seconds, we want to advance exactly that amount
|
572
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", (twz - 86400).inspect
|
573
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", (twz - 86400.seconds).inspect
|
574
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.ago(86400).inspect
|
575
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.ago(86400.seconds).inspect
|
576
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.advance(:seconds => -86400).inspect
|
577
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", (twz - 1440.minutes).inspect
|
578
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.ago(1440.minutes).inspect
|
579
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.advance(:minutes => -1440).inspect
|
580
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", (twz - 24.hours).inspect
|
581
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.ago(24.hours).inspect
|
582
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.advance(:hours => -24).inspect
|
583
|
+
end
|
584
|
+
|
585
|
+
def test_advance_1_day_across_fall_dst_transition
|
586
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,10,28,10,30))
|
587
|
+
# In 2006, fall DST transition occurred Oct 29 at 2AM; this day was 25 hours long
|
588
|
+
# When we advance 1 day, we want to end up at the same time on the next day
|
589
|
+
assert_equal "Sun, 29 Oct 2006 10:30:00 EST -05:00", twz.advance(:days => 1).inspect
|
590
|
+
assert_equal "Sun, 29 Oct 2006 10:30:00 EST -05:00", twz.since(1.days).inspect
|
591
|
+
assert_equal "Sun, 29 Oct 2006 10:30:00 EST -05:00", (twz + 1.days).inspect
|
592
|
+
assert_equal "Sun, 29 Oct 2006 10:30:01 EST -05:00", twz.since(1.days + 1.second).inspect
|
593
|
+
assert_equal "Sun, 29 Oct 2006 10:30:01 EST -05:00", (twz + 1.days + 1.second).inspect
|
594
|
+
end
|
595
|
+
|
596
|
+
def test_advance_1_day_across_fall_dst_transition_backwards
|
597
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,10,29,10,30))
|
598
|
+
# In 2006, fall DST transition occurred Oct 29 at 2AM; this day was 25 hours long
|
599
|
+
# When we advance backwards 1 day, we want to end up at the same time on the previous day
|
600
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.advance(:days => -1).inspect
|
601
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.ago(1.days).inspect
|
602
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", (twz - 1.days).inspect
|
603
|
+
assert_equal "Sat, 28 Oct 2006 10:30:01 EDT -04:00", twz.ago(1.days - 1.second).inspect
|
604
|
+
end
|
605
|
+
|
606
|
+
def test_advance_1_day_expressed_as_number_of_seconds_minutes_or_hours_across_fall_dst_transition
|
607
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,10,28,10,30))
|
608
|
+
# In 2006, fall DST transition occurred Oct 29 at 2AM; this day was 25 hours long
|
609
|
+
# When we advance a specific number of hours, minutes or seconds, we want to advance exactly that amount
|
610
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", (twz + 86400).inspect
|
611
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", (twz + 86400.seconds).inspect
|
612
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.since(86400).inspect
|
613
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.since(86400.seconds).inspect
|
614
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.advance(:seconds => 86400).inspect
|
615
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", (twz + 1440.minutes).inspect
|
616
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.since(1440.minutes).inspect
|
617
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.advance(:minutes => 1440).inspect
|
618
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", (twz + 24.hours).inspect
|
619
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.since(24.hours).inspect
|
620
|
+
assert_equal "Sun, 29 Oct 2006 09:30:00 EST -05:00", twz.advance(:hours => 24).inspect
|
621
|
+
end
|
622
|
+
|
623
|
+
def test_advance_1_day_expressed_as_number_of_seconds_minutes_or_hours_across_fall_dst_transition_backwards
|
624
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,10,29,9,30))
|
625
|
+
# In 2006, fall DST transition occurred Oct 29 at 2AM; this day was 25 hours long
|
626
|
+
# When we advance a specific number of hours, minutes or seconds, we want to advance exactly that amount
|
627
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", (twz - 86400).inspect
|
628
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", (twz - 86400.seconds).inspect
|
629
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.ago(86400).inspect
|
630
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.ago(86400.seconds).inspect
|
631
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.advance(:seconds => -86400).inspect
|
632
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", (twz - 1440.minutes).inspect
|
633
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.ago(1440.minutes).inspect
|
634
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.advance(:minutes => -1440).inspect
|
635
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", (twz - 24.hours).inspect
|
636
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.ago(24.hours).inspect
|
637
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.advance(:hours => -24).inspect
|
638
|
+
end
|
639
|
+
|
640
|
+
def test_advance_1_month_across_spring_dst_transition
|
641
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,4,1,10,30))
|
642
|
+
assert_equal "Mon, 01 May 2006 10:30:00 EDT -04:00", twz.advance(:months => 1).inspect
|
643
|
+
assert_equal "Mon, 01 May 2006 10:30:00 EDT -04:00", twz.months_since(1).inspect
|
644
|
+
assert_equal "Mon, 01 May 2006 10:30:00 EDT -04:00", twz.since(1.month).inspect
|
645
|
+
assert_equal "Mon, 01 May 2006 10:30:00 EDT -04:00", (twz + 1.month).inspect
|
646
|
+
end
|
647
|
+
|
648
|
+
def test_advance_1_month_across_spring_dst_transition_backwards
|
649
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,5,1,10,30))
|
650
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.advance(:months => -1).inspect
|
651
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.months_ago(1).inspect
|
652
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", twz.ago(1.month).inspect
|
653
|
+
assert_equal "Sat, 01 Apr 2006 10:30:00 EST -05:00", (twz - 1.month).inspect
|
654
|
+
end
|
655
|
+
|
656
|
+
def test_advance_1_month_across_fall_dst_transition
|
657
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,10,28,10,30))
|
658
|
+
assert_equal "Tue, 28 Nov 2006 10:30:00 EST -05:00", twz.advance(:months => 1).inspect
|
659
|
+
assert_equal "Tue, 28 Nov 2006 10:30:00 EST -05:00", twz.months_since(1).inspect
|
660
|
+
assert_equal "Tue, 28 Nov 2006 10:30:00 EST -05:00", twz.since(1.month).inspect
|
661
|
+
assert_equal "Tue, 28 Nov 2006 10:30:00 EST -05:00", (twz + 1.month).inspect
|
662
|
+
end
|
663
|
+
|
664
|
+
def test_advance_1_month_across_fall_dst_transition_backwards
|
665
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2006,11,28,10,30))
|
666
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.advance(:months => -1).inspect
|
667
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.months_ago(1).inspect
|
668
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", twz.ago(1.month).inspect
|
669
|
+
assert_equal "Sat, 28 Oct 2006 10:30:00 EDT -04:00", (twz - 1.month).inspect
|
670
|
+
end
|
671
|
+
|
672
|
+
def test_advance_1_year
|
673
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2008,2,15,10,30))
|
674
|
+
assert_equal "Sun, 15 Feb 2009 10:30:00 EST -05:00", twz.advance(:years => 1).inspect
|
675
|
+
assert_equal "Sun, 15 Feb 2009 10:30:00 EST -05:00", twz.years_since(1).inspect
|
676
|
+
assert_equal "Sun, 15 Feb 2009 10:30:00 EST -05:00", (twz + 1.year).inspect
|
677
|
+
assert_equal "Thu, 15 Feb 2007 10:30:00 EST -05:00", twz.advance(:years => -1).inspect
|
678
|
+
assert_equal "Thu, 15 Feb 2007 10:30:00 EST -05:00", twz.years_ago(1).inspect
|
679
|
+
assert_equal "Thu, 15 Feb 2007 10:30:00 EST -05:00", (twz - 1.year).inspect
|
680
|
+
end
|
681
|
+
|
682
|
+
def test_advance_1_year_during_dst
|
683
|
+
twz = ActiveSupport::TimeWithZone.new(nil, @time_zone, Time.utc(2008,7,15,10,30))
|
684
|
+
assert_equal "Wed, 15 Jul 2009 10:30:00 EDT -04:00", twz.advance(:years => 1).inspect
|
685
|
+
assert_equal "Wed, 15 Jul 2009 10:30:00 EDT -04:00", twz.years_since(1).inspect
|
686
|
+
assert_equal "Wed, 15 Jul 2009 10:30:00 EDT -04:00", (twz + 1.year).inspect
|
687
|
+
assert_equal "Sun, 15 Jul 2007 10:30:00 EDT -04:00", twz.advance(:years => -1).inspect
|
688
|
+
assert_equal "Sun, 15 Jul 2007 10:30:00 EDT -04:00", twz.years_ago(1).inspect
|
689
|
+
assert_equal "Sun, 15 Jul 2007 10:30:00 EDT -04:00", (twz - 1.year).inspect
|
690
|
+
end
|
691
|
+
|
692
|
+
protected
|
693
|
+
def with_env_tz(new_tz = 'US/Eastern')
|
694
|
+
old_tz, ENV['TZ'] = ENV['TZ'], new_tz
|
695
|
+
yield
|
696
|
+
ensure
|
697
|
+
old_tz ? ENV['TZ'] = old_tz : ENV.delete('TZ')
|
698
|
+
end
|
699
|
+
end
|
700
|
+
|
701
|
+
class TimeWithZoneMethodsForTimeAndDateTimeTest < Test::Unit::TestCase
|
702
|
+
def setup
|
703
|
+
@t, @dt = Time.utc(2000), DateTime.civil(2000)
|
704
|
+
end
|
705
|
+
|
706
|
+
def teardown
|
707
|
+
Time.zone = nil
|
708
|
+
end
|
709
|
+
|
710
|
+
def test_in_time_zone
|
711
|
+
Time.use_zone 'Alaska' do
|
712
|
+
assert_equal 'Fri, 31 Dec 1999 15:00:00 AKST -09:00', @t.in_time_zone.inspect
|
713
|
+
assert_equal 'Fri, 31 Dec 1999 15:00:00 AKST -09:00', @dt.in_time_zone.inspect
|
714
|
+
end
|
715
|
+
Time.use_zone 'Hawaii' do
|
716
|
+
assert_equal 'Fri, 31 Dec 1999 14:00:00 HST -10:00', @t.in_time_zone.inspect
|
717
|
+
assert_equal 'Fri, 31 Dec 1999 14:00:00 HST -10:00', @dt.in_time_zone.inspect
|
718
|
+
end
|
719
|
+
Time.use_zone nil do
|
720
|
+
assert_equal @t, @t.in_time_zone
|
721
|
+
assert_equal @dt, @dt.in_time_zone
|
722
|
+
end
|
723
|
+
end
|
724
|
+
|
725
|
+
def test_in_time_zone_with_argument
|
726
|
+
Time.use_zone 'Eastern Time (US & Canada)' do # Time.zone will not affect #in_time_zone(zone)
|
727
|
+
assert_equal 'Fri, 31 Dec 1999 15:00:00 AKST -09:00', @t.in_time_zone('Alaska').inspect
|
728
|
+
assert_equal 'Fri, 31 Dec 1999 15:00:00 AKST -09:00', @dt.in_time_zone('Alaska').inspect
|
729
|
+
assert_equal 'Fri, 31 Dec 1999 14:00:00 HST -10:00', @t.in_time_zone('Hawaii').inspect
|
730
|
+
assert_equal 'Fri, 31 Dec 1999 14:00:00 HST -10:00', @dt.in_time_zone('Hawaii').inspect
|
731
|
+
assert_equal 'Sat, 01 Jan 2000 00:00:00 UTC +00:00', @t.in_time_zone('UTC').inspect
|
732
|
+
assert_equal 'Sat, 01 Jan 2000 00:00:00 UTC +00:00', @dt.in_time_zone('UTC').inspect
|
733
|
+
assert_equal 'Fri, 31 Dec 1999 15:00:00 AKST -09:00', @t.in_time_zone(-9.hours).inspect
|
734
|
+
end
|
735
|
+
end
|
736
|
+
|
737
|
+
def test_in_time_zone_with_time_local_instance
|
738
|
+
with_env_tz 'US/Eastern' do
|
739
|
+
time = Time.local(1999, 12, 31, 19) # == Time.utc(2000)
|
740
|
+
assert_equal 'Fri, 31 Dec 1999 15:00:00 AKST -09:00', time.in_time_zone('Alaska').inspect
|
741
|
+
end
|
742
|
+
end
|
743
|
+
|
744
|
+
def test_use_zone
|
745
|
+
Time.zone = 'Alaska'
|
746
|
+
Time.use_zone 'Hawaii' do
|
747
|
+
assert_equal ActiveSupport::TimeZone['Hawaii'], Time.zone
|
748
|
+
end
|
749
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
750
|
+
end
|
751
|
+
|
752
|
+
def test_use_zone_with_exception_raised
|
753
|
+
Time.zone = 'Alaska'
|
754
|
+
assert_raise RuntimeError do
|
755
|
+
Time.use_zone('Hawaii') { raise RuntimeError }
|
756
|
+
end
|
757
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
758
|
+
end
|
759
|
+
|
760
|
+
def test_time_zone_getter_and_setter
|
761
|
+
Time.zone = ActiveSupport::TimeZone['Alaska']
|
762
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
763
|
+
Time.zone = 'Alaska'
|
764
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
765
|
+
Time.zone = -9.hours
|
766
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
767
|
+
Time.zone = nil
|
768
|
+
assert_equal nil, Time.zone
|
769
|
+
end
|
770
|
+
|
771
|
+
def test_time_zone_getter_and_setter_with_zone_default
|
772
|
+
Time.zone_default = ActiveSupport::TimeZone['Alaska']
|
773
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
774
|
+
Time.zone = ActiveSupport::TimeZone['Hawaii']
|
775
|
+
assert_equal ActiveSupport::TimeZone['Hawaii'], Time.zone
|
776
|
+
Time.zone = nil
|
777
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], Time.zone
|
778
|
+
ensure
|
779
|
+
Time.zone_default = nil
|
780
|
+
end
|
781
|
+
|
782
|
+
def test_time_zone_setter_is_thread_safe
|
783
|
+
Time.use_zone 'Paris' do
|
784
|
+
t1 = Thread.new { Time.zone = 'Alaska' }.join
|
785
|
+
t2 = Thread.new { Time.zone = 'Hawaii' }.join
|
786
|
+
assert t1.stop?, "Thread 1 did not finish running"
|
787
|
+
assert t2.stop?, "Thread 2 did not finish running"
|
788
|
+
assert_equal ActiveSupport::TimeZone['Paris'], Time.zone
|
789
|
+
assert_equal ActiveSupport::TimeZone['Alaska'], t1[:time_zone]
|
790
|
+
assert_equal ActiveSupport::TimeZone['Hawaii'], t2[:time_zone]
|
791
|
+
end
|
792
|
+
end
|
793
|
+
|
794
|
+
def test_time_zone_setter_with_tzinfo_timezone_object_wraps_in_rails_time_zone
|
795
|
+
tzinfo = TZInfo::Timezone.get('America/New_York')
|
796
|
+
Time.zone = tzinfo
|
797
|
+
assert_kind_of ActiveSupport::TimeZone, Time.zone
|
798
|
+
assert_equal tzinfo, Time.zone.tzinfo
|
799
|
+
assert_equal 'America/New_York', Time.zone.name
|
800
|
+
assert_equal(-18_000, Time.zone.utc_offset)
|
801
|
+
end
|
802
|
+
|
803
|
+
def test_time_zone_setter_with_tzinfo_timezone_identifier_does_lookup_and_wraps_in_rails_time_zone
|
804
|
+
Time.zone = 'America/New_York'
|
805
|
+
assert_kind_of ActiveSupport::TimeZone, Time.zone
|
806
|
+
assert_equal 'America/New_York', Time.zone.tzinfo.name
|
807
|
+
assert_equal 'America/New_York', Time.zone.name
|
808
|
+
assert_equal(-18_000, Time.zone.utc_offset)
|
809
|
+
end
|
810
|
+
|
811
|
+
def test_time_zone_setter_with_non_identifying_argument_returns_nil
|
812
|
+
Time.zone = 'foo'
|
813
|
+
assert_equal nil, Time.zone
|
814
|
+
Time.zone = -15.hours
|
815
|
+
assert_equal nil, Time.zone
|
816
|
+
end
|
817
|
+
|
818
|
+
def test_current_returns_time_now_when_zone_default_not_set
|
819
|
+
with_env_tz 'US/Eastern' do
|
820
|
+
Time.stubs(:now).returns Time.local(2000)
|
821
|
+
assert_equal false, Time.current.is_a?(ActiveSupport::TimeWithZone)
|
822
|
+
assert_equal Time.local(2000), Time.current
|
823
|
+
end
|
824
|
+
end
|
825
|
+
|
826
|
+
def test_current_returns_time_zone_now_when_zone_default_set
|
827
|
+
Time.zone_default = ActiveSupport::TimeZone['Eastern Time (US & Canada)']
|
828
|
+
with_env_tz 'US/Eastern' do
|
829
|
+
Time.stubs(:now).returns Time.local(2000)
|
830
|
+
assert_equal true, Time.current.is_a?(ActiveSupport::TimeWithZone)
|
831
|
+
assert_equal 'Eastern Time (US & Canada)', Time.current.time_zone.name
|
832
|
+
assert_equal Time.utc(2000), Time.current.time
|
833
|
+
end
|
834
|
+
ensure
|
835
|
+
Time.zone_default = nil
|
836
|
+
end
|
837
|
+
|
838
|
+
protected
|
839
|
+
def with_env_tz(new_tz = 'US/Eastern')
|
840
|
+
old_tz, ENV['TZ'] = ENV['TZ'], new_tz
|
841
|
+
yield
|
842
|
+
ensure
|
843
|
+
old_tz ? ENV['TZ'] = old_tz : ENV.delete('TZ')
|
844
|
+
end
|
845
|
+
end
|