radiant 0.9.1 → 1.0.0.rc1
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/.gitignore +19 -0
- data/CHANGELOG +26 -0
- data/CONTRIBUTORS +18 -0
- data/Gemfile +3 -0
- data/app/controllers/admin/configuration_controller.rb +50 -0
- data/app/controllers/admin/page_fields_controller.rb +9 -0
- data/app/controllers/admin/pages_controller.rb +39 -8
- data/app/controllers/admin/preferences_controller.rb +1 -1
- data/app/controllers/admin/resource_controller.rb +10 -2
- data/app/controllers/admin/welcome_controller.rb +6 -1
- data/app/controllers/application_controller.rb +0 -1
- data/app/controllers/site_controller.rb +1 -1
- data/app/helpers/admin/configuration_helper.rb +80 -0
- data/app/helpers/admin/node_helper.rb +47 -1
- data/app/helpers/admin/pages_helper.rb +5 -7
- data/app/helpers/admin/preferences_helper.rb +1 -0
- data/app/helpers/admin/references_helper.rb +2 -3
- data/app/helpers/application_helper.rb +4 -3
- data/app/models/deprecated_tags.rb +77 -0
- data/app/models/file_not_found_page.rb +4 -0
- data/app/models/page.rb +75 -24
- data/app/models/page_field.rb +3 -0
- data/app/models/page_part.rb +0 -1
- data/app/models/radiant/config.rb +239 -38
- data/app/models/snippet.rb +4 -0
- data/app/models/standard_tags.rb +202 -156
- data/app/models/status.rb +9 -1
- data/app/models/text_filter.rb +12 -1
- data/app/models/user.rb +1 -2
- data/app/models/user_action_observer.rb +9 -3
- data/app/views/admin/configuration/edit.html.haml +38 -0
- data/app/views/admin/configuration/show.html.haml +58 -0
- data/app/views/admin/extensions/index.html.haml +2 -2
- data/app/views/admin/layouts/_form.html.haml +2 -2
- data/app/views/admin/layouts/index.html.haml +10 -10
- data/app/views/admin/layouts/remove.html.haml +1 -1
- data/app/views/admin/page_fields/_page_field.html.haml +12 -0
- data/app/views/admin/pages/_fields.html.haml +22 -5
- data/app/views/admin/pages/_meta_row.html.haml +5 -1
- data/app/views/admin/pages/_node.html.haml +10 -9
- data/app/views/admin/pages/_popups.html.haml +17 -4
- data/app/views/admin/pages/edit.html.haml +1 -1
- data/app/views/admin/pages/index.html.haml +5 -5
- data/app/views/admin/pages/remove.html.haml +1 -1
- data/app/views/admin/preferences/edit.html.haml +1 -1
- data/app/views/admin/references/filters.haml +1 -1
- data/app/views/admin/references/tags.haml +1 -1
- data/app/views/admin/snippets/_form.html.haml +2 -2
- data/app/views/admin/snippets/index.html.haml +11 -11
- data/app/views/admin/snippets/remove.html.haml +1 -1
- data/app/views/admin/users/_avatar.html.haml +3 -1
- data/app/views/admin/users/_form.html.haml +3 -3
- data/app/views/admin/users/_password_fields.html.haml +2 -2
- data/app/views/admin/users/index.html.haml +11 -11
- data/app/views/admin/users/remove.html.haml +1 -1
- data/app/views/admin/welcome/login.html.haml +1 -1
- data/app/views/layouts/application.html.haml +9 -14
- data/config/boot.rb +28 -11
- data/config/compass.config +18 -0
- data/config/environment.rb +10 -5
- data/config/environments/cucumber.rb +5 -5
- data/config/environments/test.rb +5 -5
- data/config/initializers/compass.rb +3 -0
- data/config/initializers/radiant_config.rb +17 -0
- data/config/locales/en.yml +61 -13
- data/config/locales/en_available_tags.yml +131 -39
- data/config/routes.rb +4 -6
- data/db/migrate/20100805154952_add_page_fields.rb +15 -0
- data/db/migrate/20100805155020_convert_page_metas.rb +15 -0
- data/db/migrate/20100810151922_add_field_name_index.rb +11 -0
- data/db/schema.rb +32 -7
- data/features/admin/configuration.feature +38 -0
- data/features/admin/pages_management.feature +2 -9
- data/features/admin/resource_pagination.feature +1 -1
- data/features/admin/snippets_management.feature +2 -1
- data/features/admin/user_permissions.feature +3 -4
- data/features/admin/user_preferences.feature +1 -1
- data/features/step_definitions/admin/admin_steps.rb +1 -1
- data/features/step_definitions/admin/content_negotiation_steps.rb +4 -0
- data/features/step_definitions/admin/pages_management_steps.rb +5 -1
- data/features/step_definitions/admin/pagination_steps.rb +2 -4
- data/features/step_definitions/page_serving_steps.rb +16 -0
- data/features/support/dataset.rb +7 -3
- data/features/support/datasets_loader.rb +3 -0
- data/features/support/env.rb +2 -0
- data/features/support/matchers.rb +3 -0
- data/features/support/paths.rb +2 -0
- data/lib/generators/extension/extension_generator.rb +6 -0
- data/lib/generators/extension/templates/README +4 -1
- data/lib/generators/extension/templates/RSpecRakefile +1 -28
- data/lib/generators/extension/templates/Rakefile +0 -17
- data/lib/generators/extension/templates/cucumber_datasets_loader.rb +3 -0
- data/lib/generators/extension/templates/cucumber_env.rb +1 -10
- data/lib/generators/extension/templates/extension.rb +3 -3
- data/lib/generators/extension/templates/gemspec.rb +24 -0
- data/lib/generators/extension/templates/lib.rb +2 -0
- data/lib/generators/extension/templates/radiant_config.rb +3 -0
- data/lib/generators/extension/templates/version.rb +3 -0
- data/lib/generators/instance/instance_generator.rb +3 -2
- data/lib/generators/instance/templates/instance_boot.rb +28 -10
- data/lib/generators/instance/templates/instance_environment.rb +10 -5
- data/lib/generators/instance/templates/instance_radiant_config.rb +16 -0
- data/lib/generators/language_extension/templates/lang.yml +11 -11
- data/lib/plugins/active_record_extensions/lib/active_record_extensions.rb +10 -0
- data/lib/plugins/object_extensions/lib/object_extensions.rb +3 -0
- data/lib/radiant.rb +4 -4
- data/lib/radiant/admin_ui.rb +58 -41
- data/lib/radiant/available_locales.rb +8 -8
- data/lib/radiant/cache.rb +1 -0
- data/lib/radiant/config/definition.rb +142 -0
- data/lib/radiant/extension.rb +20 -4
- data/lib/radiant/extension/script.rb +15 -15
- data/lib/radiant/extension_gem.rb +12 -0
- data/lib/radiant/extension_loader.rb +12 -5
- data/lib/radiant/extension_locator.rb +25 -0
- data/lib/radiant/extension_migrator.rb +3 -2
- data/lib/radiant/gem_dependency_fix.rb +21 -0
- data/lib/radiant/gem_locator.rb +28 -0
- data/lib/radiant/initializer.rb +74 -7
- data/lib/radiant/pagination/controller.rb +1 -0
- data/lib/radiant/setup.rb +19 -11
- data/lib/task_support.rb +14 -8
- data/lib/tasks/database.rake +2 -0
- data/lib/tasks/framework.rake +32 -15
- data/lib/tasks/prototype.rake +8 -11
- data/lib/tasks/release.rake +1 -0
- data/public/assets/1/2375_1115822414591_1197894784_30347214_1109_n.jpg +0 -0
- data/public/assets/1/2375_1115822414591_1197894784_30347214_1109_n_icon.png +0 -0
- data/public/assets/1/2375_1115822414591_1197894784_30347214_1109_n_normal.jpg +0 -0
- data/public/assets/1/2375_1115822414591_1197894784_30347214_1109_n_thumbnail.png +0 -0
- data/public/flash/ZeroClipboard.swf +0 -0
- data/public/images/admin/assets/add.png +0 -0
- data/public/images/admin/assets/archive_icon.png +0 -0
- data/public/images/admin/assets/audio_icon.png +0 -0
- data/public/images/admin/assets/audio_thumbnail.png +0 -0
- data/public/images/admin/assets/c_icon.png +0 -0
- data/public/images/admin/assets/copy.png +0 -0
- data/public/images/admin/assets/css_icon.png +0 -0
- data/public/images/admin/assets/database_icon.png +0 -0
- data/public/images/admin/assets/delete.png +0 -0
- data/public/images/admin/assets/document_icon.png +0 -0
- data/public/images/admin/assets/document_thumbnail.png +0 -0
- data/public/images/admin/assets/flash_icon.png +0 -0
- data/public/images/admin/assets/flash_thumbnail.png +0 -0
- data/public/images/admin/assets/font_icon.png +0 -0
- data/public/images/admin/assets/gzip_icon.png +0 -0
- data/public/images/admin/assets/html_icon.png +0 -0
- data/public/images/admin/assets/image_icon.png +0 -0
- data/public/images/admin/assets/image_thumbnail.png +0 -0
- data/public/images/admin/assets/java_icon.png +0 -0
- data/public/images/admin/assets/page_edit.png +0 -0
- data/public/images/admin/assets/perl_icon.png +0 -0
- data/public/images/admin/assets/php_icon.png +0 -0
- data/public/images/admin/assets/presentation_icon.png +0 -0
- data/public/images/admin/assets/python_icon.png +0 -0
- data/public/images/admin/assets/reorder_assets.png +0 -0
- data/public/images/admin/assets/ruby_icon.png +0 -0
- data/public/images/admin/assets/script_icon.png +0 -0
- data/public/images/admin/assets/spreadsheet_icon.png +0 -0
- data/public/images/admin/assets/tar_icon.png +0 -0
- data/public/images/admin/assets/unknown_icon.png +0 -0
- data/public/images/admin/assets/unknown_thumbnail.png +0 -0
- data/public/images/admin/assets/video_icon.png +0 -0
- data/public/images/admin/assets/video_thumbnail.png +0 -0
- data/public/images/admin/assets/xml_icon.png +0 -0
- data/public/images/admin/assets/zip_icon.png +0 -0
- data/public/images/admin/avatar_64x64.png +0 -0
- data/public/images/admin/image.png +0 -0
- data/public/images/admin/javascript.png +0 -0
- data/public/images/admin/navigation_secondary_separator.gif +0 -0
- data/public/images/admin/plus_disabled.png +0 -0
- data/public/images/admin/search.png +0 -0
- data/public/images/admin/status_spinner.gif +0 -0
- data/public/images/admin/stylesheet.png +0 -0
- data/public/images/admin/upload.png +0 -0
- data/public/images/{radiant-badge-color.png → radiant/radiant-badge-color.png} +0 -0
- data/public/images/roasters/banner.jpg +0 -0
- data/public/images/roasters/closelabel.gif +0 -0
- data/public/images/roasters/comment.png +0 -0
- data/public/images/roasters/gallery1.jpg +0 -0
- data/public/images/roasters/gallery2.jpg +0 -0
- data/public/images/roasters/gallery3.jpg +0 -0
- data/public/images/roasters/gallery4.jpg +0 -0
- data/public/images/roasters/gift.gif +0 -0
- data/public/images/roasters/green.gif +0 -0
- data/public/images/roasters/nav-background.gif +0 -0
- data/public/images/roasters/nav-divider.gif +0 -0
- data/public/images/roasters/nextlabel.gif +0 -0
- data/public/images/roasters/open.gif +0 -0
- data/public/images/roasters/preview-1.jpg +0 -0
- data/public/images/roasters/preview.jpg +0 -0
- data/public/images/roasters/prevlabel.gif +0 -0
- data/public/images/roasters/prize.gif +0 -0
- data/public/images/roasters/recycle.gif +0 -0
- data/public/images/roasters/rss.gif +0 -0
- data/public/images/roasters/thumb-grinder.jpg +0 -0
- data/public/images/roasters/thumb-grower.jpg +0 -0
- data/public/images/roasters/thumb-roaster.jpg +0 -0
- data/public/images/roasters/truck.gif +0 -0
- data/public/javascripts/admin/application.js +11 -2
- data/public/javascripts/admin/codearea.js +4 -4
- data/public/javascripts/admin/cookie.js +1 -1
- data/public/javascripts/admin/dateinput.js +5 -5
- data/public/javascripts/admin/dropdown.js +216 -0
- data/public/javascripts/admin/page_preview.js +41 -0
- data/public/javascripts/admin/pagefield.js +54 -0
- data/public/javascripts/admin/popup.js +187 -64
- data/public/javascripts/admin/sitemap.js +2 -2
- data/public/javascripts/admin/status.js +13 -13
- data/public/javascripts/admin/tabcontrol.js +9 -7
- data/public/javascripts/admin/toggle.js +18 -18
- data/public/javascripts/admin/utility.js +5 -4
- data/public/loading-iframe.html +11 -0
- data/public/stylesheets/admin/base.css +1 -0
- data/public/stylesheets/admin/main.css +1 -1213
- data/public/stylesheets/admin/overrides.css +0 -1
- data/public/stylesheets/sass/admin/_base.sass +17 -0
- data/public/stylesheets/sass/admin/main.sass +21 -21
- data/public/stylesheets/sass/admin/modules/_boxes.sass +6 -0
- data/public/stylesheets/sass/admin/modules/_links.sass +6 -3
- data/public/stylesheets/sass/admin/partials/_actions.sass +51 -38
- data/public/stylesheets/sass/admin/partials/_avatars.sass +4 -4
- data/public/stylesheets/sass/admin/partials/_content.sass +41 -182
- data/public/stylesheets/sass/admin/partials/_dateinput.sass +5 -5
- data/public/stylesheets/sass/admin/partials/_deprecated.sass +31 -2
- data/public/stylesheets/sass/admin/partials/_dropdown.sass +28 -0
- data/public/stylesheets/sass/admin/partials/_forms.sass +40 -27
- data/public/stylesheets/sass/admin/partials/_header.sass +78 -76
- data/public/stylesheets/sass/admin/partials/_index.sass +147 -0
- data/public/stylesheets/sass/admin/partials/_popup.sass +116 -20
- data/public/stylesheets/sass/admin/partials/_tabcontrol.sass +5 -3
- data/public/stylesheets/sass/admin/partials/{_base.sass → _typography.sass} +4 -3
- data/public/stylesheets/sass/admin/partials/_validations.sass +16 -18
- data/radiant.gemspec +42 -0
- data/spec/controllers/admin/page_fields_controller_spec.rb +17 -0
- data/spec/controllers/admin/pages_controller_spec.rb +87 -6
- data/spec/controllers/admin/preferences_controller_spec.rb +1 -1
- data/spec/controllers/site_controller_spec.rb +4 -4
- data/spec/datasets/config_dataset.rb +3 -1
- data/spec/datasets/home_page_dataset.rb +1 -3
- data/spec/datasets/pages_dataset.rb +1 -1
- data/spec/datasets/users_dataset.rb +1 -1
- data/spec/fixtures/bad_settings.rb +5 -0
- data/spec/fixtures/invalid_config.yml +11 -0
- data/spec/fixtures/more_settings.rb +8 -0
- data/spec/fixtures/radiant_config.yml +2 -2
- data/spec/fixtures/settings.rb +5 -0
- data/spec/generators/extension_controller_generator_spec.rb +20 -18
- data/spec/generators/extension_generator_spec.rb +39 -17
- data/spec/generators/extension_generators_spec_helper.rb +10 -12
- data/spec/generators/extension_mailer_generator_spec.rb +15 -13
- data/spec/generators/extension_migration_generator_spec.rb +6 -5
- data/spec/generators/extension_model_generator_spec.rb +16 -14
- data/spec/generators/instance_generator_spec.rb +27 -20
- data/spec/helpers/admin/node_helper_spec.rb +57 -2
- data/spec/helpers/admin/pages_helper_spec.rb +4 -1
- data/spec/helpers/admin/references_helper_spec.rb +10 -1
- data/spec/helpers/application_helper_spec.rb +7 -2
- data/spec/lib/locator_spec.rb +41 -0
- data/spec/lib/login_system_spec.rb +6 -0
- data/spec/lib/radiant/admin_ui_spec.rb +12 -11
- data/spec/lib/radiant/config/definition_spec.rb +160 -0
- data/spec/lib/radiant/extension_loader_spec.rb +29 -6
- data/spec/lib/radiant/extension_migrator_spec.rb +11 -0
- data/spec/lib/radiant/extension_spec.rb +24 -4
- data/spec/lib/radiant/initializer_spec.rb +10 -0
- data/spec/lib/task_support_spec.rb +6 -0
- data/spec/matchers/render_matcher.rb +4 -4
- data/spec/models/deprecated_tags_spec.rb +85 -0
- data/spec/models/file_not_found_page_spec.rb +15 -11
- data/spec/models/page_part_spec.rb +0 -7
- data/spec/models/page_spec.rb +230 -174
- data/spec/models/radiant/config_spec.rb +38 -3
- data/spec/models/snippet_spec.rb +18 -0
- data/spec/models/standard_tags_spec.rb +175 -154
- data/spec/models/status_spec.rb +11 -0
- data/spec/models/text_filter_spec.rb +6 -2
- data/spec/models/user_spec.rb +0 -7
- data/test/fixtures/extensions/basic/basic_extension.rb +1 -6
- data/test/fixtures/extensions/basic/config/routes.rb +3 -0
- data/test/fixtures/extensions/unrouted/unrouted_extension.rb +2 -0
- data/{log/.keep → test/fixtures/gems/radiant-gem_ext-extension-0.0.0/app/views/dummy.haml} +0 -0
- data/vendor/extensions/archive/Rakefile +13 -24
- data/vendor/extensions/archive/app/models/archive_day_index_page.rb +4 -0
- data/vendor/extensions/archive/app/models/archive_finder.rb +2 -2
- data/vendor/extensions/archive/app/models/archive_month_index_page.rb +4 -0
- data/vendor/extensions/archive/app/models/archive_page.rb +50 -9
- data/vendor/extensions/archive/app/models/archive_year_index_page.rb +4 -0
- data/vendor/extensions/archive/archive_extension.rb +13 -12
- data/vendor/extensions/archive/config/initializers/radiant_config.rb +3 -0
- data/vendor/extensions/archive/config/locales/en.yml +3 -0
- data/vendor/extensions/archive/config/routes.rb +5 -0
- data/vendor/extensions/archive/cucumber.yml +1 -0
- data/vendor/extensions/archive/features/archive_content.feature +51 -0
- data/vendor/extensions/archive/features/step_definitions/web_steps.rb +7 -0
- data/vendor/extensions/archive/features/support/datasets_loader.rb +3 -0
- data/vendor/extensions/archive/features/support/env.rb +7 -0
- data/vendor/extensions/archive/features/support/matchers.rb +3 -0
- data/vendor/extensions/archive/features/support/paths.rb +14 -0
- data/vendor/extensions/archive/lib/archive_index_tags_and_methods.rb +28 -8
- data/vendor/extensions/archive/lib/radiant-archive-extension.rb +2 -0
- data/vendor/extensions/archive/lib/radiant-archive-extension/version.rb +3 -0
- data/vendor/extensions/archive/lib/tasks/archive_extension_tasks.rake +30 -3
- data/vendor/extensions/archive/radiant-archive-extension.gemspec +24 -0
- data/vendor/extensions/archive/spec/datasets/archive_dataset.rb +10 -6
- data/vendor/extensions/archive/spec/models/archive_day_index_page_spec.rb +13 -3
- data/vendor/extensions/archive/spec/models/archive_month_index_page_spec.rb +17 -3
- data/vendor/extensions/archive/spec/models/archive_page_spec.rb +31 -8
- data/vendor/extensions/archive/spec/models/archive_year_index_page_spec.rb +14 -3
- data/vendor/extensions/archive/spec/models/page_spec.rb +6 -0
- data/vendor/extensions/archive/tmp/cache/entity/d0/580097d24f3e7cfc7bf9706a0a3a3729a9de3e +6 -0
- data/vendor/extensions/archive/tmp/cache/meta/0e/da69d02186242cdfda62e46044566f2bc50f3a +0 -0
- data/vendor/extensions/assets/HELP_admin.markdown +69 -0
- data/vendor/extensions/assets/LICENSE +22 -0
- data/vendor/extensions/assets/README.md +230 -0
- data/vendor/extensions/assets/Rakefile +111 -0
- data/vendor/extensions/assets/VERSION +1 -0
- data/vendor/extensions/assets/app/controllers/admin/assets_controller.rb +54 -0
- data/vendor/extensions/assets/app/controllers/admin/page_attachments_controller.rb +45 -0
- data/vendor/extensions/assets/app/helpers/admin/assets_helper.rb +11 -0
- data/vendor/extensions/assets/app/models/asset.rb +161 -0
- data/vendor/extensions/assets/app/models/asset_tags.rb +378 -0
- data/vendor/extensions/assets/app/models/asset_type.rb +160 -0
- data/vendor/extensions/assets/app/models/old_page_attachment.rb +26 -0
- data/vendor/extensions/assets/app/models/page_attachment.rb +14 -0
- data/vendor/extensions/assets/app/views/admin/assets/_asset.html.haml +12 -0
- data/vendor/extensions/assets/app/views/admin/assets/_asset_table.html.haml +30 -0
- data/vendor/extensions/assets/app/views/admin/assets/_errors.html.haml +3 -0
- data/vendor/extensions/assets/app/views/admin/assets/_form.html.haml +20 -0
- data/vendor/extensions/assets/app/views/admin/assets/_page_assets.html.haml +12 -0
- data/vendor/extensions/assets/app/views/admin/assets/_search.html.haml +17 -0
- data/vendor/extensions/assets/app/views/admin/assets/_search_results.html.haml +17 -0
- data/vendor/extensions/assets/app/views/admin/assets/edit.html.haml +41 -0
- data/vendor/extensions/assets/app/views/admin/assets/index.html.haml +18 -0
- data/vendor/extensions/assets/app/views/admin/assets/new.html.haml +24 -0
- data/vendor/extensions/assets/app/views/admin/assets/remove.html.haml +16 -0
- data/vendor/extensions/assets/app/views/admin/configuration/_edit.html.haml +8 -0
- data/vendor/extensions/assets/app/views/admin/configuration/_show.html.haml +12 -0
- data/vendor/extensions/assets/app/views/admin/page_attachments/_attachment.html.haml +22 -0
- data/vendor/extensions/assets/app/views/admin/page_attachments/_new_attachment.html.haml +18 -0
- data/vendor/extensions/assets/app/views/admin/page_parts/_page_part.html.haml +20 -0
- data/vendor/extensions/assets/app/views/admin/pages/_asset_popups.html.haml +42 -0
- data/vendor/extensions/assets/app/views/admin/pages/_assets.html.haml +13 -0
- data/vendor/extensions/assets/app/views/admin/removed/_assets_bucket.html.haml +8 -0
- data/vendor/extensions/assets/app/views/admin/removed/_assets_container.html.haml +58 -0
- data/vendor/extensions/assets/app/views/admin/removed/_bucket.html.haml +11 -0
- data/vendor/extensions/assets/app/views/admin/removed/_bucket_asset.html.haml +9 -0
- data/vendor/extensions/assets/app/views/admin/removed/_show_bucket_link.html.haml +4 -0
- data/vendor/extensions/assets/app/views/admin/removed/_upload_to_page.html.haml +12 -0
- data/vendor/extensions/assets/app/views/admin/removed/bucket/_iframe.html.haml +1 -0
- data/vendor/extensions/assets/artwork/icons.png +0 -0
- data/vendor/extensions/assets/assets_extension.rb +86 -0
- data/vendor/extensions/assets/config/initializers/interpolation.rb +6 -0
- data/vendor/extensions/assets/config/initializers/radiant_config.rb +37 -0
- data/vendor/extensions/assets/config/locales/en.yml +105 -0
- data/vendor/extensions/assets/config/locales/nl.yml +105 -0
- data/vendor/extensions/assets/config/routes.rb +8 -0
- data/vendor/extensions/assets/db/migrate/001_create_assets.rb +12 -0
- data/vendor/extensions/assets/db/migrate/002_create_paperclip_attributes.rb +13 -0
- data/vendor/extensions/assets/db/migrate/003_create_user_observer.rb +13 -0
- data/vendor/extensions/assets/db/migrate/004_create_page_attachments.rb +19 -0
- data/vendor/extensions/assets/db/migrate/005_rename_users.rb +13 -0
- data/vendor/extensions/assets/db/migrate/20090316132151_disable_file_types.rb +20 -0
- data/vendor/extensions/assets/db/migrate/20110513205050_asset_uuid.rb +11 -0
- data/vendor/extensions/assets/lib/assets_admin_ui.rb +32 -0
- data/vendor/extensions/assets/lib/page_asset_associations.rb +13 -0
- data/vendor/extensions/assets/lib/paperclip/frame_grab.rb +39 -0
- data/vendor/extensions/assets/lib/tag_deprecation.rb +73 -0
- data/vendor/extensions/assets/lib/tasks/assets_extension_tasks.rake +123 -0
- data/vendor/extensions/assets/lib/tasks/paperclip_tasks.rake +79 -0
- data/vendor/extensions/assets/public/flash/ZeroClipboard.swf +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/add.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/archive_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/audio_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/audio_thumbnail.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/c_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/copy.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/css_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/database_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/delete.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/document_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/document_thumbnail.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/flash_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/flash_thumbnail.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/font_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/gzip_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/html_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/image_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/image_thumbnail.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/java_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/page_edit.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/perl_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/php_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/presentation_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/python_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/reorder_assets.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/ruby_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/script_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/spreadsheet_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/tar_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/unknown_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/unknown_thumbnail.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/video_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/video_thumbnail.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/xml_icon.png +0 -0
- data/vendor/extensions/assets/public/images/admin/assets/zip_icon.png +0 -0
- data/vendor/extensions/assets/public/javascripts/admin/assets.js +238 -0
- data/vendor/extensions/assets/public/stylesheets/sass/admin/assets.sass +203 -0
- data/vendor/extensions/assets/spec/controllers/admin/assets_controller_spec.rb +50 -0
- data/vendor/extensions/assets/spec/controllers/admin/page_attachment_controller_spec.rb +51 -0
- data/vendor/extensions/assets/spec/datasets/assets_dataset.rb +31 -0
- data/vendor/extensions/assets/spec/lib/asset_tags_spec.rb +9 -0
- data/vendor/extensions/assets/spec/lib/tag_deprecation_spec.rb +49 -0
- data/vendor/extensions/assets/spec/models/asset_spec.rb +71 -0
- data/vendor/extensions/assets/spec/models/asset_type_spec.rb +49 -0
- data/vendor/extensions/assets/spec/spec.opts +6 -0
- data/vendor/extensions/assets/spec/spec_helper.rb +36 -0
- data/vendor/extensions/assets/wireframes/edit-page-assets-2.bmml +453 -0
- data/vendor/extensions/assets/wireframes/edit-page-assets-2.png +0 -0
- data/vendor/extensions/assets/wireframes/edit-page-assets-3.bmml +454 -0
- data/vendor/extensions/assets/wireframes/edit-page-assets-3.png +0 -0
- data/vendor/extensions/assets/wireframes/edit-page-assets.bmml +433 -0
- data/vendor/extensions/assets/wireframes/edit-page-assets.png +0 -0
- data/vendor/extensions/assets/wireframes/edit-page.bmml +174 -0
- data/vendor/extensions/assets/wireframes/edit-page.png +0 -0
- data/vendor/extensions/debug/README +3 -0
- data/vendor/extensions/debug/Rakefile +136 -0
- data/{app → vendor/extensions/debug/app}/models/env_dump_page.rb +0 -0
- data/vendor/extensions/debug/config/locales/en.yml +3 -0
- data/vendor/extensions/debug/config/routes.rb +5 -0
- data/vendor/extensions/debug/debug_extension.rb +11 -0
- data/vendor/extensions/debug/lib/tasks/debug_extension_tasks.rake +55 -0
- data/{spec → vendor/extensions/debug/spec}/models/env_dump_page_spec.rb +0 -0
- data/vendor/extensions/debug/spec/spec.opts +6 -0
- data/vendor/extensions/debug/spec/spec_helper.rb +36 -0
- data/vendor/extensions/dutch_language_pack/config/locales/nl.yml +80 -29
- data/vendor/extensions/exporter/README +5 -0
- data/vendor/extensions/exporter/Rakefile +116 -0
- data/vendor/extensions/exporter/app/controllers/admin/export_controller.rb +5 -0
- data/vendor/extensions/exporter/app/models/radiant/exporter.rb +41 -0
- data/vendor/extensions/exporter/config/locales/en.yml +3 -0
- data/vendor/extensions/exporter/config/routes.rb +6 -0
- data/vendor/extensions/exporter/cucumber.yml +1 -0
- data/vendor/extensions/exporter/exporter_extension.rb +8 -0
- data/vendor/extensions/exporter/features/support/env.rb +16 -0
- data/vendor/extensions/exporter/features/support/paths.rb +14 -0
- data/vendor/extensions/exporter/lib/tasks/exporter_extension_tasks.rake +55 -0
- data/{spec → vendor/extensions/exporter/spec}/controllers/admin/export_controller_spec.rb +1 -1
- data/vendor/extensions/exporter/spec/models/radiant/exporter_spec.rb +29 -0
- data/vendor/extensions/exporter/spec/spec.opts +6 -0
- data/vendor/extensions/exporter/spec/spec_helper.rb +36 -0
- data/vendor/extensions/german_language_pack/config/locales/de.yml +52 -0
- data/vendor/extensions/japanese_language_pack/README +40 -1
- data/vendor/extensions/japanese_language_pack/config/locales/ja.yml +107 -71
- data/vendor/extensions/japanese_language_pack/config/locales/ja_available_tags.yml +327 -347
- data/vendor/extensions/japanese_language_pack/japanese_language_pack_extension.rb +3 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/CONTRIBUTERS +2 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/ChangeLog +1250 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/README +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/Rakefile +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/VERSION +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/bin/kramdown +5 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/data/kramdown/document.html +11 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/{default.less.css → default.scss.css} +18 -9
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/default.template +11 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/documentation.page +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/index.page +37 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/quickref.page +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/syntax.page +281 -187
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter.rb +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/html.rb +92 -90
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/kramdown.rb +421 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/latex.rb +311 -289
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/document.rb +10 -6
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/options.rb +29 -15
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/base.rb +0 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/html.rb +153 -41
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown.rb +21 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/abbreviation.rb +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/attribute_list.rb +20 -12
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/autolink.rb +11 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/block_boundary.rb +46 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/blockquote.rb +7 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/codeblock.rb +5 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/escaped_chars.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/extension.rb +23 -8
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/footnote.rb +3 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/header.rb +11 -11
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/html.rb +18 -16
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/html_entity.rb +2 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/link.rb +13 -10
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/list.rb +48 -37
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/math.rb +15 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/paragraph.rb +14 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/table.rb +17 -9
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/typographic_symbol.rb +4 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/utils.rb +37 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/utils/entities.rb +335 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/utils/html.rb +75 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/utils/ordered_hash.rb +79 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/version.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/man/man1/kramdown.1 +60 -36
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/run_tests.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/test_files.rb +66 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/02_eob/middle.html +0 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/atx_header.html +5 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/atx_header.text +3 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/setext_header.html +4 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/setext_header.html.19 +30 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/lazy.html +34 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/lazy.text +20 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/nested.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/nested.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/with_code_blocks.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/lazy.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/lazy.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/no_newline_at_end_1.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/no_newline_at_end_1.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/whitespace.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/with_ial.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/06_codeblock/with_ial.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/error.html.19 +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/normal.html +0 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/07_horizontal_rule/normal.text +0 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/item_ial.html +1 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/lazy.html +39 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/lazy.text +29 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/list_and_others.html +5 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/list_and_others.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/other_first_element.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/other_first_element.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/simple_ul.html +0 -13
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/simple_ul.text +0 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/special_cases.html +8 -31
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/special_cases.text +2 -15
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/comment.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/code.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/code.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/emphasis.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/emphasis.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_normal.html +2 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_simple.html +40 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_simple.text +42 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/typography.html.19 +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/invalid_html_1.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_raw.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_span.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/simple.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/simple.html.19 +64 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/simple.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/auto_id_and_ial.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/simple.html +4 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/comment.html +6 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/comment.text +2 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/ignored.html +5 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/ignored.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.html +5 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.kramdown +20 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.latex +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.text +11 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options.html +0 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options.text +0 -6
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/item_ial.html +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/item_ial.text +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/13_definition_list/simple.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/errors.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/errors.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/header.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/no_table.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/simple.html +78 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/14_table/simple.text +22 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/15_math/normal.html +11 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/15_math/normal.text +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/16_toc/no_toc_depth.html +33 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/16_toc/no_toc_depth.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/16_toc/no_toc_depth.text +16 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/16_toc/toc_depth_2.html +24 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/16_toc/toc_depth_2.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/16_toc/toc_depth_2.text +16 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/encoding.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/empty.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/empty.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/image_in_a.html +3 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/imagelinks.html +8 -6
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/imagelinks.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/inline.html +11 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/inline.html.19 +46 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/inline.text +11 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/link_defs.html +2 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/link_defs.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/reference.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/reference.html.19 +35 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/01_link/reference.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/highlighting.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/03_codespan/highlighting.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/definitions.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/definitions.latex +3 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/definitions.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/footnote_nr.latex +1 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/markers.latex +5 -14
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/markdown_attr.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/markdown_attr.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/normal.html +5 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/normal.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/escaped_chars/normal.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/escaped_chars/normal.text +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/comment.html +5 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/ignored.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/line_breaks/normal.latex +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_char.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_char.html.19 +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_char.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_char.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_input.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_input.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_as_input.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_numeric.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_numeric.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_numeric.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_symbolic.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_symbolic.options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/entities_symbolic.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.html.19 +18 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.text +1 -1
- data/vendor/extensions/russian_language_pack/README +3 -1
- data/vendor/extensions/russian_language_pack/config/locales/ru.yml +28 -19
- data/vendor/extensions/russian_language_pack/config/locales/ru_available_tags.yml +6 -8
- data/vendor/extensions/russian_language_pack/lib/tasks/i18n_ru_extension_tasks.rake +4 -4
- data/vendor/extensions/russian_language_pack/russian_language_pack_extension.rb +4 -4
- data/vendor/extensions/sheets/LICENSE +21 -0
- data/vendor/extensions/sheets/README.md +33 -0
- data/vendor/extensions/sheets/Rakefile +117 -0
- data/vendor/extensions/sheets/app/controllers/admin/scripts_controller.rb +13 -0
- data/vendor/extensions/sheets/app/controllers/admin/sheet_resource_controller.rb +54 -0
- data/vendor/extensions/sheets/app/controllers/admin/styles_controller.rb +13 -0
- data/vendor/extensions/sheets/app/helpers/admin/scripts_helper.rb +5 -0
- data/vendor/extensions/sheets/app/helpers/admin/styles_helper.rb +5 -0
- data/vendor/extensions/sheets/app/models/javascript_page.rb +16 -0
- data/vendor/extensions/sheets/app/models/sheet.rb +89 -0
- data/vendor/extensions/sheets/app/models/stylesheet_page.rb +16 -0
- data/vendor/extensions/sheets/app/views/admin/scripts/edit.html.haml +30 -0
- data/vendor/extensions/sheets/app/views/admin/scripts/index.html.haml +27 -0
- data/vendor/extensions/sheets/app/views/admin/scripts/new.html.haml +30 -0
- data/vendor/extensions/sheets/app/views/admin/sheets/_edit_scripts.html.haml +40 -0
- data/vendor/extensions/sheets/app/views/admin/sheets/_upload_script.html.haml +16 -0
- data/vendor/extensions/sheets/app/views/admin/styles/edit.html.haml +30 -0
- data/vendor/extensions/sheets/app/views/admin/styles/index.html.haml +31 -0
- data/vendor/extensions/sheets/app/views/admin/styles/new.html.haml +30 -0
- data/vendor/extensions/sheets/config/locales/en.yml +15 -0
- data/vendor/extensions/sheets/config/routes.rb +6 -0
- data/vendor/extensions/sheets/cucumber.yml +1 -0
- data/vendor/extensions/sheets/features/support/env.rb +16 -0
- data/vendor/extensions/sheets/features/support/paths.rb +14 -0
- data/vendor/extensions/sheets/lib/javascript_tags.rb +58 -0
- data/vendor/extensions/sheets/lib/radiant-sheets-extension.rb +2 -0
- data/vendor/extensions/sheets/lib/radiant-sheets-extension/version.rb +3 -0
- data/vendor/extensions/sheets/lib/sass_filter.rb +16 -0
- data/vendor/extensions/sheets/lib/stylesheet_tags.rb +61 -0
- data/vendor/extensions/sheets/lib/tasks/sheets_extension_tasks.rake +79 -0
- data/vendor/extensions/sheets/public/images/admin/javascript.png +0 -0
- data/vendor/extensions/sheets/public/images/admin/stylesheet.png +0 -0
- data/vendor/extensions/sheets/radiant-sheets-extension.gemspec +24 -0
- data/vendor/extensions/sheets/sass.html +82 -0
- data/vendor/extensions/sheets/sheets_extension.rb +88 -0
- data/vendor/extensions/sheets/spec/controllers/admin/scripts_controller_spec.rb +123 -0
- data/vendor/extensions/sheets/spec/controllers/admin/styles_controller_spec.rb +124 -0
- data/vendor/extensions/sheets/spec/datasets/javascripts_dataset.rb +10 -0
- data/vendor/extensions/sheets/spec/datasets/stylesheets_dataset.rb +15 -0
- data/vendor/extensions/sheets/spec/helpers/admin/scripts_helper_spec.rb +5 -0
- data/vendor/extensions/sheets/spec/helpers/admin/styles_helper_spec.rb +5 -0
- data/vendor/extensions/sheets/spec/lib/javascript_tags_spec.rb +36 -0
- data/vendor/extensions/sheets/spec/lib/stylesheet_tags_spec.rb +41 -0
- data/vendor/extensions/sheets/spec/models/javascript_page_spec.rb +80 -0
- data/vendor/extensions/sheets/spec/models/page_spec.rb +5 -0
- data/vendor/extensions/sheets/spec/models/stylesheet_page_spec.rb +80 -0
- data/vendor/extensions/sheets/spec/spec.opts +6 -0
- data/vendor/extensions/sheets/spec/spec_helper.rb +36 -0
- data/vendor/extensions/site_templates/README +3 -0
- data/vendor/extensions/site_templates/Rakefile +136 -0
- data/{db → vendor/extensions/site_templates/db}/templates/empty.yml +0 -0
- data/vendor/extensions/site_templates/db/templates/roasters.yml +7826 -0
- data/vendor/extensions/site_templates/db/templates/simple-blog.yml +251 -0
- data/vendor/extensions/site_templates/db/templates/styled-blog.yml +535 -0
- data/vendor/extensions/site_templates/lib/tasks/site_templates_extension_tasks.rake +55 -0
- data/vendor/extensions/site_templates/public/images/roasters/banner.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/closelabel.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/comment.png +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/gallery1.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/gallery2.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/gallery3.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/gallery4.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/gift.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/green.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/nav-background.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/nav-divider.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/nextlabel.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/open.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/preview-1.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/preview.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/prevlabel.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/prize.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/recycle.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/rss.gif +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/thumb-grinder.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/thumb-grower.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/thumb-roaster.jpg +0 -0
- data/vendor/extensions/site_templates/public/images/roasters/truck.gif +0 -0
- data/vendor/extensions/site_templates/site_templates_extension.rb +8 -0
- data/vendor/extensions/textile_filter/textile.html +2 -2
- data/vendor/plugins/dataset/lib/dataset.rb +2 -2
- data/vendor/plugins/dataset/plugit/descriptor.rb +25 -0
- data/vendor/plugins/haml/README.md +95 -154
- data/vendor/plugins/haml/Rakefile +104 -91
- data/vendor/plugins/haml/TODO +26 -20
- data/vendor/plugins/haml/VERSION +1 -1
- data/vendor/plugins/haml/VERSION_NAME +1 -1
- data/vendor/plugins/haml/bin/css2sass +7 -1
- data/vendor/plugins/haml/bin/sass-convert +7 -0
- data/vendor/plugins/haml/doc-src/FAQ.md +16 -4
- data/vendor/plugins/haml/doc-src/HAML_CHANGELOG.md +536 -1
- data/vendor/plugins/haml/doc-src/HAML_REFERENCE.md +176 -16
- data/vendor/plugins/haml/doc-src/INDENTED_SYNTAX.md +210 -0
- data/vendor/plugins/haml/doc-src/SASS_CHANGELOG.md +1159 -0
- data/vendor/plugins/haml/doc-src/SASS_REFERENCE.md +1163 -633
- data/vendor/plugins/haml/doc-src/SCSS_FOR_SASS_USERS.md +155 -0
- data/vendor/plugins/haml/ext/extconf.rb +10 -0
- data/vendor/plugins/haml/extra/haml-mode.el +36 -34
- data/vendor/plugins/haml/extra/sass-mode.el +10 -9
- data/vendor/plugins/haml/haml.gemspec +8 -33
- data/vendor/plugins/haml/init.rbc +404 -0
- data/vendor/plugins/haml/lib/haml.rb +5 -2
- data/vendor/plugins/haml/lib/haml.rbc +569 -0
- data/vendor/plugins/haml/lib/haml/buffer.rb +22 -4
- data/vendor/plugins/haml/lib/haml/buffer.rbc +4048 -0
- data/vendor/plugins/haml/lib/haml/engine.rb +13 -4
- data/vendor/plugins/haml/lib/haml/engine.rbc +3852 -0
- data/vendor/plugins/haml/lib/haml/error.rbc +339 -0
- data/vendor/plugins/haml/lib/haml/exec.rb +456 -64
- data/vendor/plugins/haml/lib/haml/filters.rb +19 -1
- data/vendor/plugins/haml/lib/haml/filters.rbc +5617 -0
- data/vendor/plugins/haml/lib/haml/helpers.rb +40 -19
- data/vendor/plugins/haml/lib/haml/helpers.rbc +7086 -0
- data/vendor/plugins/haml/lib/haml/helpers/action_view_extensions.rbc +522 -0
- data/vendor/plugins/haml/lib/haml/helpers/action_view_mods.rb +38 -12
- data/vendor/plugins/haml/lib/haml/helpers/action_view_mods.rbc +5515 -0
- data/vendor/plugins/haml/lib/haml/helpers/xss_mods.rb +13 -2
- data/vendor/plugins/haml/lib/haml/html.rb +209 -49
- data/vendor/plugins/haml/lib/haml/html/erb.rb +141 -0
- data/vendor/plugins/haml/lib/haml/precompiler.rb +130 -89
- data/vendor/plugins/haml/lib/haml/precompiler.rbc +22247 -0
- data/vendor/plugins/haml/lib/haml/railtie.rb +16 -13
- data/vendor/plugins/haml/lib/haml/railtie.rbc +409 -0
- data/vendor/plugins/haml/lib/haml/root.rb +7 -0
- data/vendor/plugins/haml/lib/haml/root.rbc +160 -0
- data/vendor/plugins/haml/lib/haml/shared.rbc +1137 -0
- data/vendor/plugins/haml/lib/haml/template.rb +13 -12
- data/vendor/plugins/haml/lib/haml/template.rbc +1838 -0
- data/vendor/plugins/haml/lib/haml/template/options.rb +16 -0
- data/vendor/plugins/haml/lib/haml/template/options.rbc +235 -0
- data/vendor/plugins/haml/lib/haml/template/plugin.rb +18 -6
- data/vendor/plugins/haml/lib/haml/template/plugin.rbc +2720 -0
- data/vendor/plugins/haml/lib/haml/util.rb +483 -44
- data/vendor/plugins/haml/lib/haml/util.rbc +12059 -0
- data/vendor/plugins/haml/lib/haml/util/subset_map.rb +101 -0
- data/vendor/plugins/haml/lib/haml/util/subset_map.rbc +1316 -0
- data/vendor/plugins/haml/lib/haml/version.rb +25 -2
- data/vendor/plugins/haml/lib/haml/version.rbc +1671 -0
- data/vendor/plugins/haml/lib/sass.rb +7 -2
- data/vendor/plugins/haml/lib/sass.rbc +492 -0
- data/vendor/plugins/haml/lib/sass/callbacks.rb +52 -0
- data/vendor/plugins/haml/lib/sass/callbacks.rbc +388 -0
- data/vendor/plugins/haml/lib/sass/css.rb +86 -196
- data/vendor/plugins/haml/lib/sass/engine.rb +304 -99
- data/vendor/plugins/haml/lib/sass/engine.rbc +17020 -0
- data/vendor/plugins/haml/lib/sass/environment.rb +67 -3
- data/vendor/plugins/haml/lib/sass/environment.rbc +1751 -0
- data/vendor/plugins/haml/lib/sass/error.rb +166 -25
- data/vendor/plugins/haml/lib/sass/error.rbc +2801 -0
- data/vendor/plugins/haml/lib/sass/files.rb +43 -38
- data/vendor/plugins/haml/lib/sass/files.rbc +3118 -0
- data/vendor/plugins/haml/lib/sass/less.rb +382 -0
- data/vendor/plugins/haml/lib/sass/plugin.rb +198 -150
- data/vendor/plugins/haml/lib/sass/plugin.rbc +4356 -0
- data/vendor/plugins/haml/lib/sass/plugin/configuration.rb +221 -0
- data/vendor/plugins/haml/lib/sass/plugin/configuration.rbc +1343 -0
- data/vendor/plugins/haml/lib/sass/plugin/generic.rb +15 -0
- data/vendor/plugins/haml/lib/sass/plugin/merb.rb +8 -20
- data/vendor/plugins/haml/lib/sass/plugin/rack.rb +2 -20
- data/vendor/plugins/haml/lib/sass/plugin/rack.rbc +446 -0
- data/vendor/plugins/haml/lib/sass/plugin/rails.rb +16 -9
- data/vendor/plugins/haml/lib/sass/plugin/rails.rbc +879 -0
- data/vendor/plugins/haml/lib/sass/plugin/staleness_checker.rb +123 -0
- data/vendor/plugins/haml/lib/sass/plugin/staleness_checker.rbc +2019 -0
- data/vendor/plugins/haml/lib/sass/repl.rb +1 -1
- data/vendor/plugins/haml/lib/sass/script.rb +32 -31
- data/vendor/plugins/haml/lib/sass/script.rbc +1188 -0
- data/vendor/plugins/haml/lib/sass/script/bool.rb +2 -1
- data/vendor/plugins/haml/lib/sass/script/bool.rbc +366 -0
- data/vendor/plugins/haml/lib/sass/script/color.rb +295 -26
- data/vendor/plugins/haml/lib/sass/script/color.rbc +8148 -0
- data/vendor/plugins/haml/lib/sass/script/css_lexer.rb +29 -0
- data/vendor/plugins/haml/lib/sass/script/css_lexer.rbc +809 -0
- data/vendor/plugins/haml/lib/sass/script/css_parser.rb +31 -0
- data/vendor/plugins/haml/lib/sass/script/css_parser.rbc +628 -0
- data/vendor/plugins/haml/lib/sass/script/funcall.rb +33 -6
- data/vendor/plugins/haml/lib/sass/script/funcall.rbc +1805 -0
- data/vendor/plugins/haml/lib/sass/script/functions.rb +637 -33
- data/vendor/plugins/haml/lib/sass/script/functions.rbc +8418 -0
- data/vendor/plugins/haml/lib/sass/script/interpolation.rb +70 -0
- data/vendor/plugins/haml/lib/sass/script/interpolation.rbc +1225 -0
- data/vendor/plugins/haml/lib/sass/script/lexer.rb +200 -57
- data/vendor/plugins/haml/lib/sass/script/lexer.rbc +7231 -0
- data/vendor/plugins/haml/lib/sass/script/literal.rb +69 -10
- data/vendor/plugins/haml/lib/sass/script/literal.rbc +3365 -0
- data/vendor/plugins/haml/lib/sass/script/node.rb +99 -1
- data/vendor/plugins/haml/lib/sass/script/node.rbc +1418 -0
- data/vendor/plugins/haml/lib/sass/script/number.rb +64 -24
- data/vendor/plugins/haml/lib/sass/script/number.rbc +6024 -0
- data/vendor/plugins/haml/lib/sass/script/operation.rb +53 -3
- data/vendor/plugins/haml/lib/sass/script/operation.rbc +1856 -0
- data/vendor/plugins/haml/lib/sass/script/parser.rb +229 -50
- data/vendor/plugins/haml/lib/sass/script/parser.rbc +8418 -0
- data/vendor/plugins/haml/lib/sass/script/string.rb +57 -2
- data/vendor/plugins/haml/lib/sass/script/string.rbc +1357 -0
- data/vendor/plugins/haml/lib/sass/script/string_interpolation.rb +93 -0
- data/vendor/plugins/haml/lib/sass/script/string_interpolation.rbc +1643 -0
- data/vendor/plugins/haml/lib/sass/script/unary_operation.rb +25 -2
- data/vendor/plugins/haml/lib/sass/script/unary_operation.rbc +1144 -0
- data/vendor/plugins/haml/lib/sass/script/variable.rb +22 -5
- data/vendor/plugins/haml/lib/sass/script/variable.rbc +844 -0
- data/vendor/plugins/haml/lib/sass/scss.rb +17 -0
- data/vendor/plugins/haml/lib/sass/scss.rbc +242 -0
- data/vendor/plugins/haml/lib/sass/scss/css_parser.rb +46 -0
- data/vendor/plugins/haml/lib/sass/scss/css_parser.rbc +1106 -0
- data/vendor/plugins/haml/lib/sass/scss/parser.rb +846 -0
- data/vendor/plugins/haml/lib/sass/scss/parser.rbc +19348 -0
- data/vendor/plugins/haml/lib/sass/scss/rx.rb +126 -0
- data/vendor/plugins/haml/lib/sass/scss/rx.rbc +2849 -0
- data/vendor/plugins/haml/lib/sass/scss/sass_parser.rb +11 -0
- data/vendor/plugins/haml/lib/sass/scss/sass_parser.rbc +287 -0
- data/vendor/plugins/haml/lib/sass/scss/script_lexer.rb +15 -0
- data/vendor/plugins/haml/lib/sass/scss/script_lexer.rbc +439 -0
- data/vendor/plugins/haml/lib/sass/scss/script_parser.rb +25 -0
- data/vendor/plugins/haml/lib/sass/scss/script_parser.rbc +482 -0
- data/vendor/plugins/haml/lib/sass/scss/static_parser.rb +40 -0
- data/vendor/plugins/haml/lib/sass/scss/static_parser.rbc +971 -0
- data/vendor/plugins/haml/lib/sass/selector.rb +361 -0
- data/vendor/plugins/haml/lib/sass/selector.rbc +4193 -0
- data/vendor/plugins/haml/lib/sass/selector/abstract_sequence.rb +62 -0
- data/vendor/plugins/haml/lib/sass/selector/abstract_sequence.rbc +798 -0
- data/vendor/plugins/haml/lib/sass/selector/comma_sequence.rb +82 -0
- data/vendor/plugins/haml/lib/sass/selector/comma_sequence.rbc +1814 -0
- data/vendor/plugins/haml/lib/sass/selector/sequence.rb +237 -0
- data/vendor/plugins/haml/lib/sass/selector/sequence.rbc +4928 -0
- data/vendor/plugins/haml/lib/sass/selector/simple.rb +113 -0
- data/vendor/plugins/haml/lib/sass/selector/simple.rbc +1553 -0
- data/vendor/plugins/haml/lib/sass/selector/simple_sequence.rb +136 -0
- data/vendor/plugins/haml/lib/sass/selector/simple_sequence.rbc +2346 -0
- data/vendor/plugins/haml/lib/sass/tree/charset_node.rb +37 -0
- data/vendor/plugins/haml/lib/sass/tree/charset_node.rbc +606 -0
- data/vendor/plugins/haml/lib/sass/tree/comment_node.rb +71 -27
- data/vendor/plugins/haml/lib/sass/tree/comment_node.rbc +2397 -0
- data/vendor/plugins/haml/lib/sass/tree/debug_node.rb +8 -2
- data/vendor/plugins/haml/lib/sass/tree/debug_node.rbc +740 -0
- data/vendor/plugins/haml/lib/sass/tree/directive_node.rb +44 -37
- data/vendor/plugins/haml/lib/sass/tree/directive_node.rbc +1302 -0
- data/vendor/plugins/haml/lib/sass/tree/extend_node.rb +65 -0
- data/vendor/plugins/haml/lib/sass/tree/extend_node.rbc +1276 -0
- data/vendor/plugins/haml/lib/sass/tree/for_node.rb +19 -0
- data/vendor/plugins/haml/lib/sass/tree/for_node.rbc +1145 -0
- data/vendor/plugins/haml/lib/sass/tree/if_node.rb +26 -0
- data/vendor/plugins/haml/lib/sass/tree/if_node.rbc +1119 -0
- data/vendor/plugins/haml/lib/sass/tree/import_node.rb +64 -27
- data/vendor/plugins/haml/lib/sass/tree/import_node.rbc +2242 -0
- data/vendor/plugins/haml/lib/sass/tree/mixin_def_node.rb +31 -0
- data/vendor/plugins/haml/lib/sass/tree/mixin_def_node.rbc +1001 -0
- data/vendor/plugins/haml/lib/sass/tree/mixin_node.rb +82 -7
- data/vendor/plugins/haml/lib/sass/tree/mixin_node.rbc +3355 -0
- data/vendor/plugins/haml/lib/sass/tree/node.rb +291 -77
- data/vendor/plugins/haml/lib/sass/tree/node.rbc +5533 -0
- data/vendor/plugins/haml/lib/sass/tree/prop_node.rb +157 -58
- data/vendor/plugins/haml/lib/sass/tree/prop_node.rbc +3949 -0
- data/vendor/plugins/haml/lib/sass/tree/root_node.rb +157 -0
- data/vendor/plugins/haml/lib/sass/tree/root_node.rbc +3112 -0
- data/vendor/plugins/haml/lib/sass/tree/rule_node.rb +178 -137
- data/vendor/plugins/haml/lib/sass/tree/rule_node.rbc +5636 -0
- data/vendor/plugins/haml/lib/sass/tree/variable_node.rb +10 -5
- data/vendor/plugins/haml/lib/sass/tree/variable_node.rbc +845 -0
- data/vendor/plugins/haml/lib/sass/tree/warn_node.rb +42 -0
- data/vendor/plugins/haml/lib/sass/tree/warn_node.rbc +1043 -0
- data/vendor/plugins/haml/lib/sass/tree/while_node.rb +17 -0
- data/vendor/plugins/haml/lib/sass/tree/while_node.rbc +722 -0
- data/vendor/plugins/haml/test/benchmark.rb +5 -5
- data/vendor/plugins/haml/test/haml/engine_test.rb +530 -19
- data/vendor/plugins/haml/test/haml/{rhtml/_av_partial_1.rhtml → erb/_av_partial_1.erb} +1 -1
- data/vendor/plugins/haml/test/haml/{rhtml/_av_partial_2.rhtml → erb/_av_partial_2.erb} +1 -1
- data/vendor/plugins/haml/test/haml/{rhtml/action_view.rhtml → erb/action_view.erb} +1 -1
- data/vendor/plugins/haml/test/haml/{rhtml/standard.rhtml → erb/standard.erb} +0 -0
- data/vendor/plugins/haml/test/haml/helper_test.rb +124 -7
- data/vendor/plugins/haml/test/haml/html2haml/erb_tests.rb +426 -0
- data/vendor/plugins/haml/test/haml/html2haml_test.rb +250 -66
- data/vendor/plugins/haml/test/haml/results/filters.xhtml +1 -1
- data/vendor/plugins/haml/test/haml/results/helpers.xhtml +0 -23
- data/vendor/plugins/haml/test/haml/results/just_stuff.xhtml +2 -0
- data/vendor/plugins/haml/test/haml/spec/LICENSE +14 -0
- data/vendor/plugins/haml/test/haml/spec/README.md +106 -0
- data/vendor/plugins/haml/test/haml/spec/lua_haml_spec.lua +38 -0
- data/vendor/plugins/haml/test/haml/spec/perl_haml_test.pl +81 -0
- data/vendor/plugins/haml/test/haml/spec/ruby_haml_test.rb +19 -0
- data/vendor/plugins/haml/test/haml/spec/tests.json +603 -0
- data/vendor/plugins/haml/test/haml/spec_test.rb +44 -0
- data/vendor/plugins/haml/test/haml/template_test.rb +33 -3
- data/vendor/plugins/haml/test/haml/templates/helpers.haml +0 -66
- data/vendor/plugins/haml/test/haml/templates/just_stuff.haml +2 -0
- data/vendor/plugins/haml/test/haml/util/subset_map_test.rb +91 -0
- data/vendor/plugins/haml/test/haml/util_test.rb +161 -0
- data/vendor/plugins/haml/test/linked_rails.rb +22 -1
- data/vendor/plugins/haml/test/sass/callbacks_test.rb +61 -0
- data/vendor/plugins/haml/test/sass/conversion_test.rb +1218 -0
- data/vendor/plugins/haml/test/sass/css2sass_test.rb +130 -18
- data/vendor/plugins/haml/test/sass/data/hsl-rgb.txt +319 -0
- data/vendor/plugins/haml/test/sass/engine_test.rb +1427 -139
- data/vendor/plugins/haml/test/sass/extend_test.rb +1348 -0
- data/vendor/plugins/haml/test/sass/functions_test.rb +429 -47
- data/vendor/plugins/haml/test/sass/less_conversion_test.rb +653 -0
- data/vendor/plugins/haml/test/sass/more_results/more_import.css +1 -1
- data/vendor/plugins/haml/test/sass/more_templates/more_import.sass +3 -3
- data/vendor/plugins/haml/test/sass/plugin_test.rb +246 -56
- data/vendor/plugins/haml/test/sass/results/compact.css +1 -1
- data/vendor/plugins/haml/test/sass/results/complex.css +5 -6
- data/vendor/plugins/haml/test/sass/results/compressed.css +1 -1
- data/vendor/plugins/haml/test/sass/results/expanded.css +1 -1
- data/vendor/plugins/haml/test/sass/results/import.css +3 -1
- data/vendor/plugins/haml/test/sass/results/import_charset.css +4 -0
- data/vendor/plugins/haml/test/sass/results/import_charset_1_8.css +4 -0
- data/vendor/plugins/haml/test/sass/results/import_charset_ibm866.css +4 -0
- data/vendor/plugins/haml/test/sass/results/mixins.css +12 -12
- data/vendor/plugins/haml/test/sass/results/nested.css +1 -1
- data/vendor/plugins/haml/test/sass/results/options.css +1 -0
- data/vendor/plugins/haml/test/sass/results/parent_ref.css +4 -4
- data/vendor/plugins/haml/test/sass/results/script.css +4 -4
- data/vendor/plugins/haml/test/sass/results/scss_import.css +31 -0
- data/vendor/plugins/haml/test/sass/results/scss_importee.css +2 -0
- data/vendor/plugins/haml/test/sass/results/warn.css +0 -0
- data/vendor/plugins/haml/test/sass/results/warn_imported.css +0 -0
- data/vendor/plugins/haml/test/sass/script_conversion_test.rb +314 -0
- data/vendor/plugins/haml/test/sass/script_test.rb +281 -78
- data/vendor/plugins/haml/test/sass/scss/css_test.rb +916 -0
- data/vendor/plugins/haml/test/sass/scss/rx_test.rb +156 -0
- data/vendor/plugins/haml/test/sass/scss/scss_test.rb +1088 -0
- data/vendor/plugins/haml/test/sass/scss/test_helper.rb +37 -0
- data/vendor/plugins/haml/test/sass/templates/_imported_charset_ibm866.sass +4 -0
- data/vendor/plugins/haml/test/sass/templates/_imported_charset_utf8.sass +4 -0
- data/vendor/plugins/haml/test/sass/templates/alt.sass +2 -2
- data/vendor/plugins/haml/test/sass/templates/basic.sass +1 -1
- data/vendor/plugins/haml/test/sass/templates/bork1.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/bork3.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/bork4.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/complex.sass +0 -2
- data/vendor/plugins/haml/test/sass/templates/import.sass +5 -4
- data/vendor/plugins/haml/test/sass/templates/import_charset.sass +7 -0
- data/vendor/plugins/haml/test/sass/templates/import_charset_1_8.sass +4 -0
- data/vendor/plugins/haml/test/sass/templates/import_charset_ibm866.sass +9 -0
- data/vendor/plugins/haml/test/sass/templates/importee.less +2 -0
- data/vendor/plugins/haml/test/sass/templates/importee.sass +3 -3
- data/vendor/plugins/haml/test/sass/templates/line_numbers.sass +1 -1
- data/vendor/plugins/haml/test/sass/templates/mixin_bork.sass +5 -0
- data/vendor/plugins/haml/test/sass/templates/mixins.sass +2 -2
- data/vendor/plugins/haml/test/sass/templates/nested_bork1.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/nested_bork2.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/nested_bork3.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/nested_bork4.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/nested_mixin_bork.sass +6 -0
- data/vendor/plugins/haml/test/sass/templates/options.sass +2 -0
- data/vendor/plugins/haml/test/sass/templates/parent_ref.sass +2 -2
- data/vendor/plugins/haml/test/sass/templates/script.sass +69 -69
- data/vendor/plugins/haml/test/sass/templates/scss_import.scss +11 -0
- data/vendor/plugins/haml/test/sass/templates/scss_importee.scss +1 -0
- data/vendor/plugins/haml/test/sass/templates/units.sass +10 -10
- data/vendor/plugins/haml/test/sass/templates/warn.sass +3 -0
- data/vendor/plugins/haml/test/sass/templates/warn_imported.sass +4 -0
- data/vendor/plugins/haml/test/test_helper.rb +52 -4
- data/vendor/plugins/haml/vendor/fssm/LICENSE +20 -0
- data/vendor/plugins/haml/vendor/fssm/README.markdown +55 -0
- data/vendor/plugins/haml/vendor/fssm/Rakefile +59 -0
- data/vendor/plugins/haml/vendor/fssm/VERSION.yml +5 -0
- data/vendor/plugins/haml/vendor/fssm/example.rb +9 -0
- data/vendor/plugins/haml/vendor/fssm/fssm.gemspec +77 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm.rb +33 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/backends/fsevents.rb +36 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/backends/inotify.rb +26 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/backends/polling.rb +25 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/backends/rubycocoa/fsevents.rb +131 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/monitor.rb +26 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/path.rb +91 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/pathname.rb +502 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/state/directory.rb +57 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/state/file.rb +24 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/support.rb +63 -0
- data/vendor/plugins/haml/vendor/fssm/lib/fssm/tree.rb +176 -0
- data/vendor/plugins/haml/vendor/fssm/profile/prof-cache.rb +40 -0
- data/vendor/plugins/haml/vendor/fssm/profile/prof-fssm-pathname.html +1231 -0
- data/vendor/plugins/haml/vendor/fssm/profile/prof-pathname.rb +68 -0
- data/vendor/plugins/haml/vendor/fssm/profile/prof-plain-pathname.html +988 -0
- data/vendor/plugins/haml/vendor/fssm/profile/prof.html +2379 -0
- data/vendor/plugins/haml/vendor/fssm/spec/path_spec.rb +75 -0
- data/vendor/plugins/haml/vendor/fssm/spec/root/duck/quack.txt +0 -0
- data/vendor/plugins/haml/vendor/fssm/spec/root/file.css +0 -0
- data/vendor/plugins/haml/vendor/fssm/spec/root/file.rb +0 -0
- data/vendor/plugins/haml/vendor/fssm/spec/root/file.yml +0 -0
- data/vendor/plugins/haml/vendor/fssm/spec/root/moo/cow.txt +0 -0
- data/vendor/plugins/haml/vendor/fssm/spec/spec_helper.rb +14 -0
- data/vendor/plugins/haml/yard/callbacks.rb +29 -0
- data/vendor/plugins/haml/yard/default/fulldoc/html/css/common.sass +5 -1
- data/vendor/rails/Rakefile +83 -0
- data/vendor/rails/actionmailer/CHANGELOG +3 -4
- data/vendor/rails/actionmailer/Rakefile +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer/base.rb +34 -1
- data/vendor/rails/actionmailer/lib/action_mailer/helpers.rb +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer/version.rb +1 -1
- data/vendor/rails/actionmailer/test/fixtures/test_mailer/implicitly_multipart_example.rhtml.bak +1 -0
- data/vendor/rails/actionmailer/test/fixtures/test_mailer/implicitly_multipart_example.text.html.erb~ +10 -0
- data/vendor/rails/actionpack/CHANGELOG +11 -0
- data/vendor/rails/actionpack/Rakefile +1 -1
- data/vendor/rails/actionpack/lib/action_controller/base.rb +4 -2
- data/vendor/rails/actionpack/lib/action_controller/caching/fragments.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/cookies.rb +8 -2
- data/vendor/rails/actionpack/lib/action_controller/integration.rb +19 -7
- data/vendor/rails/actionpack/lib/action_controller/request.rb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/request_forgery_protection.rb +9 -6
- data/vendor/rails/actionpack/lib/action_controller/rescue.rb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/resources.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/routing.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/routing/route.rb +3 -3
- data/vendor/rails/actionpack/lib/action_controller/session/abstract_store.rb +143 -55
- data/vendor/rails/actionpack/lib/action_controller/session/cookie_store.rb +48 -35
- data/vendor/rails/actionpack/lib/action_controller/session/mem_cache_store.rb +10 -1
- data/vendor/rails/actionpack/lib/action_controller/test_process.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/url_rewriter.rb +11 -1
- data/vendor/rails/actionpack/lib/action_pack/version.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers.rb +2 -0
- data/vendor/rails/actionpack/lib/action_view/helpers/asset_tag_helper.rb +1 -0
- data/vendor/rails/actionpack/lib/action_view/helpers/csrf_helper.rb +14 -0
- data/vendor/rails/actionpack/lib/action_view/helpers/form_helper.rb +21 -14
- 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 +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/prototype_helper.rb +3 -3
- data/vendor/rails/actionpack/lib/action_view/helpers/text_helper.rb +27 -17
- data/vendor/rails/actionpack/lib/action_view/helpers/url_helper.rb +2 -1
- data/vendor/rails/actionpack/lib/action_view/locale/en.yml +14 -14
- data/vendor/rails/actionpack/lib/action_view/renderable_partial.rb +7 -1
- data/vendor/rails/actionpack/lib/action_view/template.rb +2 -2
- data/vendor/rails/actionpack/test/abstract_unit.rb +17 -0
- data/vendor/rails/actionpack/test/activerecord/active_record_store_test.rb +65 -18
- data/vendor/rails/actionpack/test/controller/cookie_test.rb +38 -0
- data/vendor/rails/actionpack/test/controller/integration_test.rb +44 -0
- data/vendor/rails/actionpack/test/controller/reloader_test.rb +1 -0
- data/vendor/rails/actionpack/test/controller/render_test.rb +12 -0
- data/vendor/rails/actionpack/test/controller/request/multipart_params_parsing_test.rb +15 -0
- data/vendor/rails/actionpack/test/controller/request_forgery_protection_test.rb +92 -124
- data/vendor/rails/actionpack/test/controller/rescue_test.rb +5 -6
- data/vendor/rails/actionpack/test/controller/session/cookie_store_test.rb +101 -7
- data/vendor/rails/actionpack/test/controller/session/mem_cache_store_test.rb +71 -11
- data/vendor/rails/actionpack/test/controller/url_rewriter_test.rb +9 -3
- data/vendor/rails/actionpack/test/fixtures/session_autoload_test/session_autoload_test/foo.rb +10 -0
- data/vendor/rails/actionpack/test/fixtures/test/hello_world.erb~ +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/malformed/malformed.en.html.erb~ +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/malformed/malformed.erb~ +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/malformed/malformed.html.erb~ +1 -0
- data/vendor/rails/actionpack/test/template/form_options_helper_test.rb +4 -0
- data/vendor/rails/actionpack/test/template/text_helper_test.rb +47 -18
- data/vendor/rails/actionpack/test/template/url_helper_test.rb +4 -4
- 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 +5 -2
- data/vendor/rails/activerecord/MIT-LICENSE +20 -0
- data/vendor/rails/activerecord/Rakefile +1 -1
- data/vendor/rails/activerecord/examples/performance.rb +39 -3
- data/vendor/rails/activerecord/lib/active_record/association_preload.rb +12 -2
- data/vendor/rails/activerecord/lib/active_record/associations.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/associations/association_collection.rb +60 -6
- data/vendor/rails/activerecord/lib/active_record/attribute_methods.rb +0 -4
- data/vendor/rails/activerecord/lib/active_record/autosave_association.rb +2 -2
- data/vendor/rails/activerecord/lib/active_record/base.rb +28 -16
- data/vendor/rails/activerecord/lib/active_record/calculations.rb +19 -12
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/connection_specification.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb +3 -1
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb +6 -0
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb +2 -0
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb +2 -1
- data/vendor/rails/activerecord/lib/active_record/dirty.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/locale/en.yml +11 -11
- data/vendor/rails/activerecord/lib/active_record/locking/optimistic.rb +1 -0
- data/vendor/rails/activerecord/lib/active_record/migration.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/named_scope.rb +15 -10
- data/vendor/rails/activerecord/lib/active_record/serialization.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/session_store.rb +9 -1
- data/vendor/rails/activerecord/lib/active_record/validations.rb +12 -12
- data/vendor/rails/activerecord/lib/active_record/version.rb +1 -1
- data/vendor/rails/activerecord/test/cases/adapter_test.rb +7 -8
- data/vendor/rails/activerecord/test/cases/associations/eager_load_nested_include_test.rb +7 -7
- data/vendor/rails/activerecord/test/cases/associations/eager_load_nested_polymorphic_include.rb +19 -0
- data/vendor/rails/activerecord/test/cases/associations/eager_test.rb +12 -0
- data/vendor/rails/activerecord/test/cases/associations/has_and_belongs_to_many_associations_test.rb +5 -0
- data/vendor/rails/activerecord/test/cases/associations/has_many_associations_test.rb +108 -4
- data/vendor/rails/activerecord/test/cases/associations/has_many_through_associations_test.rb +14 -0
- data/vendor/rails/activerecord/test/cases/associations_test.rb +10 -0
- data/vendor/rails/activerecord/test/cases/base_test.rb +35 -75
- data/vendor/rails/activerecord/test/cases/calculations_test.rb +13 -0
- data/vendor/rails/activerecord/test/cases/connection_test_mysql.rb +1 -0
- data/vendor/rails/activerecord/test/cases/counter_cache_test.rb +84 -0
- data/vendor/rails/activerecord/test/cases/locking_test.rb +2 -1
- data/vendor/rails/activerecord/test/cases/migration_test.rb +11 -0
- data/vendor/rails/activerecord/test/cases/named_scope_test.rb +12 -1
- data/vendor/rails/activerecord/test/cases/nested_attributes_test.rb +28 -1
- data/vendor/rails/activerecord/test/cases/reflection_test.rb +5 -5
- data/vendor/rails/activerecord/test/cases/sp_test_mysql.rb +16 -0
- data/vendor/rails/activerecord/test/cases/transactions_test.rb +22 -1
- data/vendor/rails/activerecord/test/cases/validations_i18n_test.rb +12 -12
- data/vendor/rails/activerecord/test/cases/validations_test.rb +42 -30
- data/vendor/rails/activerecord/test/fixtures/polymorphic_designs.yml +19 -0
- data/vendor/rails/activerecord/test/fixtures/polymorphic_prices.yml +19 -0
- data/vendor/rails/activerecord/test/fixtures/tees.yml +4 -0
- data/vendor/rails/activerecord/test/fixtures/ties.yml +4 -0
- data/vendor/rails/activerecord/test/models/author.rb +2 -0
- data/vendor/rails/activerecord/test/models/company.rb +2 -0
- data/vendor/rails/activerecord/test/models/event_author.rb +3 -0
- data/vendor/rails/activerecord/test/models/pirate.rb +2 -2
- data/vendor/rails/activerecord/test/models/polymorphic_design.rb +3 -0
- data/vendor/rails/activerecord/test/models/polymorphic_price.rb +3 -0
- data/vendor/rails/activerecord/test/models/post.rb +2 -0
- data/vendor/rails/activerecord/test/models/tee.rb +4 -0
- data/vendor/rails/activerecord/test/models/tie.rb +4 -0
- data/vendor/rails/activerecord/test/schema/mysql_specific_schema.rb +7 -0
- data/vendor/rails/activerecord/test/schema/schema.rb +16 -0
- data/vendor/rails/activeresource/CHANGELOG +3 -4
- data/vendor/rails/activeresource/MIT-LICENSE +20 -0
- data/vendor/rails/activeresource/Rakefile +1 -1
- data/vendor/rails/activeresource/lib/active_resource/http_mock.rb +104 -9
- data/vendor/rails/activeresource/lib/active_resource/version.rb +1 -1
- data/vendor/rails/activeresource/test/http_mock_test.rb +155 -0
- data/vendor/rails/activesupport/CHANGELOG +16 -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/basic_object.rb +7 -10
- data/vendor/rails/activesupport/lib/active_support/buffered_logger.rb +2 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/array/grouping.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/array/random_access.rb +24 -4
- data/vendor/rails/activesupport/lib/active_support/core_ext/class.rb +1 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/class/attribute.rb +67 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/enumerable.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/kernel/singleton_class.rb +13 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/module/remove_method.rb +6 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/object/misc.rb +3 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/range/blockless_step.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/string/output_safety.rb +0 -11
- data/vendor/rails/activesupport/lib/active_support/dependencies.rb +38 -12
- data/vendor/rails/activesupport/lib/active_support/deprecation.rb +7 -0
- data/vendor/rails/activesupport/lib/active_support/json/backends/yajl.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/locale/en.yml +4 -1
- data/vendor/rails/activesupport/lib/active_support/memoizable.rb +2 -0
- data/vendor/rails/activesupport/lib/active_support/ordered_hash.rb +6 -0
- data/vendor/rails/activesupport/lib/active_support/testing/performance.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/testing/setup_and_teardown.rb +2 -2
- data/vendor/rails/activesupport/lib/active_support/values/time_zone.rb +5 -1
- data/vendor/rails/activesupport/lib/active_support/vendor.rb +2 -2
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n.rb +92 -105
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend.rb +5 -4
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/backend/active_record.rb +61 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/active_record/missing.rb +4 -6
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/active_record/store_procs.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/active_record/translation.rb +8 -3
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/base.rb +55 -84
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/cache.rb +1 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/cascade.rb +0 -1
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/chain.rb +3 -1
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/cldr.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/fallbacks.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/backend/flatten.rb +113 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/gettext.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/interpolation_compiler.rb +8 -4
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/backend/key_value.rb +102 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/backend/memoize.rb +48 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/metadata.rb +5 -13
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/backend/pluralization.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/backend/simple.rb +87 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/backend/transliterator.rb +98 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/config.rb +84 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/core_ext/hash.rb +28 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/core_ext/string/interpolate.rb +3 -4
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/exceptions.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/gettext.rb +2 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7/i18n/helpers/gettext.rb → i18n-0.4.1/i18n/gettext/helpers.rb} +2 -2
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/gettext/po_parser.rb +7 -7
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/locale.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/locale/fallbacks.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/locale/tag.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/locale/tag/parents.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/locale/tag/rfc4646.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.3.7 → i18n-0.4.1}/i18n/locale/tag/simple.rb +0 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.4.1/i18n/version.rb +3 -0
- data/vendor/rails/activesupport/lib/active_support/version.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/whiny_nil.rb +1 -1
- data/vendor/rails/activesupport/test/abstract_unit.rb +37 -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 +355 -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 +394 -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 +21 -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 +38 -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 +286 -0
- data/vendor/rails/activesupport/test/core_ext/date_time_ext_test.rb +363 -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 +102 -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 +1016 -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 +39 -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 +86 -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 +168 -0
- data/vendor/rails/activesupport/test/core_ext/object_and_class_ext_test.rb +294 -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 +402 -0
- data/vendor/rails/activesupport/test/core_ext/symbol_test.rb +9 -0
- data/vendor/rails/activesupport/test/core_ext/time_ext_test.rb +771 -0
- data/vendor/rails/activesupport/test/core_ext/time_with_zone_test.rb +851 -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 +789 -0
- data/vendor/rails/activesupport/test/deprecation/proxy_wrappers_test.rb +22 -0
- data/vendor/rails/activesupport/test/deprecation_test.rb +167 -0
- data/vendor/rails/activesupport/test/empty_bool.rb +7 -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 +262 -0
- data/vendor/rails/activesupport/test/json/decoding_test.rb +79 -0
- data/vendor/rails/activesupport/test/json/encoding_test.rb +162 -0
- data/vendor/rails/activesupport/test/memoizable_test.rb +261 -0
- data/vendor/rails/activesupport/test/message_encryptor_test.rb +55 -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 +237 -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/safe_buffer_test.rb +36 -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_case_test.rb +57 -0
- data/vendor/rails/activesupport/test/test_test.rb +188 -0
- data/vendor/rails/activesupport/test/time_zone_test.rb +285 -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/libxml_engine_test.rb +204 -0
- data/vendor/rails/activesupport/test/xml_mini/libxmlsax_engine_test.rb +181 -0
- data/vendor/rails/activesupport/test/xml_mini/nokogiri_engine_test.rb +204 -0
- data/vendor/rails/activesupport/test/xml_mini/nokogirisax_engine_test.rb +217 -0
- data/vendor/rails/activesupport/test/xml_mini/rexml_engine_test.rb +15 -0
- data/vendor/rails/railties/CHANGELOG +7 -2
- data/vendor/rails/railties/Rakefile +6 -7
- data/vendor/rails/railties/builtin/rails_info/rails/info.rb +1 -1
- data/vendor/rails/railties/environments/boot.rb +6 -2
- data/vendor/rails/railties/environments/environment.rb +1 -1
- data/vendor/rails/railties/guides/rails_guides.rb +13 -24
- data/vendor/rails/railties/guides/rails_guides/generator.rb +169 -49
- data/vendor/rails/railties/guides/rails_guides/indexer.rb +24 -11
- data/vendor/rails/railties/guides/rails_guides/levenshtein.rb +31 -0
- data/vendor/rails/railties/guides/source/action_mailer_basics.textile +29 -12
- data/vendor/rails/railties/guides/source/{credits.erb.textile → credits.html.erb} +4 -4
- data/vendor/rails/railties/guides/source/{index.erb.textile → index.html.erb} +13 -12
- data/vendor/rails/railties/guides/source/plugins.textile +1 -1
- data/vendor/rails/railties/guides/source/security.textile +1 -1
- data/vendor/rails/railties/lib/initializer.rb +44 -20
- data/vendor/rails/railties/lib/rails/gem_dependency.rb +4 -2
- data/vendor/rails/railties/lib/rails/plugin.rb +1 -1
- data/vendor/rails/railties/lib/rails/plugin/loader.rb +3 -3
- data/vendor/rails/railties/lib/rails/vendor_gem_source_index.rb +2 -2
- data/vendor/rails/railties/lib/rails/version.rb +1 -1
- data/vendor/rails/railties/lib/rails_generator/generators/applications/app/scm/git.rb +18 -0
- data/vendor/rails/railties/lib/rails_generator/generators/components/migration/migration_generator.rb +1 -1
- data/vendor/rails/railties/lib/rails_generator/generators/components/plugin/templates/test_helper.rb +2 -1
- data/vendor/rails/railties/lib/tasks/databases.rake +9 -9
- data/vendor/rails/railties/lib/tasks/tmp.rake +37 -0
- 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/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 +9 -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 +227 -0
- data/vendor/rails/railties/test/generator_lookup_test.rb +40 -0
- data/vendor/rails/railties/test/generators/generated_attribute_test.rb +38 -0
- data/vendor/rails/railties/test/generators/generator_test_helper.rb +322 -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 +437 -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 +47 -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/railties/test/vendor/gems/dummy-gem-l-1.0.0-x86-mswin32/lib/dummy-gem-l.rb +1 -0
- metadata +1156 -125
- data/app/controllers/admin/export_controller.rb +0 -5
- data/app/helpers/admin/abstract_model_helper.rb +0 -2
- data/app/models/radiant/exporter.rb +0 -11
- data/db/templates/roasters.yml +0 -1210
- data/db/templates/simple-blog.yml +0 -197
- data/db/templates/styled-blog.yml +0 -472
- data/lib/radiant/legacy_routes.rb +0 -72
- data/public/images/admin/buttons_background.png +0 -0
- data/public/images/admin/login_shadow.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_shadow.png +0 -0
- data/public/images/admin/navigation_tabs.png +0 -0
- data/public/images/admin/new_homepage.png +0 -0
- data/public/images/admin/new_layout.png +0 -0
- data/public/images/admin/new_snippet.png +0 -0
- data/public/images/admin/new_user.png +0 -0
- data/public/images/admin/shadow.png +0 -0
- data/public/images/admin/shadow_grey.png +0 -0
- data/public/images/admin/spacer.gif +0 -0
- data/public/images/admin/vertical_tan_gradient.png +0 -0
- data/public/images/admin/view_site.png +0 -0
- data/public/stylesheets/sass/admin/modules/_grid.sass +0 -56
- data/public/stylesheets/sass/admin/modules/_opacity.sass +0 -7
- data/public/stylesheets/sass/admin/modules/_rounded.sass +0 -41
- data/public/stylesheets/sass/admin/modules/_shadow.sass +0 -9
- data/public/stylesheets/sass/admin/partials/_reset.sass +0 -36
- data/rerun.txt +0 -1
- data/spec/helpers/admin/abstract_model_helper_spec.rb +0 -4
- data/spec/lib/radiant/legacy_routes_spec.rb +0 -14
- data/spec/models/radiant/exporter_spec.rb +0 -25
- data/vendor/extensions/archive/test/fixtures/pages.yml +0 -397
- data/vendor/extensions/archive/test/functional/archive_extension_test.rb +0 -16
- data/vendor/extensions/archive/test/helpers/archive_index_test_helper.rb +0 -37
- data/vendor/extensions/archive/test/test_helper.rb +0 -26
- data/vendor/extensions/archive/test/unit/archive_day_index_page_test.rb +0 -22
- data/vendor/extensions/archive/test/unit/archive_month_index_page_test.rb +0 -22
- data/vendor/extensions/archive/test/unit/archive_page_test.rb +0 -40
- data/vendor/extensions/archive/test/unit/archive_year_index_page_test.rb +0 -22
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/only_first_quoted.html +0 -8
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/05_blockquote/only_first_quoted.text +0 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/filtered_html.html +0 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/filtered_html.options +0 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/filtered_html.text +0 -1
- data/vendor/plugins/haml/test/sass/templates/bork.sass +0 -2
- data/vendor/rails/activerecord/examples/performance.sql +0 -85
- data/vendor/rails/activerecord/test/cases/encoding_test.rb +0 -6
- 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 -80350
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/active_record.rb +0 -66
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/fast.rb +0 -69
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/helpers.rb +0 -68
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/links.rb +0 -34
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/simple.rb +0 -22
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/hash/except.rb +0 -8
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/hash/slice.rb +0 -8
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/object/meta_class.rb +0 -5
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/helpers.rb +0 -5
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/version.rb +0 -3
@@ -0,0 +1,22 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class DuplicableTest < Test::Unit::TestCase
|
4
|
+
NO = [nil, false, true, :symbol, 1, 2.3, BigDecimal.new('4.56'), Class.new]
|
5
|
+
YES = ['1', Object.new, /foo/, [], {}, Time.now]
|
6
|
+
|
7
|
+
def test_duplicable
|
8
|
+
NO.each do |v|
|
9
|
+
assert !v.duplicable?
|
10
|
+
begin
|
11
|
+
v.dup
|
12
|
+
fail
|
13
|
+
rescue Exception
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
YES.each do |v|
|
18
|
+
assert v.duplicable?
|
19
|
+
assert_nothing_raised { v.dup }
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
@@ -0,0 +1,121 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class DurationTest < ActiveSupport::TestCase
|
4
|
+
def test_inspect
|
5
|
+
assert_equal '0 seconds', 0.seconds.inspect
|
6
|
+
assert_equal '1 month', 1.month.inspect
|
7
|
+
assert_equal '1 month and 1 day', (1.month + 1.day).inspect
|
8
|
+
assert_equal '6 months and -2 days', (6.months - 2.days).inspect
|
9
|
+
assert_equal '10 seconds', 10.seconds.inspect
|
10
|
+
assert_equal '10 years, 2 months, and 1 day', (10.years + 2.months + 1.day).inspect
|
11
|
+
assert_equal '7 days', 1.week.inspect
|
12
|
+
assert_equal '14 days', 1.fortnight.inspect
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_minus_with_duration_does_not_break_subtraction_of_date_from_date
|
16
|
+
assert_nothing_raised { Date.today - Date.today }
|
17
|
+
end
|
18
|
+
|
19
|
+
def test_plus_with_time
|
20
|
+
assert_equal 1 + 1.second, 1.second + 1, "Duration + Numeric should == Numeric + Duration"
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_argument_error
|
24
|
+
begin
|
25
|
+
1.second.ago('')
|
26
|
+
flunk("no exception was raised")
|
27
|
+
rescue ArgumentError => e
|
28
|
+
assert_equal 'expected a time or date, got ""', e.message, "ensure ArgumentError is not being raised by dependencies.rb"
|
29
|
+
rescue Exception
|
30
|
+
flunk("ArgumentError should be raised, but we got #{$!.class} instead")
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def test_fractional_weeks
|
35
|
+
assert_equal((86400 * 7) * 1.5, 1.5.weeks)
|
36
|
+
assert_equal((86400 * 7) * 1.7, 1.7.weeks)
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_fractional_days
|
40
|
+
assert_equal 86400 * 1.5, 1.5.days
|
41
|
+
assert_equal 86400 * 1.7, 1.7.days
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_since_and_ago_with_fractional_days
|
45
|
+
t = Time.local(2000)
|
46
|
+
# since
|
47
|
+
assert_equal 36.hours.since(t), 1.5.days.since(t)
|
48
|
+
assert_in_delta((24 * 1.7).hours.since(t), 1.7.days.since(t), 1)
|
49
|
+
# ago
|
50
|
+
assert_equal 36.hours.ago(t), 1.5.days.ago(t)
|
51
|
+
assert_in_delta((24 * 1.7).hours.ago(t), 1.7.days.ago(t), 1)
|
52
|
+
end
|
53
|
+
|
54
|
+
def test_since_and_ago_with_fractional_weeks
|
55
|
+
t = Time.local(2000)
|
56
|
+
# since
|
57
|
+
assert_in_delta((7 * 36).hours.since, 1.5.weeks.since, 1)
|
58
|
+
assert_in_delta((7 * 24 * 1.7).hours.since, 1.7.weeks.since, 1)
|
59
|
+
# ago
|
60
|
+
assert_in_delta((7 * 36).hours.ago, 1.5.weeks.ago, 1)
|
61
|
+
assert_in_delta((7 * 24 * 1.7).hours.ago, 1.7.weeks.ago, 1)
|
62
|
+
end
|
63
|
+
|
64
|
+
def test_deprecated_fractional_years
|
65
|
+
years_re = /Fractional years are not respected\. Convert value to integer before calling #years\./
|
66
|
+
assert_deprecated(years_re){1.0.years}
|
67
|
+
assert_deprecated(years_re){1.5.years}
|
68
|
+
assert_not_deprecated{1.years}
|
69
|
+
assert_deprecated(years_re){1.0.year}
|
70
|
+
assert_deprecated(years_re){1.5.year}
|
71
|
+
assert_not_deprecated{1.year}
|
72
|
+
end
|
73
|
+
|
74
|
+
def test_deprecated_fractional_months
|
75
|
+
months_re = /Fractional months are not respected\. Convert value to integer before calling #months\./
|
76
|
+
assert_deprecated(months_re){1.5.months}
|
77
|
+
assert_deprecated(months_re){1.0.months}
|
78
|
+
assert_not_deprecated{1.months}
|
79
|
+
assert_deprecated(months_re){1.5.month}
|
80
|
+
assert_deprecated(months_re){1.0.month}
|
81
|
+
assert_not_deprecated{1.month}
|
82
|
+
end
|
83
|
+
|
84
|
+
def test_since_and_ago_anchored_to_time_now_when_time_zone_default_not_set
|
85
|
+
Time.zone_default = nil
|
86
|
+
with_env_tz 'US/Eastern' do
|
87
|
+
Time.stubs(:now).returns Time.local(2000)
|
88
|
+
# since
|
89
|
+
assert_equal false, 5.seconds.since.is_a?(ActiveSupport::TimeWithZone)
|
90
|
+
assert_equal Time.local(2000,1,1,0,0,5), 5.seconds.since
|
91
|
+
# ago
|
92
|
+
assert_equal false, 5.seconds.ago.is_a?(ActiveSupport::TimeWithZone)
|
93
|
+
assert_equal Time.local(1999,12,31,23,59,55), 5.seconds.ago
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
def test_since_and_ago_anchored_to_time_zone_now_when_time_zone_default_set
|
98
|
+
Time.zone_default = ActiveSupport::TimeZone['Eastern Time (US & Canada)']
|
99
|
+
with_env_tz 'US/Eastern' do
|
100
|
+
Time.stubs(:now).returns Time.local(2000)
|
101
|
+
# since
|
102
|
+
assert_equal true, 5.seconds.since.is_a?(ActiveSupport::TimeWithZone)
|
103
|
+
assert_equal Time.utc(2000,1,1,0,0,5), 5.seconds.since.time
|
104
|
+
assert_equal 'Eastern Time (US & Canada)', 5.seconds.since.time_zone.name
|
105
|
+
# ago
|
106
|
+
assert_equal true, 5.seconds.ago.is_a?(ActiveSupport::TimeWithZone)
|
107
|
+
assert_equal Time.utc(1999,12,31,23,59,55), 5.seconds.ago.time
|
108
|
+
assert_equal 'Eastern Time (US & Canada)', 5.seconds.ago.time_zone.name
|
109
|
+
end
|
110
|
+
ensure
|
111
|
+
Time.zone_default = nil
|
112
|
+
end
|
113
|
+
|
114
|
+
protected
|
115
|
+
def with_env_tz(new_tz = 'US/Eastern')
|
116
|
+
old_tz, ENV['TZ'] = ENV['TZ'], new_tz
|
117
|
+
yield
|
118
|
+
ensure
|
119
|
+
old_tz ? ENV['TZ'] = old_tz : ENV.delete('TZ')
|
120
|
+
end
|
121
|
+
end
|
@@ -0,0 +1,102 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
Payment = Struct.new(:price)
|
4
|
+
class SummablePayment < Payment
|
5
|
+
def +(p) self.class.new(price + p.price) end
|
6
|
+
end
|
7
|
+
|
8
|
+
class EnumerableTests < Test::Unit::TestCase
|
9
|
+
def test_group_by
|
10
|
+
names = %w(marcel sam david jeremy)
|
11
|
+
klass = Struct.new(:name)
|
12
|
+
objects = (1..50).inject([]) do |people,|
|
13
|
+
p = klass.new
|
14
|
+
p.name = names.sort_by { rand }.first
|
15
|
+
people << p
|
16
|
+
end
|
17
|
+
|
18
|
+
grouped = objects.group_by { |object| object.name }
|
19
|
+
|
20
|
+
grouped.each do |name, group|
|
21
|
+
assert group.all? { |person| person.name == name }
|
22
|
+
end
|
23
|
+
|
24
|
+
assert_equal objects.uniq.map(&:name), grouped.keys
|
25
|
+
assert({}.merge(grouped), "Could not convert ActiveSupport::OrderedHash into Hash")
|
26
|
+
end
|
27
|
+
|
28
|
+
def test_sums
|
29
|
+
assert_equal 30, [5, 15, 10].sum
|
30
|
+
assert_equal 30, [5, 15, 10].sum { |i| i }
|
31
|
+
|
32
|
+
assert_equal 'abc', %w(a b c).sum
|
33
|
+
assert_equal 'abc', %w(a b c).sum { |i| i }
|
34
|
+
|
35
|
+
payments = [ Payment.new(5), Payment.new(15), Payment.new(10) ]
|
36
|
+
assert_equal 30, payments.sum(&:price)
|
37
|
+
assert_equal 60, payments.sum { |p| p.price * 2 }
|
38
|
+
|
39
|
+
payments = [ SummablePayment.new(5), SummablePayment.new(15) ]
|
40
|
+
assert_equal SummablePayment.new(20), payments.sum
|
41
|
+
assert_equal SummablePayment.new(20), payments.sum { |p| p }
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_nil_sums
|
45
|
+
expected_raise = TypeError
|
46
|
+
|
47
|
+
assert_raise(expected_raise) { [5, 15, nil].sum }
|
48
|
+
|
49
|
+
payments = [ Payment.new(5), Payment.new(15), Payment.new(10), Payment.new(nil) ]
|
50
|
+
assert_raise(expected_raise) { payments.sum(&:price) }
|
51
|
+
|
52
|
+
assert_equal 60, payments.sum { |p| p.price.to_i * 2 }
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_empty_sums
|
56
|
+
assert_equal 0, [].sum
|
57
|
+
assert_equal 0, [].sum { |i| i }
|
58
|
+
assert_equal Payment.new(0), [].sum(Payment.new(0))
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_enumerable_sums
|
62
|
+
assert_equal 10, (1..4).sum
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_each_with_object
|
66
|
+
result = %w(foo bar).each_with_object({}) { |str, hsh| hsh[str] = str.upcase }
|
67
|
+
assert_equal({'foo' => 'FOO', 'bar' => 'BAR'}, result)
|
68
|
+
end
|
69
|
+
|
70
|
+
def test_index_by
|
71
|
+
payments = [ Payment.new(5), Payment.new(15), Payment.new(10) ]
|
72
|
+
assert_equal({ 5 => payments[0], 15 => payments[1], 10 => payments[2] },
|
73
|
+
payments.index_by { |p| p.price })
|
74
|
+
end
|
75
|
+
|
76
|
+
def test_many
|
77
|
+
assert ![].many?
|
78
|
+
assert ![ 1 ].many?
|
79
|
+
assert [ 1, 2 ].many?
|
80
|
+
|
81
|
+
assert ![].many? {|x| x > 1 }
|
82
|
+
assert ![ 2 ].many? {|x| x > 1 }
|
83
|
+
assert ![ 1, 2 ].many? {|x| x > 1 }
|
84
|
+
assert [ 1, 2, 2 ].many? {|x| x > 1 }
|
85
|
+
end
|
86
|
+
|
87
|
+
def test_none
|
88
|
+
assert [].none?
|
89
|
+
assert [nil, false].none?
|
90
|
+
assert ![1].none?
|
91
|
+
|
92
|
+
assert [].none? {|x| x > 1 }
|
93
|
+
assert ![ 2 ].none? {|x| x > 1 }
|
94
|
+
assert ![ 1, 2 ].none? {|x| x > 1 }
|
95
|
+
assert [ 1, 1 ].none? {|x| x > 1 }
|
96
|
+
end
|
97
|
+
|
98
|
+
def test_exclude?
|
99
|
+
assert [ 1 ].exclude?(2)
|
100
|
+
assert ![ 1 ].exclude?(1)
|
101
|
+
end
|
102
|
+
end
|
@@ -0,0 +1,68 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class ExceptionExtTests < Test::Unit::TestCase
|
4
|
+
|
5
|
+
def get_exception(cls = RuntimeError, msg = nil, trace = nil)
|
6
|
+
begin raise cls, msg, (trace || caller)
|
7
|
+
rescue Exception => e # passed Exception
|
8
|
+
return e
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
12
|
+
def setup
|
13
|
+
Exception::TraceSubstitutions.clear
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_clean_backtrace
|
17
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
18
|
+
e = get_exception RuntimeError, 'RAWR', ['bhal.rb', 'rawh hid den stuff is not here', 'almost all']
|
19
|
+
assert_kind_of Exception, e
|
20
|
+
assert_equal ['bhal.rb', 'rawh hid den stuff is not here', 'almost all'], e.clean_backtrace
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_app_backtrace
|
24
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
25
|
+
e = get_exception RuntimeError, 'RAWR', ['bhal.rb', ' vendor/file.rb some stuff', 'almost all']
|
26
|
+
assert_kind_of Exception, e
|
27
|
+
assert_equal ['bhal.rb', 'almost all'], e.application_backtrace
|
28
|
+
end
|
29
|
+
|
30
|
+
def test_app_backtrace_with_before
|
31
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
32
|
+
e = get_exception RuntimeError, 'RAWR', ['vendor/file.rb some stuff', 'bhal.rb', ' vendor/file.rb some stuff', 'almost all']
|
33
|
+
assert_kind_of Exception, e
|
34
|
+
assert_equal ['vendor/file.rb some stuff', 'bhal.rb', 'almost all'], e.application_backtrace
|
35
|
+
end
|
36
|
+
|
37
|
+
def test_framework_backtrace_with_before
|
38
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
39
|
+
e = get_exception RuntimeError, 'RAWR', ['vendor/file.rb some stuff', 'bhal.rb', ' vendor/file.rb some stuff', 'almost all']
|
40
|
+
assert_kind_of Exception, e
|
41
|
+
assert_equal ['vendor/file.rb some stuff', ' vendor/file.rb some stuff'], e.framework_backtrace
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_backtrace_should_clean_paths
|
45
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
46
|
+
e = get_exception RuntimeError, 'RAWR', ['a/b/c/../d/../../../bhal.rb', 'rawh hid den stuff is not here', 'almost all']
|
47
|
+
assert_kind_of Exception, e
|
48
|
+
assert_equal ['bhal.rb', 'rawh hid den stuff is not here', 'almost all'], e.clean_backtrace
|
49
|
+
end
|
50
|
+
|
51
|
+
def test_clean_message_should_clean_paths
|
52
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
53
|
+
e = get_exception RuntimeError, "I dislike a/z/x/../../b/y/../c", ['a/b/c/../d/../../../bhal.rb', 'rawh hid den stuff is not here', 'almost all']
|
54
|
+
assert_kind_of Exception, e
|
55
|
+
assert_equal "I dislike a/b/c", e.clean_message
|
56
|
+
end
|
57
|
+
|
58
|
+
def test_app_trace_should_be_empty_when_no_app_frames
|
59
|
+
Exception::TraceSubstitutions << [/\s*hidden.*/, '']
|
60
|
+
e = get_exception RuntimeError, 'RAWR', ['vendor/file.rb some stuff', 'generated/bhal.rb', ' vendor/file.rb some stuff', 'generated/almost all']
|
61
|
+
assert_kind_of Exception, e
|
62
|
+
assert_equal [], e.application_backtrace
|
63
|
+
end
|
64
|
+
|
65
|
+
def test_frozen_error
|
66
|
+
assert_raise(ActiveSupport::FrozenObjectError) { "foo".freeze.gsub!(/oo/,'aa') }
|
67
|
+
end
|
68
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class AtomicWriteTest < Test::Unit::TestCase
|
4
|
+
def test_atomic_write_without_errors
|
5
|
+
contents = "Atomic Text"
|
6
|
+
File.atomic_write(file_name, Dir.pwd) do |file|
|
7
|
+
file.write(contents)
|
8
|
+
assert !File.exist?(file_name)
|
9
|
+
end
|
10
|
+
assert File.exist?(file_name)
|
11
|
+
assert_equal contents, File.read(file_name)
|
12
|
+
ensure
|
13
|
+
File.unlink(file_name) rescue nil
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_atomic_write_doesnt_write_when_block_raises
|
17
|
+
File.atomic_write(file_name) do |file|
|
18
|
+
file.write("testing")
|
19
|
+
raise "something bad"
|
20
|
+
end
|
21
|
+
rescue
|
22
|
+
assert !File.exist?(file_name)
|
23
|
+
end
|
24
|
+
|
25
|
+
def test_atomic_write_preserves_file_permissions
|
26
|
+
contents = "Atomic Text"
|
27
|
+
File.open(file_name, "w", 0755) do |file|
|
28
|
+
file.write(contents)
|
29
|
+
assert File.exist?(file_name)
|
30
|
+
end
|
31
|
+
assert File.exist?(file_name)
|
32
|
+
assert_equal 0100755, file_mode
|
33
|
+
assert_equal contents, File.read(file_name)
|
34
|
+
|
35
|
+
File.atomic_write(file_name, Dir.pwd) do |file|
|
36
|
+
file.write(contents)
|
37
|
+
assert File.exist?(file_name)
|
38
|
+
end
|
39
|
+
assert File.exist?(file_name)
|
40
|
+
assert_equal 0100755, file_mode
|
41
|
+
assert_equal contents, File.read(file_name)
|
42
|
+
ensure
|
43
|
+
File.unlink(file_name) rescue nil
|
44
|
+
end
|
45
|
+
|
46
|
+
def test_atomic_write_preserves_default_file_permissions
|
47
|
+
contents = "Atomic Text"
|
48
|
+
File.atomic_write(file_name, Dir.pwd) do |file|
|
49
|
+
file.write(contents)
|
50
|
+
assert !File.exist?(file_name)
|
51
|
+
end
|
52
|
+
assert File.exist?(file_name)
|
53
|
+
assert_equal 0100666 ^ File.umask, file_mode
|
54
|
+
assert_equal contents, File.read(file_name)
|
55
|
+
ensure
|
56
|
+
File.unlink(file_name) rescue nil
|
57
|
+
end
|
58
|
+
|
59
|
+
private
|
60
|
+
def file_name
|
61
|
+
"atomic.file"
|
62
|
+
end
|
63
|
+
|
64
|
+
def file_mode
|
65
|
+
File.stat(file_name).mode
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
|
3
|
+
class FloatExtRoundingTests < Test::Unit::TestCase
|
4
|
+
def test_round_for_positive_number
|
5
|
+
assert_equal 1, 1.4.round
|
6
|
+
assert_equal 2, 1.6.round
|
7
|
+
assert_equal 2, 1.6.round(0)
|
8
|
+
assert_equal 1.4, 1.4.round(1)
|
9
|
+
assert_equal 1.4, 1.4.round(3)
|
10
|
+
assert_equal 1.5, 1.45.round(1)
|
11
|
+
assert_equal 1.45, 1.445.round(2)
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_round_for_negative_number
|
15
|
+
assert_equal( -1, -1.4.round )
|
16
|
+
assert_equal( -2, -1.6.round )
|
17
|
+
assert_equal( -1.4, -1.4.round(1) )
|
18
|
+
assert_equal( -1.5, -1.45.round(1) )
|
19
|
+
end
|
20
|
+
|
21
|
+
def test_round_with_negative_precision
|
22
|
+
assert_equal 123460.0, 123456.0.round(-1)
|
23
|
+
assert_equal 123500.0, 123456.0.round(-2)
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,1016 @@
|
|
1
|
+
require 'abstract_unit'
|
2
|
+
require 'builder'
|
3
|
+
|
4
|
+
class HashExtTest < Test::Unit::TestCase
|
5
|
+
def setup
|
6
|
+
@strings = { 'a' => 1, 'b' => 2 }
|
7
|
+
@symbols = { :a => 1, :b => 2 }
|
8
|
+
@mixed = { :a => 1, 'b' => 2 }
|
9
|
+
@fixnums = { 0 => 1, 1 => 2 }
|
10
|
+
if RUBY_VERSION < '1.9.0'
|
11
|
+
@illegal_symbols = { "\0" => 1, "" => 2, [] => 3 }
|
12
|
+
else
|
13
|
+
@illegal_symbols = { [] => 3 }
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
def test_methods
|
18
|
+
h = {}
|
19
|
+
assert_respond_to h, :symbolize_keys
|
20
|
+
assert_respond_to h, :symbolize_keys!
|
21
|
+
assert_respond_to h, :stringify_keys
|
22
|
+
assert_respond_to h, :stringify_keys!
|
23
|
+
assert_respond_to h, :to_options
|
24
|
+
assert_respond_to h, :to_options!
|
25
|
+
end
|
26
|
+
|
27
|
+
def test_symbolize_keys
|
28
|
+
assert_equal @symbols, @symbols.symbolize_keys
|
29
|
+
assert_equal @symbols, @strings.symbolize_keys
|
30
|
+
assert_equal @symbols, @mixed.symbolize_keys
|
31
|
+
end
|
32
|
+
|
33
|
+
def test_symbolize_keys!
|
34
|
+
assert_equal @symbols, @symbols.dup.symbolize_keys!
|
35
|
+
assert_equal @symbols, @strings.dup.symbolize_keys!
|
36
|
+
assert_equal @symbols, @mixed.dup.symbolize_keys!
|
37
|
+
end
|
38
|
+
|
39
|
+
def test_symbolize_keys_preserves_keys_that_cant_be_symbolized
|
40
|
+
assert_equal @illegal_symbols, @illegal_symbols.symbolize_keys
|
41
|
+
assert_equal @illegal_symbols, @illegal_symbols.dup.symbolize_keys!
|
42
|
+
end
|
43
|
+
|
44
|
+
def test_symbolize_keys_preserves_fixnum_keys
|
45
|
+
assert_equal @fixnums, @fixnums.symbolize_keys
|
46
|
+
assert_equal @fixnums, @fixnums.dup.symbolize_keys!
|
47
|
+
end
|
48
|
+
|
49
|
+
def test_stringify_keys
|
50
|
+
assert_equal @strings, @symbols.stringify_keys
|
51
|
+
assert_equal @strings, @strings.stringify_keys
|
52
|
+
assert_equal @strings, @mixed.stringify_keys
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_stringify_keys!
|
56
|
+
assert_equal @strings, @symbols.dup.stringify_keys!
|
57
|
+
assert_equal @strings, @strings.dup.stringify_keys!
|
58
|
+
assert_equal @strings, @mixed.dup.stringify_keys!
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_indifferent_assorted
|
62
|
+
@strings = @strings.with_indifferent_access
|
63
|
+
@symbols = @symbols.with_indifferent_access
|
64
|
+
@mixed = @mixed.with_indifferent_access
|
65
|
+
|
66
|
+
assert_equal 'a', @strings.__send__(:convert_key, :a)
|
67
|
+
|
68
|
+
assert_equal 1, @strings.fetch('a')
|
69
|
+
assert_equal 1, @strings.fetch(:a.to_s)
|
70
|
+
assert_equal 1, @strings.fetch(:a)
|
71
|
+
|
72
|
+
hashes = { :@strings => @strings, :@symbols => @symbols, :@mixed => @mixed }
|
73
|
+
method_map = { :'[]' => 1, :fetch => 1, :values_at => [1],
|
74
|
+
:has_key? => true, :include? => true, :key? => true,
|
75
|
+
:member? => true }
|
76
|
+
|
77
|
+
hashes.each do |name, hash|
|
78
|
+
method_map.sort_by { |m| m.to_s }.each do |meth, expected|
|
79
|
+
assert_equal(expected, hash.__send__(meth, 'a'),
|
80
|
+
"Calling #{name}.#{meth} 'a'")
|
81
|
+
assert_equal(expected, hash.__send__(meth, :a),
|
82
|
+
"Calling #{name}.#{meth} :a")
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
assert_equal [1, 2], @strings.values_at('a', 'b')
|
87
|
+
assert_equal [1, 2], @strings.values_at(:a, :b)
|
88
|
+
assert_equal [1, 2], @symbols.values_at('a', 'b')
|
89
|
+
assert_equal [1, 2], @symbols.values_at(:a, :b)
|
90
|
+
assert_equal [1, 2], @mixed.values_at('a', 'b')
|
91
|
+
assert_equal [1, 2], @mixed.values_at(:a, :b)
|
92
|
+
end
|
93
|
+
|
94
|
+
def test_indifferent_reading
|
95
|
+
hash = HashWithIndifferentAccess.new
|
96
|
+
hash["a"] = 1
|
97
|
+
hash["b"] = true
|
98
|
+
hash["c"] = false
|
99
|
+
hash["d"] = nil
|
100
|
+
|
101
|
+
assert_equal 1, hash[:a]
|
102
|
+
assert_equal true, hash[:b]
|
103
|
+
assert_equal false, hash[:c]
|
104
|
+
assert_equal nil, hash[:d]
|
105
|
+
assert_equal nil, hash[:e]
|
106
|
+
end
|
107
|
+
|
108
|
+
def test_indifferent_reading_with_nonnil_default
|
109
|
+
hash = HashWithIndifferentAccess.new(1)
|
110
|
+
hash["a"] = 1
|
111
|
+
hash["b"] = true
|
112
|
+
hash["c"] = false
|
113
|
+
hash["d"] = nil
|
114
|
+
|
115
|
+
assert_equal 1, hash[:a]
|
116
|
+
assert_equal true, hash[:b]
|
117
|
+
assert_equal false, hash[:c]
|
118
|
+
assert_equal nil, hash[:d]
|
119
|
+
assert_equal 1, hash[:e]
|
120
|
+
end
|
121
|
+
|
122
|
+
def test_indifferent_writing
|
123
|
+
hash = HashWithIndifferentAccess.new
|
124
|
+
hash[:a] = 1
|
125
|
+
hash['b'] = 2
|
126
|
+
hash[3] = 3
|
127
|
+
|
128
|
+
assert_equal hash['a'], 1
|
129
|
+
assert_equal hash['b'], 2
|
130
|
+
assert_equal hash[:a], 1
|
131
|
+
assert_equal hash[:b], 2
|
132
|
+
assert_equal hash[3], 3
|
133
|
+
end
|
134
|
+
|
135
|
+
def test_indifferent_update
|
136
|
+
hash = HashWithIndifferentAccess.new
|
137
|
+
hash[:a] = 'a'
|
138
|
+
hash['b'] = 'b'
|
139
|
+
|
140
|
+
updated_with_strings = hash.update(@strings)
|
141
|
+
updated_with_symbols = hash.update(@symbols)
|
142
|
+
updated_with_mixed = hash.update(@mixed)
|
143
|
+
|
144
|
+
assert_equal updated_with_strings[:a], 1
|
145
|
+
assert_equal updated_with_strings['a'], 1
|
146
|
+
assert_equal updated_with_strings['b'], 2
|
147
|
+
|
148
|
+
assert_equal updated_with_symbols[:a], 1
|
149
|
+
assert_equal updated_with_symbols['b'], 2
|
150
|
+
assert_equal updated_with_symbols[:b], 2
|
151
|
+
|
152
|
+
assert_equal updated_with_mixed[:a], 1
|
153
|
+
assert_equal updated_with_mixed['b'], 2
|
154
|
+
|
155
|
+
assert [updated_with_strings, updated_with_symbols, updated_with_mixed].all? { |h| h.keys.size == 2 }
|
156
|
+
end
|
157
|
+
|
158
|
+
def test_indifferent_merging
|
159
|
+
hash = HashWithIndifferentAccess.new
|
160
|
+
hash[:a] = 'failure'
|
161
|
+
hash['b'] = 'failure'
|
162
|
+
|
163
|
+
other = { 'a' => 1, :b => 2 }
|
164
|
+
|
165
|
+
merged = hash.merge(other)
|
166
|
+
|
167
|
+
assert_equal HashWithIndifferentAccess, merged.class
|
168
|
+
assert_equal 1, merged[:a]
|
169
|
+
assert_equal 2, merged['b']
|
170
|
+
|
171
|
+
hash.update(other)
|
172
|
+
|
173
|
+
assert_equal 1, hash[:a]
|
174
|
+
assert_equal 2, hash['b']
|
175
|
+
end
|
176
|
+
|
177
|
+
def test_indifferent_reverse_merging
|
178
|
+
hash = HashWithIndifferentAccess.new('some' => 'value', 'other' => 'value')
|
179
|
+
hash.reverse_merge!(:some => 'noclobber', :another => 'clobber')
|
180
|
+
assert_equal 'value', hash[:some]
|
181
|
+
assert_equal 'clobber', hash[:another]
|
182
|
+
end
|
183
|
+
|
184
|
+
def test_indifferent_deleting
|
185
|
+
get_hash = proc{ { :a => 'foo' }.with_indifferent_access }
|
186
|
+
hash = get_hash.call
|
187
|
+
assert_equal hash.delete(:a), 'foo'
|
188
|
+
assert_equal hash.delete(:a), nil
|
189
|
+
hash = get_hash.call
|
190
|
+
assert_equal hash.delete('a'), 'foo'
|
191
|
+
assert_equal hash.delete('a'), nil
|
192
|
+
end
|
193
|
+
|
194
|
+
def test_indifferent_to_hash
|
195
|
+
# Should convert to a Hash with String keys.
|
196
|
+
assert_equal @strings, @mixed.with_indifferent_access.to_hash
|
197
|
+
|
198
|
+
# Should preserve the default value.
|
199
|
+
mixed_with_default = @mixed.dup
|
200
|
+
mixed_with_default.default = '1234'
|
201
|
+
roundtrip = mixed_with_default.with_indifferent_access.to_hash
|
202
|
+
assert_equal @strings, roundtrip
|
203
|
+
assert_equal '1234', roundtrip.default
|
204
|
+
end
|
205
|
+
|
206
|
+
def test_indifferent_hash_with_array_of_hashes
|
207
|
+
hash = { "urls" => { "url" => [ { "address" => "1" }, { "address" => "2" } ] }}.with_indifferent_access
|
208
|
+
assert_equal "1", hash[:urls][:url].first[:address]
|
209
|
+
end
|
210
|
+
|
211
|
+
def test_stringify_and_symbolize_keys_on_indifferent_preserves_hash
|
212
|
+
h = HashWithIndifferentAccess.new
|
213
|
+
h[:first] = 1
|
214
|
+
h.stringify_keys!
|
215
|
+
assert_equal 1, h['first']
|
216
|
+
h = HashWithIndifferentAccess.new
|
217
|
+
h['first'] = 1
|
218
|
+
h.symbolize_keys!
|
219
|
+
assert_equal 1, h[:first]
|
220
|
+
end
|
221
|
+
|
222
|
+
def test_to_options_on_indifferent_preserves_hash
|
223
|
+
h = HashWithIndifferentAccess.new
|
224
|
+
h['first'] = 1
|
225
|
+
h.to_options!
|
226
|
+
assert_equal 1, h['first']
|
227
|
+
end
|
228
|
+
|
229
|
+
|
230
|
+
def test_indifferent_subhashes
|
231
|
+
h = {'user' => {'id' => 5}}.with_indifferent_access
|
232
|
+
['user', :user].each {|user| [:id, 'id'].each {|id| assert_equal 5, h[user][id], "h[#{user.inspect}][#{id.inspect}] should be 5"}}
|
233
|
+
|
234
|
+
h = {:user => {:id => 5}}.with_indifferent_access
|
235
|
+
['user', :user].each {|user| [:id, 'id'].each {|id| assert_equal 5, h[user][id], "h[#{user.inspect}][#{id.inspect}] should be 5"}}
|
236
|
+
end
|
237
|
+
|
238
|
+
def test_assert_valid_keys
|
239
|
+
assert_nothing_raised do
|
240
|
+
{ :failure => "stuff", :funny => "business" }.assert_valid_keys([ :failure, :funny ])
|
241
|
+
{ :failure => "stuff", :funny => "business" }.assert_valid_keys(:failure, :funny)
|
242
|
+
end
|
243
|
+
|
244
|
+
assert_raise(ArgumentError, "Unknown key(s): failore") do
|
245
|
+
{ :failore => "stuff", :funny => "business" }.assert_valid_keys([ :failure, :funny ])
|
246
|
+
{ :failore => "stuff", :funny => "business" }.assert_valid_keys(:failure, :funny)
|
247
|
+
end
|
248
|
+
end
|
249
|
+
|
250
|
+
def test_assorted_keys_not_stringified
|
251
|
+
original = {Object.new => 2, 1 => 2, [] => true}
|
252
|
+
indiff = original.with_indifferent_access
|
253
|
+
assert(!indiff.keys.any? {|k| k.kind_of? String}, "A key was converted to a string!")
|
254
|
+
end
|
255
|
+
|
256
|
+
def test_deep_merge
|
257
|
+
hash_1 = { :a => "a", :b => "b", :c => { :c1 => "c1", :c2 => "c2", :c3 => { :d1 => "d1" } } }
|
258
|
+
hash_2 = { :a => 1, :c => { :c1 => 2, :c3 => { :d2 => "d2" } } }
|
259
|
+
expected = { :a => 1, :b => "b", :c => { :c1 => 2, :c2 => "c2", :c3 => { :d1 => "d1", :d2 => "d2" } } }
|
260
|
+
assert_equal expected, hash_1.deep_merge(hash_2)
|
261
|
+
|
262
|
+
hash_1.deep_merge!(hash_2)
|
263
|
+
assert_equal expected, hash_1
|
264
|
+
end
|
265
|
+
|
266
|
+
def test_reverse_merge
|
267
|
+
defaults = { :a => "x", :b => "y", :c => 10 }.freeze
|
268
|
+
options = { :a => 1, :b => 2 }
|
269
|
+
expected = { :a => 1, :b => 2, :c => 10 }
|
270
|
+
|
271
|
+
# Should merge defaults into options, creating a new hash.
|
272
|
+
assert_equal expected, options.reverse_merge(defaults)
|
273
|
+
assert_not_equal expected, options
|
274
|
+
|
275
|
+
# Should merge! defaults into options, replacing options.
|
276
|
+
merged = options.dup
|
277
|
+
assert_equal expected, merged.reverse_merge!(defaults)
|
278
|
+
assert_equal expected, merged
|
279
|
+
|
280
|
+
# Should be an alias for reverse_merge!
|
281
|
+
merged = options.dup
|
282
|
+
assert_equal expected, merged.reverse_update(defaults)
|
283
|
+
assert_equal expected, merged
|
284
|
+
end
|
285
|
+
|
286
|
+
def test_diff
|
287
|
+
assert_equal({ :a => 2 }, { :a => 2, :b => 5 }.diff({ :a => 1, :b => 5 }))
|
288
|
+
end
|
289
|
+
|
290
|
+
def test_slice
|
291
|
+
original = { :a => 'x', :b => 'y', :c => 10 }
|
292
|
+
expected = { :a => 'x', :b => 'y' }
|
293
|
+
|
294
|
+
# Should return a new hash with only the given keys.
|
295
|
+
assert_equal expected, original.slice(:a, :b)
|
296
|
+
assert_not_equal expected, original
|
297
|
+
end
|
298
|
+
|
299
|
+
def test_slice_inplace
|
300
|
+
original = { :a => 'x', :b => 'y', :c => 10 }
|
301
|
+
expected = { :c => 10 }
|
302
|
+
|
303
|
+
# Should replace the hash with only the given keys.
|
304
|
+
assert_equal expected, original.slice!(:a, :b)
|
305
|
+
end
|
306
|
+
|
307
|
+
def test_slice_with_an_array_key
|
308
|
+
original = { :a => 'x', :b => 'y', :c => 10, [:a, :b] => "an array key" }
|
309
|
+
expected = { [:a, :b] => "an array key", :c => 10 }
|
310
|
+
|
311
|
+
# Should return a new hash with only the given keys when given an array key.
|
312
|
+
assert_equal expected, original.slice([:a, :b], :c)
|
313
|
+
assert_not_equal expected, original
|
314
|
+
end
|
315
|
+
|
316
|
+
def test_slice_inplace_with_an_array_key
|
317
|
+
original = { :a => 'x', :b => 'y', :c => 10, [:a, :b] => "an array key" }
|
318
|
+
expected = { :a => 'x', :b => 'y' }
|
319
|
+
|
320
|
+
# Should replace the hash with only the given keys when given an array key.
|
321
|
+
assert_equal expected, original.slice!([:a, :b], :c)
|
322
|
+
end
|
323
|
+
|
324
|
+
def test_slice_with_splatted_keys
|
325
|
+
original = { :a => 'x', :b => 'y', :c => 10, [:a, :b] => "an array key" }
|
326
|
+
expected = { :a => 'x', :b => "y" }
|
327
|
+
|
328
|
+
# Should grab each of the splatted keys.
|
329
|
+
assert_equal expected, original.slice(*[:a, :b])
|
330
|
+
end
|
331
|
+
|
332
|
+
def test_indifferent_slice
|
333
|
+
original = { :a => 'x', :b => 'y', :c => 10 }.with_indifferent_access
|
334
|
+
expected = { :a => 'x', :b => 'y' }.with_indifferent_access
|
335
|
+
|
336
|
+
[['a', 'b'], [:a, :b]].each do |keys|
|
337
|
+
# Should return a new hash with only the given keys.
|
338
|
+
assert_equal expected, original.slice(*keys), keys.inspect
|
339
|
+
assert_not_equal expected, original
|
340
|
+
end
|
341
|
+
end
|
342
|
+
|
343
|
+
def test_indifferent_slice_inplace
|
344
|
+
original = { :a => 'x', :b => 'y', :c => 10 }.with_indifferent_access
|
345
|
+
expected = { :c => 10 }.with_indifferent_access
|
346
|
+
|
347
|
+
[['a', 'b'], [:a, :b]].each do |keys|
|
348
|
+
# Should replace the hash with only the given keys.
|
349
|
+
copy = original.dup
|
350
|
+
assert_equal expected, copy.slice!(*keys)
|
351
|
+
end
|
352
|
+
end
|
353
|
+
|
354
|
+
def test_indifferent_slice_access_with_symbols
|
355
|
+
original = {'login' => 'bender', 'password' => 'shiny', 'stuff' => 'foo'}
|
356
|
+
original = original.with_indifferent_access
|
357
|
+
|
358
|
+
slice = original.slice(:login, :password)
|
359
|
+
|
360
|
+
assert_equal 'bender', slice[:login]
|
361
|
+
assert_equal 'bender', slice['login']
|
362
|
+
end
|
363
|
+
|
364
|
+
def test_except
|
365
|
+
original = { :a => 'x', :b => 'y', :c => 10 }
|
366
|
+
expected = { :a => 'x', :b => 'y' }
|
367
|
+
|
368
|
+
# Should return a new hash with only the given keys.
|
369
|
+
assert_equal expected, original.except(:c)
|
370
|
+
assert_not_equal expected, original
|
371
|
+
|
372
|
+
# Should replace the hash with only the given keys.
|
373
|
+
assert_equal expected, original.except!(:c)
|
374
|
+
assert_equal expected, original
|
375
|
+
end
|
376
|
+
|
377
|
+
def test_except_with_original_frozen
|
378
|
+
original = { :a => 'x', :b => 'y' }
|
379
|
+
original.freeze
|
380
|
+
assert_nothing_raised { original.except(:a) }
|
381
|
+
end
|
382
|
+
|
383
|
+
def test_except_with_mocha_expectation_on_original
|
384
|
+
original = { :a => 'x', :b => 'y' }
|
385
|
+
original.expects(:delete).never
|
386
|
+
original.except(:a)
|
387
|
+
end
|
388
|
+
end
|
389
|
+
|
390
|
+
class IWriteMyOwnXML
|
391
|
+
def to_xml(options = {})
|
392
|
+
options[:indent] ||= 2
|
393
|
+
xml = options[:builder] ||= Builder::XmlMarkup.new(:indent => options[:indent])
|
394
|
+
xml.instruct! unless options[:skip_instruct]
|
395
|
+
xml.level_one do
|
396
|
+
xml.tag!(:second_level, 'content')
|
397
|
+
end
|
398
|
+
end
|
399
|
+
end
|
400
|
+
|
401
|
+
class HashToXmlTest < Test::Unit::TestCase
|
402
|
+
def setup
|
403
|
+
@xml_options = { :root => :person, :skip_instruct => true, :indent => 0 }
|
404
|
+
end
|
405
|
+
|
406
|
+
def test_default_values_for_rename_keys
|
407
|
+
assert_equal true,ActiveSupport.dasherize_xml
|
408
|
+
assert_equal false,ActiveSupport.camelize_xml
|
409
|
+
end
|
410
|
+
|
411
|
+
def test_one_level
|
412
|
+
xml = { :name => "David", :street => "Paulina" }.to_xml(@xml_options)
|
413
|
+
assert_equal "<person>", xml.first(8)
|
414
|
+
assert xml.include?(%(<street>Paulina</street>))
|
415
|
+
assert xml.include?(%(<name>David</name>))
|
416
|
+
end
|
417
|
+
# we add :camelize => false because otherwise we'd be accidentally testing the default value for :camelize
|
418
|
+
def test_one_level_dasherize_false
|
419
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => false,:camelize=>false))
|
420
|
+
assert_equal "<person>", xml.first(8)
|
421
|
+
assert xml.include?(%(<street_name>Paulina</street_name>))
|
422
|
+
assert xml.include?(%(<name>David</name>))
|
423
|
+
end
|
424
|
+
|
425
|
+
def test_one_level_dasherize_true
|
426
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => true,:camelize=>false))
|
427
|
+
assert_equal "<person>", xml.first(8)
|
428
|
+
assert xml.include?(%(<street-name>Paulina</street-name>))
|
429
|
+
assert xml.include?(%(<name>David</name>))
|
430
|
+
end
|
431
|
+
|
432
|
+
def test_one_level_dasherize_default_false
|
433
|
+
current_default = ActiveSupport.dasherize_xml
|
434
|
+
ActiveSupport.dasherize_xml = false
|
435
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:camelize=>false))
|
436
|
+
assert_equal "<person>", xml.first(8)
|
437
|
+
assert xml.include?(%(<street_name>Paulina</street_name>))
|
438
|
+
assert xml.include?(%(<name>David</name>))
|
439
|
+
ensure
|
440
|
+
ActiveSupport.dasherize_xml = current_default
|
441
|
+
end
|
442
|
+
|
443
|
+
def test_one_level_dasherize_default_true
|
444
|
+
current_default = ActiveSupport.dasherize_xml
|
445
|
+
ActiveSupport.dasherize_xml = true
|
446
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:camelize=>false))
|
447
|
+
assert_equal "<person>", xml.first(8)
|
448
|
+
assert xml.include?(%(<street-name>Paulina</street-name>))
|
449
|
+
assert xml.include?(%(<name>David</name>))
|
450
|
+
ensure
|
451
|
+
ActiveSupport.dasherize_xml = current_default
|
452
|
+
end
|
453
|
+
|
454
|
+
def test_one_level_camelize_true
|
455
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:camelize => true,:dasherize => false))
|
456
|
+
assert_equal "<Person>", xml.first(8)
|
457
|
+
assert xml.include?(%(<StreetName>Paulina</StreetName>))
|
458
|
+
assert xml.include?(%(<Name>David</Name>))
|
459
|
+
end
|
460
|
+
|
461
|
+
#camelize=>false is already tested above
|
462
|
+
|
463
|
+
def test_one_level_camelize_default_false
|
464
|
+
current_default = ActiveSupport.camelize_xml
|
465
|
+
ActiveSupport.camelize_xml = false
|
466
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => false))
|
467
|
+
assert_equal "<person>", xml.first(8)
|
468
|
+
assert xml.include?(%(<street_name>Paulina</street_name>))
|
469
|
+
assert xml.include?(%(<name>David</name>))
|
470
|
+
ensure
|
471
|
+
ActiveSupport.camelize_xml = current_default
|
472
|
+
end
|
473
|
+
|
474
|
+
def test_one_level_camelize_default_true
|
475
|
+
current_default = ActiveSupport.camelize_xml
|
476
|
+
ActiveSupport.camelize_xml = true
|
477
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => false))
|
478
|
+
assert_equal "<Person>", xml.first(8)
|
479
|
+
assert xml.include?(%(<StreetName>Paulina</StreetName>))
|
480
|
+
assert xml.include?(%(<Name>David</Name>))
|
481
|
+
ensure
|
482
|
+
ActiveSupport.camelize_xml = current_default
|
483
|
+
end
|
484
|
+
|
485
|
+
def test_one_level_camelize_true_dasherize_true
|
486
|
+
xml = { :name => "David", :street_name => "Paulina" }.to_xml(@xml_options.merge(:dasherize => true,:camelize=>true))
|
487
|
+
assert_equal "<Person>", xml.first(8)
|
488
|
+
assert xml.include?(%(<StreetName>Paulina</StreetName>))
|
489
|
+
assert xml.include?(%(<Name>David</Name>))
|
490
|
+
end
|
491
|
+
|
492
|
+
def test_one_level_with_types
|
493
|
+
xml = { :name => "David", :street => "Paulina", :age => 26, :age_in_millis => 820497600000, :moved_on => Date.new(2005, 11, 15), :resident => :yes }.to_xml(@xml_options)
|
494
|
+
assert_equal "<person>", xml.first(8)
|
495
|
+
assert xml.include?(%(<street>Paulina</street>))
|
496
|
+
assert xml.include?(%(<name>David</name>))
|
497
|
+
assert xml.include?(%(<age type="integer">26</age>))
|
498
|
+
assert xml.include?(%(<age-in-millis type="integer">820497600000</age-in-millis>))
|
499
|
+
assert xml.include?(%(<moved-on type="date">2005-11-15</moved-on>))
|
500
|
+
assert xml.include?(%(<resident type="symbol">yes</resident>))
|
501
|
+
end
|
502
|
+
|
503
|
+
def test_one_level_with_nils
|
504
|
+
xml = { :name => "David", :street => "Paulina", :age => nil }.to_xml(@xml_options)
|
505
|
+
assert_equal "<person>", xml.first(8)
|
506
|
+
assert xml.include?(%(<street>Paulina</street>))
|
507
|
+
assert xml.include?(%(<name>David</name>))
|
508
|
+
assert xml.include?(%(<age nil="true"></age>))
|
509
|
+
end
|
510
|
+
|
511
|
+
def test_one_level_with_skipping_types
|
512
|
+
xml = { :name => "David", :street => "Paulina", :age => nil }.to_xml(@xml_options.merge(:skip_types => true))
|
513
|
+
assert_equal "<person>", xml.first(8)
|
514
|
+
assert xml.include?(%(<street>Paulina</street>))
|
515
|
+
assert xml.include?(%(<name>David</name>))
|
516
|
+
assert xml.include?(%(<age nil="true"></age>))
|
517
|
+
end
|
518
|
+
|
519
|
+
def test_one_level_with_yielding
|
520
|
+
xml = { :name => "David", :street => "Paulina" }.to_xml(@xml_options) do |x|
|
521
|
+
x.creator("Rails")
|
522
|
+
end
|
523
|
+
|
524
|
+
assert_equal "<person>", xml.first(8)
|
525
|
+
assert xml.include?(%(<street>Paulina</street>))
|
526
|
+
assert xml.include?(%(<name>David</name>))
|
527
|
+
assert xml.include?(%(<creator>Rails</creator>))
|
528
|
+
end
|
529
|
+
|
530
|
+
def test_two_levels
|
531
|
+
xml = { :name => "David", :address => { :street => "Paulina" } }.to_xml(@xml_options)
|
532
|
+
assert_equal "<person>", xml.first(8)
|
533
|
+
assert xml.include?(%(<address><street>Paulina</street></address>))
|
534
|
+
assert xml.include?(%(<name>David</name>))
|
535
|
+
end
|
536
|
+
|
537
|
+
def test_two_levels_with_second_level_overriding_to_xml
|
538
|
+
xml = { :name => "David", :address => { :street => "Paulina" }, :child => IWriteMyOwnXML.new }.to_xml(@xml_options)
|
539
|
+
assert_equal "<person>", xml.first(8)
|
540
|
+
assert xml.include?(%(<address><street>Paulina</street></address>))
|
541
|
+
assert xml.include?(%(<level_one><second_level>content</second_level></level_one>))
|
542
|
+
end
|
543
|
+
|
544
|
+
def test_two_levels_with_array
|
545
|
+
xml = { :name => "David", :addresses => [{ :street => "Paulina" }, { :street => "Evergreen" }] }.to_xml(@xml_options)
|
546
|
+
assert_equal "<person>", xml.first(8)
|
547
|
+
assert xml.include?(%(<addresses type="array"><address>))
|
548
|
+
assert xml.include?(%(<address><street>Paulina</street></address>))
|
549
|
+
assert xml.include?(%(<address><street>Evergreen</street></address>))
|
550
|
+
assert xml.include?(%(<name>David</name>))
|
551
|
+
end
|
552
|
+
|
553
|
+
def test_three_levels_with_array
|
554
|
+
xml = { :name => "David", :addresses => [{ :streets => [ { :name => "Paulina" }, { :name => "Paulina" } ] } ] }.to_xml(@xml_options)
|
555
|
+
assert xml.include?(%(<addresses type="array"><address><streets type="array"><street><name>))
|
556
|
+
end
|
557
|
+
|
558
|
+
def test_timezoned_attributes
|
559
|
+
xml = {
|
560
|
+
:created_at => Time.utc(1999,2,2),
|
561
|
+
:local_created_at => Time.utc(1999,2,2).in_time_zone('Eastern Time (US & Canada)')
|
562
|
+
}.to_xml(@xml_options)
|
563
|
+
assert_match %r{<created-at type=\"datetime\">1999-02-02T00:00:00Z</created-at>}, xml
|
564
|
+
assert_match %r{<local-created-at type=\"datetime\">1999-02-01T19:00:00-05:00</local-created-at>}, xml
|
565
|
+
end
|
566
|
+
|
567
|
+
def test_single_record_from_xml
|
568
|
+
topic_xml = <<-EOT
|
569
|
+
<topic>
|
570
|
+
<title>The First Topic</title>
|
571
|
+
<author-name>David</author-name>
|
572
|
+
<id type="integer">1</id>
|
573
|
+
<approved type="boolean"> true </approved>
|
574
|
+
<replies-count type="integer">0</replies-count>
|
575
|
+
<replies-close-in type="integer">2592000000</replies-close-in>
|
576
|
+
<written-on type="date">2003-07-16</written-on>
|
577
|
+
<viewed-at type="datetime">2003-07-16T09:28:00+0000</viewed-at>
|
578
|
+
<content type="yaml">--- \n1: should be an integer\n:message: Have a nice day\narray: \n- should-have-dashes: true\n should_have_underscores: true\n</content>
|
579
|
+
<author-email-address>david@loudthinking.com</author-email-address>
|
580
|
+
<parent-id></parent-id>
|
581
|
+
<ad-revenue type="decimal">1.5</ad-revenue>
|
582
|
+
<optimum-viewing-angle type="float">135</optimum-viewing-angle>
|
583
|
+
<resident type="symbol">yes</resident>
|
584
|
+
</topic>
|
585
|
+
EOT
|
586
|
+
|
587
|
+
expected_topic_hash = {
|
588
|
+
:title => "The First Topic",
|
589
|
+
:author_name => "David",
|
590
|
+
:id => 1,
|
591
|
+
:approved => true,
|
592
|
+
:replies_count => 0,
|
593
|
+
:replies_close_in => 2592000000,
|
594
|
+
:written_on => Date.new(2003, 7, 16),
|
595
|
+
:viewed_at => Time.utc(2003, 7, 16, 9, 28),
|
596
|
+
:content => { :message => "Have a nice day", 1 => "should be an integer", "array" => [{ "should-have-dashes" => true, "should_have_underscores" => true }] },
|
597
|
+
:author_email_address => "david@loudthinking.com",
|
598
|
+
:parent_id => nil,
|
599
|
+
:ad_revenue => BigDecimal("1.50"),
|
600
|
+
:optimum_viewing_angle => 135.0,
|
601
|
+
:resident => :yes
|
602
|
+
}.stringify_keys
|
603
|
+
|
604
|
+
assert_equal expected_topic_hash, Hash.from_xml(topic_xml)["topic"]
|
605
|
+
end
|
606
|
+
|
607
|
+
def test_single_record_from_xml_with_nil_values
|
608
|
+
topic_xml = <<-EOT
|
609
|
+
<topic>
|
610
|
+
<title></title>
|
611
|
+
<id type="integer"></id>
|
612
|
+
<approved type="boolean"></approved>
|
613
|
+
<written-on type="date"></written-on>
|
614
|
+
<viewed-at type="datetime"></viewed-at>
|
615
|
+
<content type="yaml"></content>
|
616
|
+
<parent-id></parent-id>
|
617
|
+
</topic>
|
618
|
+
EOT
|
619
|
+
|
620
|
+
expected_topic_hash = {
|
621
|
+
:title => nil,
|
622
|
+
:id => nil,
|
623
|
+
:approved => nil,
|
624
|
+
:written_on => nil,
|
625
|
+
:viewed_at => nil,
|
626
|
+
:content => nil,
|
627
|
+
:parent_id => nil
|
628
|
+
}.stringify_keys
|
629
|
+
|
630
|
+
assert_equal expected_topic_hash, Hash.from_xml(topic_xml)["topic"]
|
631
|
+
end
|
632
|
+
|
633
|
+
def test_multiple_records_from_xml
|
634
|
+
topics_xml = <<-EOT
|
635
|
+
<topics type="array">
|
636
|
+
<topic>
|
637
|
+
<title>The First Topic</title>
|
638
|
+
<author-name>David</author-name>
|
639
|
+
<id type="integer">1</id>
|
640
|
+
<approved type="boolean">false</approved>
|
641
|
+
<replies-count type="integer">0</replies-count>
|
642
|
+
<replies-close-in type="integer">2592000000</replies-close-in>
|
643
|
+
<written-on type="date">2003-07-16</written-on>
|
644
|
+
<viewed-at type="datetime">2003-07-16T09:28:00+0000</viewed-at>
|
645
|
+
<content>Have a nice day</content>
|
646
|
+
<author-email-address>david@loudthinking.com</author-email-address>
|
647
|
+
<parent-id nil="true"></parent-id>
|
648
|
+
</topic>
|
649
|
+
<topic>
|
650
|
+
<title>The Second Topic</title>
|
651
|
+
<author-name>Jason</author-name>
|
652
|
+
<id type="integer">1</id>
|
653
|
+
<approved type="boolean">false</approved>
|
654
|
+
<replies-count type="integer">0</replies-count>
|
655
|
+
<replies-close-in type="integer">2592000000</replies-close-in>
|
656
|
+
<written-on type="date">2003-07-16</written-on>
|
657
|
+
<viewed-at type="datetime">2003-07-16T09:28:00+0000</viewed-at>
|
658
|
+
<content>Have a nice day</content>
|
659
|
+
<author-email-address>david@loudthinking.com</author-email-address>
|
660
|
+
<parent-id></parent-id>
|
661
|
+
</topic>
|
662
|
+
</topics>
|
663
|
+
EOT
|
664
|
+
|
665
|
+
expected_topic_hash = {
|
666
|
+
:title => "The First Topic",
|
667
|
+
:author_name => "David",
|
668
|
+
:id => 1,
|
669
|
+
:approved => false,
|
670
|
+
:replies_count => 0,
|
671
|
+
:replies_close_in => 2592000000,
|
672
|
+
:written_on => Date.new(2003, 7, 16),
|
673
|
+
:viewed_at => Time.utc(2003, 7, 16, 9, 28),
|
674
|
+
:content => "Have a nice day",
|
675
|
+
:author_email_address => "david@loudthinking.com",
|
676
|
+
:parent_id => nil
|
677
|
+
}.stringify_keys
|
678
|
+
|
679
|
+
assert_equal expected_topic_hash, Hash.from_xml(topics_xml)["topics"].first
|
680
|
+
end
|
681
|
+
|
682
|
+
def test_single_record_from_xml_with_attributes_other_than_type
|
683
|
+
topic_xml = <<-EOT
|
684
|
+
<rsp stat="ok">
|
685
|
+
<photos page="1" pages="1" perpage="100" total="16">
|
686
|
+
<photo id="175756086" owner="55569174@N00" secret="0279bf37a1" server="76" title="Colored Pencil PhotoBooth Fun" ispublic="1" isfriend="0" isfamily="0"/>
|
687
|
+
</photos>
|
688
|
+
</rsp>
|
689
|
+
EOT
|
690
|
+
|
691
|
+
expected_topic_hash = {
|
692
|
+
:id => "175756086",
|
693
|
+
:owner => "55569174@N00",
|
694
|
+
:secret => "0279bf37a1",
|
695
|
+
:server => "76",
|
696
|
+
:title => "Colored Pencil PhotoBooth Fun",
|
697
|
+
:ispublic => "1",
|
698
|
+
:isfriend => "0",
|
699
|
+
:isfamily => "0",
|
700
|
+
}.stringify_keys
|
701
|
+
|
702
|
+
assert_equal expected_topic_hash, Hash.from_xml(topic_xml)["rsp"]["photos"]["photo"]
|
703
|
+
end
|
704
|
+
|
705
|
+
def test_empty_array_from_xml
|
706
|
+
blog_xml = <<-XML
|
707
|
+
<blog>
|
708
|
+
<posts type="array"></posts>
|
709
|
+
</blog>
|
710
|
+
XML
|
711
|
+
expected_blog_hash = {"blog" => {"posts" => []}}
|
712
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
713
|
+
end
|
714
|
+
|
715
|
+
def test_all_caps_key_from_xml
|
716
|
+
test_xml = <<-EOT
|
717
|
+
<ABC3XYZ>
|
718
|
+
<TEST>Lorem Ipsum</TEST>
|
719
|
+
</ABC3XYZ>
|
720
|
+
EOT
|
721
|
+
|
722
|
+
expected_hash = {
|
723
|
+
"ABC3XYZ" => {
|
724
|
+
"TEST" => "Lorem Ipsum"
|
725
|
+
}
|
726
|
+
}
|
727
|
+
|
728
|
+
assert_equal expected_hash, Hash.from_xml(test_xml)
|
729
|
+
end
|
730
|
+
|
731
|
+
def test_empty_array_with_whitespace_from_xml
|
732
|
+
blog_xml = <<-XML
|
733
|
+
<blog>
|
734
|
+
<posts type="array">
|
735
|
+
</posts>
|
736
|
+
</blog>
|
737
|
+
XML
|
738
|
+
expected_blog_hash = {"blog" => {"posts" => []}}
|
739
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
740
|
+
end
|
741
|
+
|
742
|
+
def test_array_with_one_entry_from_xml
|
743
|
+
blog_xml = <<-XML
|
744
|
+
<blog>
|
745
|
+
<posts type="array">
|
746
|
+
<post>a post</post>
|
747
|
+
</posts>
|
748
|
+
</blog>
|
749
|
+
XML
|
750
|
+
expected_blog_hash = {"blog" => {"posts" => ["a post"]}}
|
751
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
752
|
+
end
|
753
|
+
|
754
|
+
def test_array_with_multiple_entries_from_xml
|
755
|
+
blog_xml = <<-XML
|
756
|
+
<blog>
|
757
|
+
<posts type="array">
|
758
|
+
<post>a post</post>
|
759
|
+
<post>another post</post>
|
760
|
+
</posts>
|
761
|
+
</blog>
|
762
|
+
XML
|
763
|
+
expected_blog_hash = {"blog" => {"posts" => ["a post", "another post"]}}
|
764
|
+
assert_equal expected_blog_hash, Hash.from_xml(blog_xml)
|
765
|
+
end
|
766
|
+
|
767
|
+
def test_file_from_xml
|
768
|
+
blog_xml = <<-XML
|
769
|
+
<blog>
|
770
|
+
<logo type="file" name="logo.png" content_type="image/png">
|
771
|
+
</logo>
|
772
|
+
</blog>
|
773
|
+
XML
|
774
|
+
hash = Hash.from_xml(blog_xml)
|
775
|
+
assert hash.has_key?('blog')
|
776
|
+
assert hash['blog'].has_key?('logo')
|
777
|
+
|
778
|
+
file = hash['blog']['logo']
|
779
|
+
assert_equal 'logo.png', file.original_filename
|
780
|
+
assert_equal 'image/png', file.content_type
|
781
|
+
end
|
782
|
+
|
783
|
+
def test_file_from_xml_with_defaults
|
784
|
+
blog_xml = <<-XML
|
785
|
+
<blog>
|
786
|
+
<logo type="file">
|
787
|
+
</logo>
|
788
|
+
</blog>
|
789
|
+
XML
|
790
|
+
file = Hash.from_xml(blog_xml)['blog']['logo']
|
791
|
+
assert_equal 'untitled', file.original_filename
|
792
|
+
assert_equal 'application/octet-stream', file.content_type
|
793
|
+
end
|
794
|
+
|
795
|
+
def test_xsd_like_types_from_xml
|
796
|
+
bacon_xml = <<-EOT
|
797
|
+
<bacon>
|
798
|
+
<weight type="double">0.5</weight>
|
799
|
+
<price type="decimal">12.50</price>
|
800
|
+
<chunky type="boolean"> 1 </chunky>
|
801
|
+
<expires-at type="dateTime">2007-12-25T12:34:56+0000</expires-at>
|
802
|
+
<notes type="string"></notes>
|
803
|
+
<illustration type="base64Binary">YmFiZS5wbmc=</illustration>
|
804
|
+
</bacon>
|
805
|
+
EOT
|
806
|
+
|
807
|
+
expected_bacon_hash = {
|
808
|
+
:weight => 0.5,
|
809
|
+
:chunky => true,
|
810
|
+
:price => BigDecimal("12.50"),
|
811
|
+
:expires_at => Time.utc(2007,12,25,12,34,56),
|
812
|
+
:notes => "",
|
813
|
+
:illustration => "babe.png"
|
814
|
+
}.stringify_keys
|
815
|
+
|
816
|
+
assert_equal expected_bacon_hash, Hash.from_xml(bacon_xml)["bacon"]
|
817
|
+
end
|
818
|
+
|
819
|
+
def test_type_trickles_through_when_unknown
|
820
|
+
product_xml = <<-EOT
|
821
|
+
<product>
|
822
|
+
<weight type="double">0.5</weight>
|
823
|
+
<image type="ProductImage"><filename>image.gif</filename></image>
|
824
|
+
|
825
|
+
</product>
|
826
|
+
EOT
|
827
|
+
|
828
|
+
expected_product_hash = {
|
829
|
+
:weight => 0.5,
|
830
|
+
:image => {'type' => 'ProductImage', 'filename' => 'image.gif' },
|
831
|
+
}.stringify_keys
|
832
|
+
|
833
|
+
assert_equal expected_product_hash, Hash.from_xml(product_xml)["product"]
|
834
|
+
end
|
835
|
+
|
836
|
+
def test_should_use_default_value_for_unknown_key
|
837
|
+
hash_wia = HashWithIndifferentAccess.new(3)
|
838
|
+
assert_equal 3, hash_wia[:new_key]
|
839
|
+
end
|
840
|
+
|
841
|
+
def test_should_use_default_value_if_no_key_is_supplied
|
842
|
+
hash_wia = HashWithIndifferentAccess.new(3)
|
843
|
+
assert_equal 3, hash_wia.default
|
844
|
+
end
|
845
|
+
|
846
|
+
def test_should_nil_if_no_default_value_is_supplied
|
847
|
+
hash_wia = HashWithIndifferentAccess.new
|
848
|
+
assert_nil hash_wia.default
|
849
|
+
end
|
850
|
+
|
851
|
+
def test_should_copy_the_default_value_when_converting_to_hash_with_indifferent_access
|
852
|
+
hash = Hash.new(3)
|
853
|
+
hash_wia = hash.with_indifferent_access
|
854
|
+
assert_equal 3, hash_wia.default
|
855
|
+
end
|
856
|
+
|
857
|
+
# The XML builder seems to fail miserably when trying to tag something
|
858
|
+
# with the same name as a Kernel method (throw, test, loop, select ...)
|
859
|
+
def test_kernel_method_names_to_xml
|
860
|
+
hash = { :throw => { :ball => 'red' } }
|
861
|
+
expected = '<person><throw><ball>red</ball></throw></person>'
|
862
|
+
|
863
|
+
assert_nothing_raised do
|
864
|
+
assert_equal expected, hash.to_xml(@xml_options)
|
865
|
+
end
|
866
|
+
end
|
867
|
+
|
868
|
+
def test_empty_string_works_for_typecast_xml_value
|
869
|
+
assert_nothing_raised do
|
870
|
+
Hash.__send__(:typecast_xml_value, "")
|
871
|
+
end
|
872
|
+
end
|
873
|
+
|
874
|
+
def test_escaping_to_xml
|
875
|
+
hash = {
|
876
|
+
:bare_string => 'First & Last Name',
|
877
|
+
:pre_escaped_string => 'First & Last Name'
|
878
|
+
}.stringify_keys
|
879
|
+
|
880
|
+
expected_xml = '<person><bare-string>First & Last Name</bare-string><pre-escaped-string>First &amp; Last Name</pre-escaped-string></person>'
|
881
|
+
assert_equal expected_xml, hash.to_xml(@xml_options)
|
882
|
+
end
|
883
|
+
|
884
|
+
def test_unescaping_from_xml
|
885
|
+
xml_string = '<person><bare-string>First & Last Name</bare-string><pre-escaped-string>First &amp; Last Name</pre-escaped-string></person>'
|
886
|
+
expected_hash = {
|
887
|
+
:bare_string => 'First & Last Name',
|
888
|
+
:pre_escaped_string => 'First & Last Name'
|
889
|
+
}.stringify_keys
|
890
|
+
assert_equal expected_hash, Hash.from_xml(xml_string)['person']
|
891
|
+
end
|
892
|
+
|
893
|
+
def test_roundtrip_to_xml_from_xml
|
894
|
+
hash = {
|
895
|
+
:bare_string => 'First & Last Name',
|
896
|
+
:pre_escaped_string => 'First & Last Name'
|
897
|
+
}.stringify_keys
|
898
|
+
|
899
|
+
assert_equal hash, Hash.from_xml(hash.to_xml(@xml_options))['person']
|
900
|
+
end
|
901
|
+
|
902
|
+
def test_to_xml_dups_options
|
903
|
+
options = {:skip_instruct => true}
|
904
|
+
{}.to_xml(options)
|
905
|
+
# :builder, etc, shouldn't be added to options
|
906
|
+
assert_equal({:skip_instruct => true}, options)
|
907
|
+
end
|
908
|
+
|
909
|
+
def test_datetime_xml_type_with_utc_time
|
910
|
+
alert_xml = <<-XML
|
911
|
+
<alert>
|
912
|
+
<alert_at type="datetime">2008-02-10T15:30:45Z</alert_at>
|
913
|
+
</alert>
|
914
|
+
XML
|
915
|
+
alert_at = Hash.from_xml(alert_xml)['alert']['alert_at']
|
916
|
+
assert alert_at.utc?
|
917
|
+
assert_equal Time.utc(2008, 2, 10, 15, 30, 45), alert_at
|
918
|
+
end
|
919
|
+
|
920
|
+
def test_datetime_xml_type_with_non_utc_time
|
921
|
+
alert_xml = <<-XML
|
922
|
+
<alert>
|
923
|
+
<alert_at type="datetime">2008-02-10T10:30:45-05:00</alert_at>
|
924
|
+
</alert>
|
925
|
+
XML
|
926
|
+
alert_at = Hash.from_xml(alert_xml)['alert']['alert_at']
|
927
|
+
assert alert_at.utc?
|
928
|
+
assert_equal Time.utc(2008, 2, 10, 15, 30, 45), alert_at
|
929
|
+
end
|
930
|
+
|
931
|
+
def test_datetime_xml_type_with_far_future_date
|
932
|
+
alert_xml = <<-XML
|
933
|
+
<alert>
|
934
|
+
<alert_at type="datetime">2050-02-10T15:30:45Z</alert_at>
|
935
|
+
</alert>
|
936
|
+
XML
|
937
|
+
alert_at = Hash.from_xml(alert_xml)['alert']['alert_at']
|
938
|
+
assert alert_at.utc?
|
939
|
+
assert_equal 2050, alert_at.year
|
940
|
+
assert_equal 2, alert_at.month
|
941
|
+
assert_equal 10, alert_at.day
|
942
|
+
assert_equal 15, alert_at.hour
|
943
|
+
assert_equal 30, alert_at.min
|
944
|
+
assert_equal 45, alert_at.sec
|
945
|
+
end
|
946
|
+
end
|
947
|
+
|
948
|
+
class QueryTest < Test::Unit::TestCase
|
949
|
+
def test_simple_conversion
|
950
|
+
assert_query_equal 'a=10', :a => 10
|
951
|
+
end
|
952
|
+
|
953
|
+
def test_cgi_escaping
|
954
|
+
assert_query_equal 'a%3Ab=c+d', 'a:b' => 'c d'
|
955
|
+
end
|
956
|
+
|
957
|
+
def test_nil_parameter_value
|
958
|
+
empty = Object.new
|
959
|
+
def empty.to_param; nil end
|
960
|
+
assert_query_equal 'a=', 'a' => empty
|
961
|
+
end
|
962
|
+
|
963
|
+
def test_nested_conversion
|
964
|
+
assert_query_equal 'person%5Blogin%5D=seckar&person%5Bname%5D=Nicholas',
|
965
|
+
:person => {:name => 'Nicholas', :login => 'seckar'}
|
966
|
+
end
|
967
|
+
|
968
|
+
def test_multiple_nested
|
969
|
+
assert_query_equal 'account%5Bperson%5D%5Bid%5D=20&person%5Bid%5D=10',
|
970
|
+
:person => {:id => 10}, :account => {:person => {:id => 20}}
|
971
|
+
end
|
972
|
+
|
973
|
+
def test_array_values
|
974
|
+
assert_query_equal 'person%5Bid%5D%5B%5D=10&person%5Bid%5D%5B%5D=20',
|
975
|
+
:person => {:id => [10, 20]}
|
976
|
+
end
|
977
|
+
|
978
|
+
def test_array_values_are_not_sorted
|
979
|
+
assert_query_equal 'person%5Bid%5D%5B%5D=20&person%5Bid%5D%5B%5D=10',
|
980
|
+
:person => {:id => [20, 10]}
|
981
|
+
end
|
982
|
+
|
983
|
+
def test_expansion_count_is_limited
|
984
|
+
expected = {
|
985
|
+
'ActiveSupport::XmlMini_REXML' => 'RuntimeError',
|
986
|
+
'ActiveSupport::XmlMini_Nokogiri' => 'Nokogiri::XML::SyntaxError',
|
987
|
+
'ActiveSupport::XmlMini_NokogiriSAX' => 'RuntimeError',
|
988
|
+
'ActiveSupport::XmlMini_LibXML' => 'LibXML::XML::Error',
|
989
|
+
'ActiveSupport::XmlMini_LibXMLSAX' => 'LibXML::XML::Error',
|
990
|
+
}[ActiveSupport::XmlMini.backend.name].constantize
|
991
|
+
|
992
|
+
assert_raise expected do
|
993
|
+
attack_xml = <<-EOT
|
994
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
995
|
+
<!DOCTYPE member [
|
996
|
+
<!ENTITY a "&b;&b;&b;&b;&b;&b;&b;&b;&b;&b;">
|
997
|
+
<!ENTITY b "&c;&c;&c;&c;&c;&c;&c;&c;&c;&c;">
|
998
|
+
<!ENTITY c "&d;&d;&d;&d;&d;&d;&d;&d;&d;&d;">
|
999
|
+
<!ENTITY d "&e;&e;&e;&e;&e;&e;&e;&e;&e;&e;">
|
1000
|
+
<!ENTITY e "&f;&f;&f;&f;&f;&f;&f;&f;&f;&f;">
|
1001
|
+
<!ENTITY f "&g;&g;&g;&g;&g;&g;&g;&g;&g;&g;">
|
1002
|
+
<!ENTITY g "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx">
|
1003
|
+
]>
|
1004
|
+
<member>
|
1005
|
+
&a;
|
1006
|
+
</member>
|
1007
|
+
EOT
|
1008
|
+
Hash.from_xml(attack_xml)
|
1009
|
+
end
|
1010
|
+
end
|
1011
|
+
|
1012
|
+
private
|
1013
|
+
def assert_query_equal(expected, actual, message = nil)
|
1014
|
+
assert_equal expected.split('&'), actual.to_query.split('&')
|
1015
|
+
end
|
1016
|
+
end
|