radiant 0.9.0.rc2 → 0.9.1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of radiant might be problematic. Click here for more details.
- data/CHANGELOG +18 -6
- data/CONTRIBUTORS +7 -1
- data/INSTALL +0 -5
- data/README +21 -0
- data/app/controllers/admin/layouts_controller.rb +1 -0
- data/app/controllers/admin/preferences_controller.rb +4 -3
- data/app/controllers/admin/resource_controller.rb +62 -8
- data/app/controllers/admin/snippets_controller.rb +1 -0
- data/app/controllers/admin/users_controller.rb +1 -0
- data/app/controllers/application_controller.rb +0 -17
- data/app/controllers/site_controller.rb +6 -4
- data/app/helpers/application_helper.rb +19 -0
- data/app/models/standard_tags.rb +212 -18
- data/app/models/status.rb +1 -1
- data/app/models/user.rb +2 -2
- data/app/views/admin/extensions/index.html.haml +1 -1
- data/app/views/admin/layouts/_form.html.haml +4 -4
- data/app/views/admin/layouts/index.html.haml +2 -2
- data/app/views/admin/page_parts/_page_part.html.haml +2 -2
- data/app/views/admin/pages/_fields.html.haml +5 -5
- data/app/views/admin/preferences/edit.html.haml +3 -3
- data/app/views/admin/snippets/_form.html.haml +5 -5
- data/app/views/admin/snippets/index.html.haml +3 -3
- data/app/views/admin/users/_form.html.haml +3 -4
- data/app/views/admin/users/index.html.haml +2 -1
- data/app/views/layouts/application.html.haml +1 -1
- data/config/environment.rb +2 -2
- data/config/environments/cucumber.rb +3 -3
- data/config/locales/en.yml +10 -10
- data/config/locales/en_available_tags.yml +80 -1
- data/db/migrate/20081203140407_add_indexes.rb +10 -10
- data/db/schema.rb +1 -1
- data/features/admin/resource_pagination.feature +27 -0
- data/features/admin/user_preferences.feature +17 -0
- data/features/step_definitions/admin/pagination_steps.rb +46 -0
- data/features/step_definitions/web_steps.rb +13 -3
- data/features/support/env.rb +7 -3
- data/features/support/paths.rb +1 -1
- data/lib/generators/instance/templates/instance_environment.rb +2 -2
- data/lib/generators/language_extension/templates/lang.yml +6 -6
- data/lib/plugins/active_record_extensions/lib/active_record_extensions.rb +0 -29
- data/lib/radiant.rb +3 -3
- data/lib/radiant/admin_ui.rb +1 -1
- data/lib/radiant/extension/script.rb +20 -5
- data/lib/radiant/extension_loader.rb +1 -1
- data/lib/radiant/initializer.rb +9 -3
- data/lib/radiant/pagination/controller.rb +34 -0
- data/lib/radiant/pagination/link_renderer.rb +7 -4
- data/lib/task_support.rb +6 -1
- data/lib/tasks/cucumber.rake +1 -1
- data/lib/tasks/framework.rake +1 -2
- data/lib/tasks/release.rake +11 -3
- data/lib/tasks/rspec.rake +1 -1
- data/public/images/admin/shadow.png +0 -0
- data/public/images/admin/shadow_grey.png +0 -0
- data/public/javascripts/admin/application.js +4 -1
- data/public/javascripts/admin/cookie.js +2 -2
- data/public/javascripts/admin/validationerror.js +18 -0
- data/public/stylesheets/admin/main.css +110 -37
- data/public/stylesheets/sass/admin/main.sass +3 -2
- data/public/stylesheets/sass/admin/modules/_grid.sass +56 -0
- data/public/stylesheets/sass/admin/partials/_actions.sass +74 -34
- data/public/stylesheets/sass/admin/partials/{_depreciated.sass → _deprecated.sass} +1 -1
- data/public/stylesheets/sass/admin/partials/_popup.sass +1 -1
- data/public/stylesheets/sass/admin/partials/_validations.sass +21 -0
- data/spec/controllers/admin/paginated_controller_spec.rb +26 -0
- data/spec/controllers/admin/preferences_controller_spec.rb +14 -0
- data/spec/controllers/application_controller_spec.rb +1 -11
- data/spec/controllers/site_controller_spec.rb +9 -0
- data/spec/datasets/users_dataset.rb +1 -1
- data/spec/generators/instance_generator_spec.rb +1 -1
- data/spec/helpers/application_helper_spec.rb +38 -0
- data/spec/lib/radiant/extension/script_spec.rb +5 -1
- data/spec/lib/radiant/initializer_spec.rb +7 -0
- data/spec/lib/radiant_spec.rb +1 -1
- data/spec/lib/task_support_spec.rb +14 -0
- data/spec/matchers/render_matcher.rb +14 -1
- data/spec/models/layout_spec.rb +3 -3
- data/spec/models/page_part_spec.rb +3 -3
- data/spec/models/page_spec.rb +8 -9
- data/spec/models/snippet_spec.rb +3 -3
- data/spec/models/standard_tags_spec.rb +99 -5
- data/spec/models/user_spec.rb +11 -11
- data/vendor/extensions/archive/app/models/archive_finder.rb +5 -0
- data/vendor/extensions/french_language_pack/config/locales/fr.yml +31 -25
- data/vendor/extensions/german_language_pack/README +2 -1
- data/vendor/extensions/german_language_pack/config/locales/de.yml +47 -45
- data/vendor/extensions/german_language_pack/config/locales/de_available_tags.yml +375 -304
- data/vendor/extensions/german_language_pack/german_language_pack_extension.rb +2 -2
- data/vendor/extensions/markdown_filter/README +1 -1
- data/vendor/extensions/markdown_filter/lib/markdown_filter.rb +4 -4
- data/vendor/extensions/markdown_filter/lib/markdown_tags.rb +0 -15
- data/vendor/extensions/markdown_filter/markdown_filter_extension.rb +1 -10
- data/vendor/extensions/markdown_filter/spec/models/markdown_filter_spec.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/CONTRIBUTERS +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/ChangeLog +1332 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/README +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/Rakefile +97 -38
- data/vendor/extensions/markdown_filter/vendor/kramdown/VERSION +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/generate_data.rb +6 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-jruby-1.4.0.dat +7 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.8.6.dat +7 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.8.7.dat +7 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.9.1p243.dat +7 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/historic-ruby-1.9.2dev.dat +7 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/benchmark/testing.sh +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/bin/kramdown +11 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/data/kramdown/document.html +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/data/kramdown/document.latex +43 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/default.less.css +510 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/default.template +26 -33
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/documentation.page +72 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/index.page +21 -49
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/installation.page +6 -6
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/links.markdown +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/news.page +3 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/quickref.page +140 -127
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/syntax.page +501 -431
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/tests.page +3 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/compatibility.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter.rb +8 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/base.rb +40 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/html.rb +99 -27
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/converter/latex.rb +57 -18
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/document.rb +32 -13
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/error.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/options.rb +34 -14
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser.rb +9 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/base.rb +95 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/html.rb +387 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown.rb +74 -65
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/abbreviation.rb +65 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/attribute_list.rb +3 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/autolink.rb +8 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/blank_line.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/blockquote.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/codeblock.rb +3 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/codespan.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/emphasis.rb +4 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/eob.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/escaped_chars.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/extension.rb +47 -55
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/footnote.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/header.rb +3 -18
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/horizontal_rule.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/html.rb +69 -149
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/html_entity.rb +4 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/line_break.rb +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/link.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/list.rb +12 -9
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/math.rb +53 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/paragraph.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/smart_quotes.rb +5 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/table.rb +4 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/parser/kramdown/typographic_symbol.rb +7 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/lib/kramdown/version.rb +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/man/man1/kramdown.1 +222 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/run_tests.rb +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/test_files.rb +68 -7
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/with_auto_id_prefix.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/with_auto_id_prefix.options +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/04_header/with_auto_id_prefix.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/item_ial.html +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/item_ial.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/mixed.html +9 -3
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/special_cases.html +49 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/08_list/special_cases.text +29 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/comment.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/comment.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/content_model/tables.html +2 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/code.html +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/code.text +9 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/comment.html +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/comment.text +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/emphasis.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/emphasis.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/entity.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/entity.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/header.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/header.options +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/header.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/list_dl.html +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/list_dl.text +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/list_ol.html +15 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/list_ol.text +17 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/list_ul.html +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/list_ul.text +22 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/options +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/paragraph.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/paragraph.text +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_normal.html +13 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_normal.text +12 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_simple.html +10 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/table_simple.text +14 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/typography.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/html_to_native/typography.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_raw.html +3 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/09_html/parse_as_raw.text +0 -1
- 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/auto_id_and_ial.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/simple.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/11_ial/simple.text +7 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/comment.text +5 -5
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/ignored.html +0 -2
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/ignored.text +3 -6
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/nomarkdown.text +4 -4
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options.text +5 -6
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options2.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/12_extension/options3.text +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/15_math/normal.html +19 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/block/15_math/normal.text +18 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/errors.html +1 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/nesting.html +4 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/02_emphasis/nesting.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/definitions.latex +18 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/footnote_nr.latex +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/04_footnote/markers.latex +32 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/invalid.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/05_html/invalid.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/abbreviations/abbrev.html +8 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/abbreviations/abbrev.text +15 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/abbreviations/abbrev_defs.html +2 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/abbreviations/abbrev_defs.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/autolinks/url_links.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/autolinks/url_links.text +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/comment.html +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/comment.text +6 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/ignored.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/ignored.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/nomarkdown.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/nomarkdown.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/options.html +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/extension/options.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/ial/simple.html +2 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/ial/simple.text +1 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/math/normal.html +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/math/normal.text +5 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.html +3 -0
- data/vendor/extensions/markdown_filter/vendor/kramdown/test/testcases/span/text_substitutions/typography.text +3 -0
- data/vendor/extensions/smarty_pants_filter/README +1 -0
- data/vendor/extensions/smarty_pants_filter/Rakefile +136 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/lib/smarty_pants_filter.rb +0 -0
- data/vendor/extensions/smarty_pants_filter/lib/smarty_pants_tags.rb +18 -0
- data/vendor/extensions/smarty_pants_filter/lib/tasks/smarty_pants_filter_extension_tasks.rake +28 -0
- data/vendor/extensions/smarty_pants_filter/smarty_pants_filter_extension.rb +18 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/smartypants.html +0 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/spec/models/smarty_pants_filter_spec.rb +0 -0
- data/vendor/extensions/smarty_pants_filter/spec/spec.opts +6 -0
- data/vendor/extensions/smarty_pants_filter/spec/spec_helper.rb +36 -0
- data/vendor/extensions/smarty_pants_filter/test/test_helper.rb +19 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/test/unit/smarty_pants_filter_test.rb +0 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/vendor/rubypants/README +0 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/vendor/rubypants/Rakefile +0 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/vendor/rubypants/install.rb +0 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/vendor/rubypants/rubypants.rb +0 -0
- data/vendor/extensions/{markdown_filter → smarty_pants_filter}/vendor/rubypants/test_rubypants.rb +0 -0
- data/vendor/plugins/haml/Rakefile +84 -52
- data/vendor/plugins/haml/VERSION +1 -1
- data/vendor/plugins/haml/doc-src/HAML_CHANGELOG.md +77 -0
- data/vendor/plugins/haml/doc-src/SASS_CHANGELOG.md +60 -0
- data/vendor/plugins/haml/extra/haml-mode.el +15 -12
- data/vendor/plugins/haml/extra/sass-mode.el +2 -2
- data/vendor/plugins/haml/haml.gemspec +16 -7
- data/vendor/plugins/haml/init.rb +3 -1
- data/vendor/plugins/haml/lib/haml.rb +1 -0
- data/vendor/plugins/haml/lib/haml/filters.rb +14 -2
- data/vendor/plugins/haml/lib/haml/helpers.rb +34 -14
- data/vendor/plugins/haml/lib/haml/helpers/action_view_extensions.rb +6 -4
- data/vendor/plugins/haml/lib/haml/helpers/action_view_mods.rb +74 -34
- data/vendor/plugins/haml/lib/haml/helpers/xss_mods.rb +37 -8
- data/vendor/plugins/haml/lib/haml/html.rb +1 -1
- data/vendor/plugins/haml/lib/haml/precompiler.rb +3 -2
- data/vendor/plugins/haml/lib/haml/railtie.rb +18 -0
- data/vendor/plugins/haml/lib/haml/template.rb +15 -4
- data/vendor/plugins/haml/lib/haml/template/plugin.rb +37 -2
- data/vendor/plugins/haml/lib/haml/util.rb +56 -2
- data/vendor/plugins/haml/lib/haml/version.rb +29 -14
- data/vendor/plugins/haml/lib/sass/files.rb +10 -2
- data/vendor/plugins/haml/lib/sass/plugin.rb +7 -2
- data/vendor/plugins/haml/lib/sass/plugin/rack.rb +2 -2
- data/vendor/plugins/haml/lib/sass/plugin/rails.rb +2 -1
- data/vendor/plugins/haml/lib/sass/script/number.rb +2 -2
- data/vendor/plugins/haml/lib/sass/tree/if_node.rb +1 -0
- data/vendor/plugins/haml/lib/sass/tree/rule_node.rb +9 -1
- data/vendor/plugins/haml/test/haml/engine_test.rb +24 -2
- data/vendor/plugins/haml/test/haml/helper_test.rb +60 -9
- data/vendor/plugins/haml/test/haml/template_test.rb +80 -3
- data/vendor/plugins/haml/test/haml/templates/helpers.haml +26 -0
- data/vendor/plugins/haml/test/haml/templates/partial_layout.haml +6 -2
- data/vendor/plugins/haml/test/sass/engine_test.rb +6 -1
- data/vendor/plugins/haml/test/test_helper.rb +16 -1
- data/vendor/radius/LICENSE +19 -0
- data/vendor/radius/QUICKSTART.rdoc +7 -7
- data/vendor/radius/README.rdoc +9 -25
- data/vendor/radius/Rakefile +4 -27
- data/vendor/radius/VERSION +1 -0
- data/vendor/radius/lib/radius/parser.rb +4 -4
- data/vendor/radius/lib/radius/parser/scan.rb +371 -940
- data/vendor/radius/lib/radius/parser/scan.rl +2 -1
- data/vendor/radius/lib/radius/version.rb +5 -11
- data/vendor/radius/radius.gemspec +55 -22
- data/vendor/radius/tasks/jeweler.rake +21 -0
- data/vendor/radius/tasks/rdoc.rake +13 -0
- data/vendor/radius/tasks/test.rake +7 -0
- data/vendor/radius/test/parser_test.rb +5 -0
- data/vendor/radius/test/test_helper.rb +1 -0
- data/vendor/rails/actionmailer/CHANGELOG +18 -0
- data/vendor/rails/actionmailer/MIT-LICENSE +1 -1
- data/vendor/rails/actionmailer/Rakefile +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer.rb +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer/base.rb +2 -2
- data/vendor/rails/actionmailer/lib/action_mailer/quoting.rb +1 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail.rb +1 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/Makefile +18 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/address.rb +4 -38
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/attachments.rb +65 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/base64.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/compat.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/config.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/core_extensions.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/encode.rb +9 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/header.rb +4 -2
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/index.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/interface.rb +33 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/loader.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/mail.rb +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/mailbox.rb +3 -2
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/main.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/mbox.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/net.rb +3 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/obsolete.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/parser.rb +1060 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/parser.y +416 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/port.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/quoting.rb +47 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/require_arch.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/scanner.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/scanner_r.rb +2 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/stringio.rb +0 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/utils.rb +50 -25
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/COPYING +504 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/README +12 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet.rb +67 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/big5freq.rb +927 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/big5prober.rb +42 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/chardistribution.rb +238 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/charsetgroupprober.rb +112 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/charsetprober.rb +75 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/codingstatemachine.rb +64 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/constants.rb +42 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/escprober.rb +89 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/escsm.rb +244 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/eucjpprober.rb +88 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/euckrfreq.rb +596 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/euckrprober.rb +42 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/euctwfreq.rb +430 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/euctwprober.rb +42 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/gb2312freq.rb +474 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/gb2312prober.rb +42 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/hebrewprober.rb +289 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/jisfreq.rb +570 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/jpcntx.rb +229 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/langbulgarianmodel.rb +229 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/langcyrillicmodel.rb +330 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/langgreekmodel.rb +227 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/langhebrewmodel.rb +202 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/langhungarianmodel.rb +226 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/langthaimodel.rb +201 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/latin1prober.rb +147 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/mbcharsetprober.rb +89 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/mbcsgroupprober.rb +45 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/mbcssm.rb +542 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/sbcharsetprober.rb +124 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/sbcsgroupprober.rb +56 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/sjisprober.rb +88 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/universaldetector.rb +168 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.7/tmail/vendor/rchardet-1.3/lib/rchardet/utf8prober.rb +87 -0
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/{tmail-1.2.3 → tmail-1.2.7}/tmail/version.rb +1 -1
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail.rb +2 -2
- data/vendor/rails/actionmailer/lib/action_mailer/version.rb +1 -1
- data/vendor/rails/actionmailer/test/abstract_unit.rb +4 -4
- data/vendor/rails/actionmailer/test/fixtures/helpers/example_helper.rb +1 -1
- data/vendor/rails/actionmailer/test/mail_service_test.rb +66 -2
- data/vendor/rails/actionmailer/test/quoting_test.rb +10 -4
- data/vendor/rails/actionpack/CHANGELOG +55 -0
- data/vendor/rails/actionpack/MIT-LICENSE +1 -1
- data/vendor/rails/actionpack/README +7 -7
- data/vendor/rails/actionpack/Rakefile +2 -2
- data/vendor/rails/actionpack/lib/action_controller.rb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/assertions/response_assertions.rb +18 -9
- data/vendor/rails/actionpack/lib/action_controller/base.rb +14 -14
- data/vendor/rails/actionpack/lib/action_controller/caching/fragments.rb +6 -6
- data/vendor/rails/actionpack/lib/action_controller/cookies.rb +96 -0
- data/vendor/rails/actionpack/lib/action_controller/failsafe.rb +1 -0
- data/vendor/rails/actionpack/lib/action_controller/flash.rb +42 -0
- data/vendor/rails/actionpack/lib/action_controller/integration.rb +5 -1
- data/vendor/rails/actionpack/lib/action_controller/polymorphic_routes.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/rack_lint_patch.rb +1 -1
- data/vendor/rails/actionpack/lib/action_controller/rescue.rb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/response.rb +4 -7
- data/vendor/rails/actionpack/lib/action_controller/routing/route_set.rb +1 -0
- data/vendor/rails/actionpack/lib/action_controller/session/abstract_store.rb +6 -0
- data/vendor/rails/actionpack/lib/action_controller/session/cookie_store.rb +6 -0
- data/vendor/rails/actionpack/lib/action_controller/templates/rescues/_trace.erb +2 -2
- data/vendor/rails/actionpack/lib/action_controller/url_rewriter.rb +4 -1
- data/vendor/rails/actionpack/lib/action_pack.rb +1 -1
- data/vendor/rails/actionpack/lib/action_pack/version.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view.rb +3 -3
- data/vendor/rails/actionpack/lib/action_view/helpers/active_record_helper.rb +11 -11
- data/vendor/rails/actionpack/lib/action_view/helpers/asset_tag_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/capture_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/date_helper.rb +12 -11
- data/vendor/rails/actionpack/lib/action_view/helpers/debug_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/form_helper.rb +49 -12
- data/vendor/rails/actionpack/lib/action_view/helpers/form_options_helper.rb +3 -4
- data/vendor/rails/actionpack/lib/action_view/helpers/form_tag_helper.rb +7 -4
- data/vendor/rails/actionpack/lib/action_view/helpers/javascript_helper.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/number_helper.rb +1 -1
- data/vendor/rails/actionpack/lib/action_view/helpers/prototype_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/raw_output_helper.rb +2 -2
- data/vendor/rails/actionpack/lib/action_view/helpers/sanitize_helper.rb +2 -10
- data/vendor/rails/actionpack/lib/action_view/helpers/tag_helper.rb +6 -5
- data/vendor/rails/actionpack/lib/action_view/helpers/text_helper.rb +5 -5
- data/vendor/rails/actionpack/lib/action_view/helpers/translation_helper.rb +37 -9
- data/vendor/rails/actionpack/lib/action_view/helpers/url_helper.rb +9 -11
- data/vendor/rails/actionpack/lib/action_view/partials.rb +2 -1
- data/vendor/rails/actionpack/lib/action_view/paths.rb +8 -0
- data/vendor/rails/actionpack/lib/action_view/renderable.rb +16 -2
- data/vendor/rails/actionpack/lib/action_view/template_handlers/erb.rb +7 -4
- data/vendor/rails/actionpack/lib/action_view/test_case.rb +1 -1
- data/vendor/rails/actionpack/test/abstract_unit.rb +8 -8
- data/vendor/rails/actionpack/test/active_record_unit.rb +1 -1
- data/vendor/rails/actionpack/test/controller/action_pack_assertions_test.rb +3 -1
- data/vendor/rails/actionpack/test/controller/assert_select_test.rb +6 -5
- data/vendor/rails/actionpack/test/controller/caching_test.rb +16 -2
- data/vendor/rails/actionpack/test/controller/capture_test.rb +1 -1
- data/vendor/rails/actionpack/test/controller/cookie_test.rb +37 -1
- data/vendor/rails/actionpack/test/controller/flash_test.rb +28 -1
- data/vendor/rails/actionpack/test/controller/helper_test.rb +1 -1
- data/vendor/rails/actionpack/test/controller/integration_test.rb +0 -1
- data/vendor/rails/actionpack/test/controller/localized_templates_test.rb +24 -0
- data/vendor/rails/actionpack/test/controller/output_escaping_test.rb +19 -0
- data/vendor/rails/actionpack/test/controller/rack_test.rb +1 -4
- data/vendor/rails/actionpack/test/controller/render_test.rb +11 -2
- data/vendor/rails/actionpack/test/controller/rescue_test.rb +8 -2
- data/vendor/rails/actionpack/test/controller/routing_test.rb +1 -0
- data/vendor/rails/actionpack/test/controller/send_file_test.rb +1 -1
- data/vendor/rails/actionpack/test/controller/session/cookie_store_test.rb +2 -2
- data/vendor/rails/actionpack/test/controller/url_rewriter_test.rb +10 -6
- data/vendor/rails/actionpack/test/fixtures/localized/hello_world.de.html +1 -0
- data/vendor/rails/actionpack/test/fixtures/localized/hello_world.en.html +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/_customer_counter_with_as.erb +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/_utf8_partial.html.erb +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/_utf8_partial_magic.html.erb +2 -0
- data/vendor/rails/actionpack/test/fixtures/test/array_translation.erb +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/capturing.erb +2 -2
- data/vendor/rails/actionpack/test/fixtures/test/scoped_array_translation.erb +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/translation.erb +1 -0
- data/vendor/rails/actionpack/test/fixtures/test/utf8.html.erb +4 -2
- data/vendor/rails/actionpack/test/fixtures/test/utf8_magic.html.erb +5 -0
- data/vendor/rails/actionpack/test/fixtures/test/utf8_magic_with_bare_partial.html.erb +5 -0
- data/vendor/rails/actionpack/test/template/active_record_helper_i18n_test.rb +9 -2
- data/vendor/rails/actionpack/test/template/asset_tag_helper_test.rb +0 -1
- data/vendor/rails/actionpack/test/template/date_helper_test.rb +118 -0
- data/vendor/rails/actionpack/test/template/erb_util_test.rb +12 -0
- data/vendor/rails/actionpack/test/template/form_helper_test.rb +57 -3
- data/vendor/rails/actionpack/test/template/form_tag_helper_test.rb +21 -9
- data/vendor/rails/actionpack/test/template/render_test.rb +47 -8
- data/vendor/rails/actionpack/test/template/text_helper_test.rb +26 -1
- data/vendor/rails/actionpack/test/template/translation_helper_test.rb +72 -9
- data/vendor/rails/actionpack/test/template/url_helper_test.rb +20 -1
- data/vendor/rails/actionpack/test/view/test_case_test.rb +2 -2
- data/vendor/rails/activerecord/CHANGELOG +43 -0
- data/vendor/rails/activerecord/Rakefile +1 -1
- data/vendor/rails/activerecord/examples/performance.sql +85 -0
- data/vendor/rails/activerecord/lib/active_record.rb +1 -2
- data/vendor/rails/activerecord/lib/active_record/association_preload.rb +9 -2
- data/vendor/rails/activerecord/lib/active_record/associations.rb +48 -38
- data/vendor/rails/activerecord/lib/active_record/associations/association_collection.rb +15 -11
- data/vendor/rails/activerecord/lib/active_record/associations/association_proxy.rb +16 -6
- data/vendor/rails/activerecord/lib/active_record/associations/belongs_to_association.rb +11 -1
- data/vendor/rails/activerecord/lib/active_record/associations/belongs_to_polymorphic_association.rb +34 -10
- data/vendor/rails/activerecord/lib/active_record/associations/has_many_association.rb +5 -0
- data/vendor/rails/activerecord/lib/active_record/associations/has_many_through_association.rb +5 -5
- data/vendor/rails/activerecord/lib/active_record/associations/has_one_association.rb +10 -1
- data/vendor/rails/activerecord/lib/active_record/attribute_methods.rb +5 -1
- data/vendor/rails/activerecord/lib/active_record/autosave_association.rb +66 -35
- data/vendor/rails/activerecord/lib/active_record/base.rb +77 -36
- data/vendor/rails/activerecord/lib/active_record/batches.rb +13 -9
- data/vendor/rails/activerecord/lib/active_record/calculations.rb +6 -3
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/connection_specification.rb +3 -3
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/database_limits.rb +57 -0
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/query_cache.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb +3 -7
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/schema_definitions.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract/schema_statements.rb +64 -10
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/abstract_adapter.rb +2 -0
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/mysql_adapter.rb +31 -1
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb +31 -66
- data/vendor/rails/activerecord/lib/active_record/connection_adapters/sqlite_adapter.rb +5 -5
- data/vendor/rails/activerecord/lib/active_record/dirty.rb +2 -2
- data/vendor/rails/activerecord/lib/active_record/fixtures.rb +1 -0
- data/vendor/rails/activerecord/lib/active_record/locking/optimistic.rb +34 -1
- data/vendor/rails/activerecord/lib/active_record/migration.rb +5 -0
- data/vendor/rails/activerecord/lib/active_record/nested_attributes.rb +64 -52
- data/vendor/rails/activerecord/lib/active_record/reflection.rb +66 -1
- data/vendor/rails/activerecord/lib/active_record/schema.rb +5 -1
- data/vendor/rails/activerecord/lib/active_record/schema_dumper.rb +3 -0
- data/vendor/rails/activerecord/lib/active_record/serializers/json_serializer.rb +1 -1
- data/vendor/rails/activerecord/lib/active_record/validations.rb +13 -1
- data/vendor/rails/activerecord/lib/active_record/version.rb +1 -1
- data/vendor/rails/activerecord/test/cases/active_schema_test_mysql.rb +22 -0
- data/vendor/rails/activerecord/test/cases/associations/belongs_to_associations_test.rb +13 -0
- data/vendor/rails/activerecord/test/cases/associations/eager_load_nested_include_test.rb +8 -7
- data/vendor/rails/activerecord/test/cases/associations/eager_test.rb +7 -1
- data/vendor/rails/activerecord/test/cases/associations/has_many_associations_test.rb +26 -0
- data/vendor/rails/activerecord/test/cases/associations/inverse_associations_test.rb +566 -0
- data/vendor/rails/activerecord/test/cases/associations_test.rb +10 -0
- data/vendor/rails/activerecord/test/cases/autosave_association_test.rb +86 -10
- data/vendor/rails/activerecord/test/cases/base_test.rb +29 -0
- data/vendor/rails/activerecord/test/cases/batches_test.rb +20 -0
- data/vendor/rails/activerecord/test/cases/calculations_test.rb +2 -3
- data/vendor/rails/activerecord/test/cases/encoding_test.rb +6 -0
- data/vendor/rails/activerecord/test/cases/finder_test.rb +19 -3
- data/vendor/rails/activerecord/test/cases/fixtures_test.rb +5 -0
- data/vendor/rails/activerecord/test/cases/json_serialization_test.rb +14 -0
- data/vendor/rails/activerecord/test/cases/locking_test.rb +48 -3
- data/vendor/rails/activerecord/test/cases/migration_test.rb +115 -0
- data/vendor/rails/activerecord/test/cases/modules_test.rb +28 -0
- data/vendor/rails/activerecord/test/cases/named_scope_test.rb +1 -1
- data/vendor/rails/activerecord/test/cases/nested_attributes_test.rb +239 -7
- data/vendor/rails/activerecord/test/cases/query_cache_test.rb +7 -1
- data/vendor/rails/activerecord/test/cases/reflection_test.rb +47 -7
- data/vendor/rails/activerecord/test/cases/schema_test_postgresql.rb +2 -2
- data/vendor/rails/activerecord/test/cases/validations_i18n_test.rb +6 -36
- data/vendor/rails/activerecord/test/cases/validations_test.rb +33 -1
- data/vendor/rails/activerecord/test/cases/yaml_serialization_test.rb +11 -0
- data/vendor/rails/activerecord/test/fixtures/faces.yml +11 -0
- data/vendor/rails/{pkg/rails-3.0.pre.gem → 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/activerecord/test/fixtures/interests.yml +33 -0
- data/vendor/rails/activerecord/test/fixtures/men.yml +5 -0
- data/vendor/rails/activerecord/test/fixtures/zines.yml +5 -0
- data/vendor/rails/activerecord/test/models/author.rb +3 -0
- data/vendor/rails/activerecord/test/models/bird.rb +6 -0
- data/vendor/rails/activerecord/test/models/company_in_module.rb +17 -0
- data/vendor/rails/activerecord/test/models/event_author.rb +5 -0
- data/vendor/rails/activerecord/test/models/face.rb +7 -0
- data/vendor/rails/activerecord/test/models/interest.rb +5 -0
- data/vendor/rails/activerecord/test/models/invoice.rb +4 -0
- data/vendor/rails/activerecord/test/models/line_item.rb +3 -0
- data/vendor/rails/activerecord/test/models/man.rb +9 -0
- data/vendor/rails/activerecord/test/models/parrot.rb +6 -0
- data/vendor/rails/activerecord/test/models/pirate.rb +10 -0
- data/vendor/rails/activerecord/test/models/ship.rb +10 -1
- data/vendor/rails/activerecord/test/models/ship_part.rb +3 -1
- data/vendor/rails/activerecord/test/models/zine.rb +3 -0
- data/vendor/rails/activerecord/test/schema/schema.rb +41 -0
- data/vendor/rails/activeresource/CHANGELOG +15 -0
- data/vendor/rails/activeresource/Rakefile +1 -1
- data/vendor/rails/activeresource/lib/active_resource/base.rb +11 -2
- data/vendor/rails/activeresource/lib/active_resource/http_mock.rb +2 -2
- data/vendor/rails/activeresource/lib/active_resource/validations.rb +3 -3
- data/vendor/rails/activeresource/lib/active_resource/version.rb +1 -1
- data/vendor/rails/activeresource/test/abstract_unit.rb +2 -2
- data/vendor/rails/activeresource/test/base_errors_test.rb +13 -0
- data/vendor/rails/activeresource/test/base_test.rb +49 -0
- data/vendor/rails/activeresource/test/debug.log +80350 -0
- data/vendor/rails/activesupport/CHANGELOG +37 -0
- data/vendor/rails/activesupport/lib/active_support.rb +1 -0
- data/vendor/rails/activesupport/lib/active_support/buffered_logger.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/cache/memory_store.rb +7 -1
- data/vendor/rails/activesupport/lib/active_support/cache/strategy/local_cache.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/array/conversions.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/array/random_access.rb +11 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/class/attribute_accessors.rb +35 -28
- data/vendor/rails/activesupport/lib/active_support/core_ext/date/calculations.rb +14 -4
- data/vendor/rails/activesupport/lib/active_support/core_ext/date_time/conversions.rb +14 -3
- data/vendor/rails/activesupport/lib/active_support/core_ext/enumerable.rb +6 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/file/atomic.rb +2 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/kernel/reporting.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/module/aliasing.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/module/attr_accessor_with_default.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/module/attribute_accessors.rb +33 -26
- data/vendor/rails/activesupport/lib/active_support/core_ext/module/synchronization.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/numeric/conversions.rb +2 -2
- data/vendor/rails/activesupport/lib/active_support/core_ext/object.rb +1 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/object/blank.rb +20 -2
- data/vendor/rails/activesupport/lib/active_support/core_ext/object/metaclass.rb +6 -5
- data/vendor/rails/activesupport/lib/active_support/core_ext/object/singleton_class.rb +13 -0
- data/vendor/rails/activesupport/lib/active_support/core_ext/string.rb +0 -1
- data/vendor/rails/activesupport/lib/active_support/core_ext/string/output_safety.rb +108 -44
- data/vendor/rails/activesupport/lib/active_support/core_ext/string/starts_ends_with.rb +2 -4
- data/vendor/rails/activesupport/lib/active_support/core_ext/time.rb +8 -4
- data/vendor/rails/activesupport/lib/active_support/core_ext/time/calculations.rb +12 -3
- data/vendor/rails/activesupport/lib/active_support/deprecation.rb +3 -2
- data/vendor/rails/activesupport/lib/active_support/inflections.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/inflector.rb +5 -2
- data/vendor/rails/activesupport/lib/active_support/json/backends/yajl.rb +40 -0
- data/vendor/rails/activesupport/lib/active_support/json/backends/yaml.rb +10 -7
- data/vendor/rails/activesupport/lib/active_support/json/decoding.rb +16 -1
- data/vendor/rails/activesupport/lib/active_support/json/encoding.rb +11 -2
- data/vendor/rails/activesupport/lib/active_support/memoizable.rb +1 -1
- data/vendor/rails/activesupport/lib/active_support/multibyte/unicode_database.rb +2 -2
- data/vendor/rails/activesupport/lib/active_support/multibyte/utils.rb +6 -7
- data/vendor/rails/activesupport/lib/active_support/ordered_hash.rb +28 -11
- data/vendor/rails/activesupport/lib/active_support/testing/assertions.rb +14 -0
- data/vendor/rails/activesupport/lib/active_support/values/time_zone.rb +84 -76
- data/vendor/rails/activesupport/lib/active_support/vendor.rb +10 -2
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.1.3/lib → i18n-0.3.7}/i18n.rb +175 -39
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend.rb +19 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/active_record.rb +66 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/active_record/missing.rb +67 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/active_record/store_procs.rb +38 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/active_record/translation.rb +88 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/base.rb +266 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/cache.rb +76 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/cascade.rb +58 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/chain.rb +75 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/cldr.rb +100 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/fallbacks.rb +69 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/fast.rb +69 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/gettext.rb +75 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/helpers.rb +68 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/interpolation_compiler.rb +119 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/links.rb +34 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/metadata.rb +73 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/pluralization.rb +57 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/backend/simple.rb +22 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/hash/except.rb +8 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/hash/slice.rb +8 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/object/meta_class.rb +5 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/core_ext/string/interpolate.rb +99 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/{i18n-0.1.3/lib → i18n-0.3.7}/i18n/exceptions.rb +15 -7
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/gettext.rb +25 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/gettext/po_parser.rb +329 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/helpers.rb +5 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/helpers/gettext.rb +65 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/locale.rb +6 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/locale/fallbacks.rb +98 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/locale/tag.rb +28 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/locale/tag/parents.rb +24 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/locale/tag/rfc4646.rb +76 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/i18n/locale/tag/simple.rb +41 -0
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.3.7/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/lib/active_support/xml_mini/libxml.rb +23 -83
- data/vendor/rails/activesupport/lib/active_support/xml_mini/libxmlsax.rb +74 -0
- data/vendor/rails/activesupport/lib/active_support/xml_mini/nokogiri.rb +25 -22
- data/vendor/rails/activesupport/lib/active_support/xml_mini/nokogirisax.rb +73 -0
- data/vendor/rails/railties/CHANGELOG +18 -2
- data/vendor/rails/railties/MIT-LICENSE +1 -1
- data/vendor/rails/railties/Rakefile +5 -5
- data/vendor/rails/railties/bin/rails +6 -5
- data/vendor/rails/railties/builtin/rails_info/rails/info.rb +1 -1
- data/vendor/rails/railties/configs/initializers/cookie_verification_secret.rb +7 -0
- data/vendor/rails/railties/guides/source/getting_started.textile +2 -2
- data/vendor/rails/railties/lib/commands/dbconsole.rb +1 -1
- data/vendor/rails/railties/lib/commands/runner.rb +1 -1
- data/vendor/rails/railties/lib/dispatcher.rb +1 -1
- data/vendor/rails/railties/lib/rails/gem_dependency.rb +11 -4
- data/vendor/rails/railties/lib/rails/vendor_gem_source_index.rb +1 -1
- data/vendor/rails/railties/lib/rails/version.rb +1 -1
- data/vendor/rails/railties/lib/rails_generator.rb +5 -2
- data/vendor/rails/railties/lib/rails_generator/generated_attribute.rb +7 -6
- data/vendor/rails/railties/lib/rails_generator/generators/applications/app/app_generator.rb +3 -0
- data/vendor/rails/railties/lib/rails_generator/generators/components/model/templates/fixtures.yml +9 -5
- data/vendor/rails/railties/lib/rails_generator/generators/components/plugin/plugin_generator.rb +2 -2
- data/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/controller.rb +2 -4
- data/vendor/rails/railties/lib/rails_generator/generators/components/scaffold/templates/layout.html.erb +1 -1
- data/vendor/rails/railties/lib/tasks/databases.rake +14 -14
- data/vendor/rails/railties/lib/tasks/framework.rake +4 -1
- data/vendor/rails/railties/lib/tasks/rails.rb +6 -1
- metadata +276 -321
- data/config/initializers/pagination.rb +0 -1
- data/vendor/extensions/markdown_filter/vendor/kramdown/doc/default.css +0 -293
- data/vendor/plugins/haml/FAQ +0 -138
- data/vendor/plugins/haml/README.rdoc +0 -319
- data/vendor/plugins/haml/REVISION +0 -1
- data/vendor/plugins/haml/lib/sass/constant.rb +0 -216
- data/vendor/plugins/haml/lib/sass/constant/color.rb +0 -101
- data/vendor/plugins/haml/lib/sass/constant/literal.rb +0 -54
- data/vendor/plugins/haml/lib/sass/constant/nil.rb +0 -9
- data/vendor/plugins/haml/lib/sass/constant/number.rb +0 -87
- data/vendor/plugins/haml/lib/sass/constant/operation.rb +0 -30
- data/vendor/plugins/haml/lib/sass/constant/string.rb +0 -22
- data/vendor/plugins/haml/lib/sass/tree/attr_node.rb +0 -57
- data/vendor/plugins/haml/lib/sass/tree/value_node.rb +0 -20
- data/vendor/plugins/haml/test/sass/results/constants.css +0 -16
- data/vendor/plugins/haml/test/sass/templates/constants.sass +0 -100
- data/vendor/radius/Manifest.txt +0 -21
- data/vendor/rails/Rakefile +0 -81
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.3/tmail/attachments.rb +0 -46
- data/vendor/rails/actionmailer/lib/action_mailer/vendor/tmail-1.2.3/tmail/parser.rb +0 -1478
- data/vendor/rails/actionmailer/pkg/actionmailer-3.0.pre.gem +0 -0
- data/vendor/rails/actionpack/lib/action_view/erb/util.rb +0 -44
- data/vendor/rails/actionpack/lib/action_view/safe_buffer.rb +0 -28
- data/vendor/rails/actionpack/pkg/actionpack-3.0.pre.gem +0 -0
- data/vendor/rails/actionpack/test/view/safe_buffer_test.rb +0 -36
- data/vendor/rails/activemodel/CHANGES +0 -12
- data/vendor/rails/activemodel/README +0 -21
- data/vendor/rails/activemodel/Rakefile +0 -24
- data/vendor/rails/activemodel/lib/active_model.rb +0 -5
- data/vendor/rails/activemodel/lib/active_model/base.rb +0 -8
- data/vendor/rails/activemodel/lib/active_model/callbacks.rb +0 -7
- data/vendor/rails/activemodel/lib/active_model/core.rb +0 -7
- data/vendor/rails/activemodel/lib/active_model/deprecated_error_methods.rb +0 -38
- data/vendor/rails/activemodel/lib/active_model/errors.rb +0 -82
- data/vendor/rails/activemodel/lib/active_model/observing.rb +0 -98
- data/vendor/rails/activemodel/lib/active_model/state_machine.rb +0 -68
- data/vendor/rails/activemodel/lib/active_model/state_machine/event.rb +0 -64
- data/vendor/rails/activemodel/lib/active_model/state_machine/machine.rb +0 -78
- data/vendor/rails/activemodel/lib/active_model/state_machine/state.rb +0 -47
- data/vendor/rails/activemodel/lib/active_model/state_machine/state_transition.rb +0 -40
- data/vendor/rails/activemodel/lib/active_model/validations.rb +0 -126
- data/vendor/rails/activemodel/lib/active_model/validations/acceptance.rb +0 -45
- data/vendor/rails/activemodel/lib/active_model/validations/associated.rb +0 -46
- data/vendor/rails/activemodel/lib/active_model/validations/confirmation.rb +0 -44
- data/vendor/rails/activemodel/lib/active_model/validations/exclusion.rb +0 -37
- data/vendor/rails/activemodel/lib/active_model/validations/format.rb +0 -39
- data/vendor/rails/activemodel/lib/active_model/validations/inclusion.rb +0 -37
- data/vendor/rails/activemodel/lib/active_model/validations/length.rb +0 -95
- data/vendor/rails/activemodel/lib/active_model/validations/numericality.rb +0 -80
- data/vendor/rails/activemodel/lib/active_model/validations/presence.rb +0 -42
- data/vendor/rails/activemodel/lib/active_model/validations/uniqueness.rb +0 -104
- data/vendor/rails/activemodel/pkg/activemodel-3.0.pre.gem +0 -0
- data/vendor/rails/activemodel/test/observing_test.rb +0 -121
- data/vendor/rails/activemodel/test/state_machine/event_test.rb +0 -49
- data/vendor/rails/activemodel/test/state_machine/machine_test.rb +0 -43
- data/vendor/rails/activemodel/test/state_machine/state_test.rb +0 -72
- data/vendor/rails/activemodel/test/state_machine/state_transition_test.rb +0 -84
- data/vendor/rails/activemodel/test/state_machine_test.rb +0 -312
- data/vendor/rails/activemodel/test/test_helper.rb +0 -21
- data/vendor/rails/activerecord/MIT-LICENSE +0 -20
- data/vendor/rails/activerecord/lib/active_record/i18n_interpolation_deprecation.rb +0 -26
- data/vendor/rails/activerecord/pkg/activerecord-3.0.pre.gem +0 -0
- data/vendor/rails/activeresource/MIT-LICENSE +0 -20
- data/vendor/rails/activeresource/pkg/activeresource-3.0.pre.gem +0 -0
- data/vendor/rails/activesupport/MIT-LICENSE +0 -20
- data/vendor/rails/activesupport/Rakefile +0 -175
- data/vendor/rails/activesupport/bin/generate_tables +0 -147
- data/vendor/rails/activesupport/install.rb +0 -30
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/MIT-LICENSE +0 -20
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/README.textile +0 -20
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/Rakefile +0 -5
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/i18n.gemspec +0 -27
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/lib/i18n/backend/simple.rb +0 -214
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/test/all.rb +0 -5
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/test/i18n_exceptions_test.rb +0 -99
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/test/i18n_test.rb +0 -124
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/test/locale/en.rb +0 -1
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/test/locale/en.yml +0 -3
- data/vendor/rails/activesupport/lib/active_support/vendor/i18n-0.1.3/test/simple_backend_test.rb +0 -567
- data/vendor/rails/activesupport/pkg/activesupport-3.0.pre.gem +0 -0
- data/vendor/rails/activesupport/test/abstract_unit.rb +0 -36
- data/vendor/rails/activesupport/test/autoloading_fixtures/a/b.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/a/c/d.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/a/c/e/f.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/application.rb +0 -1
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder.rb +0 -3
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder/class_folder_subclass.rb +0 -3
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder/inline_class.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/class_folder/nested_class.rb +0 -7
- data/vendor/rails/activesupport/test/autoloading_fixtures/conflict.rb +0 -1
- data/vendor/rails/activesupport/test/autoloading_fixtures/counting_loader.rb +0 -5
- data/vendor/rails/activesupport/test/autoloading_fixtures/cross_site_dependency.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/e.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_folder/inline_class.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_folder/nested_class.rb +0 -4
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_folder/nested_sibling.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/module_with_custom_const_missing/a/b.rb +0 -1
- data/vendor/rails/activesupport/test/autoloading_fixtures/multiple_constant_file.rb +0 -2
- data/vendor/rails/activesupport/test/autoloading_fixtures/raises_name_error.rb +0 -3
- data/vendor/rails/activesupport/test/autoloading_fixtures/raises_no_method_error.rb +0 -3
- data/vendor/rails/activesupport/test/buffered_logger_test.rb +0 -146
- data/vendor/rails/activesupport/test/caching_test.rb +0 -348
- data/vendor/rails/activesupport/test/callbacks_test.rb +0 -188
- data/vendor/rails/activesupport/test/clean_backtrace_test.rb +0 -47
- data/vendor/rails/activesupport/test/clean_logger_test.rb +0 -57
- data/vendor/rails/activesupport/test/core_ext/array_ext_test.rb +0 -363
- data/vendor/rails/activesupport/test/core_ext/base64_ext_test.rb +0 -8
- data/vendor/rails/activesupport/test/core_ext/bigdecimal.rb +0 -10
- data/vendor/rails/activesupport/test/core_ext/blank_test.rb +0 -24
- data/vendor/rails/activesupport/test/core_ext/cgi_ext_test.rb +0 -14
- data/vendor/rails/activesupport/test/core_ext/class/attribute_accessor_test.rb +0 -31
- data/vendor/rails/activesupport/test/core_ext/class/class_inheritable_attributes_test.rb +0 -224
- data/vendor/rails/activesupport/test/core_ext/class/delegating_attributes_test.rb +0 -115
- data/vendor/rails/activesupport/test/core_ext/class_test.rb +0 -46
- data/vendor/rails/activesupport/test/core_ext/date_ext_test.rb +0 -278
- data/vendor/rails/activesupport/test/core_ext/date_time_ext_test.rb +0 -359
- data/vendor/rails/activesupport/test/core_ext/duplicable_test.rb +0 -22
- data/vendor/rails/activesupport/test/core_ext/duration_test.rb +0 -121
- data/vendor/rails/activesupport/test/core_ext/enumerable_test.rb +0 -97
- data/vendor/rails/activesupport/test/core_ext/exception_test.rb +0 -68
- data/vendor/rails/activesupport/test/core_ext/file_test.rb +0 -67
- data/vendor/rails/activesupport/test/core_ext/float_ext_test.rb +0 -25
- data/vendor/rails/activesupport/test/core_ext/hash_ext_test.rb +0 -1014
- data/vendor/rails/activesupport/test/core_ext/integer_ext_test.rb +0 -37
- data/vendor/rails/activesupport/test/core_ext/kernel_test.rb +0 -43
- data/vendor/rails/activesupport/test/core_ext/load_error_test.rb +0 -16
- data/vendor/rails/activesupport/test/core_ext/module/attr_accessor_with_default_test.rb +0 -30
- data/vendor/rails/activesupport/test/core_ext/module/attr_internal_test.rb +0 -52
- data/vendor/rails/activesupport/test/core_ext/module/attribute_accessor_test.rb +0 -33
- data/vendor/rails/activesupport/test/core_ext/module/attribute_aliasing_test.rb +0 -58
- data/vendor/rails/activesupport/test/core_ext/module/model_naming_test.rb +0 -27
- data/vendor/rails/activesupport/test/core_ext/module/synchronization_test.rb +0 -85
- data/vendor/rails/activesupport/test/core_ext/module_test.rb +0 -363
- data/vendor/rails/activesupport/test/core_ext/name_error_test.rb +0 -20
- data/vendor/rails/activesupport/test/core_ext/numeric_ext_test.rb +0 -162
- data/vendor/rails/activesupport/test/core_ext/object_and_class_ext_test.rb +0 -282
- data/vendor/rails/activesupport/test/core_ext/object_ext_test.rb +0 -8
- data/vendor/rails/activesupport/test/core_ext/pathname_test.rb +0 -9
- data/vendor/rails/activesupport/test/core_ext/proc_test.rb +0 -11
- data/vendor/rails/activesupport/test/core_ext/range_ext_test.rb +0 -63
- data/vendor/rails/activesupport/test/core_ext/string_ext_test.rb +0 -369
- data/vendor/rails/activesupport/test/core_ext/symbol_test.rb +0 -9
- data/vendor/rails/activesupport/test/core_ext/time_ext_test.rb +0 -744
- data/vendor/rails/activesupport/test/core_ext/time_with_zone_test.rb +0 -845
- data/vendor/rails/activesupport/test/core_ext/uri_ext_test.rb +0 -12
- data/vendor/rails/activesupport/test/dependencies/check_warnings.rb +0 -2
- data/vendor/rails/activesupport/test/dependencies/conflict.rb +0 -1
- data/vendor/rails/activesupport/test/dependencies/cross_site_depender.rb +0 -3
- data/vendor/rails/activesupport/test/dependencies/mutual_one.rb +0 -4
- data/vendor/rails/activesupport/test/dependencies/mutual_two.rb +0 -4
- data/vendor/rails/activesupport/test/dependencies/raises_exception.rb +0 -3
- data/vendor/rails/activesupport/test/dependencies/requires_nonexistent0.rb +0 -1
- data/vendor/rails/activesupport/test/dependencies/requires_nonexistent1.rb +0 -1
- data/vendor/rails/activesupport/test/dependencies/service_one.rb +0 -5
- data/vendor/rails/activesupport/test/dependencies/service_two.rb +0 -2
- data/vendor/rails/activesupport/test/dependencies_test.rb +0 -782
- data/vendor/rails/activesupport/test/deprecation_test.rb +0 -167
- data/vendor/rails/activesupport/test/flush_cache_on_private_memoization_test.rb +0 -43
- data/vendor/rails/activesupport/test/gzip_test.rb +0 -7
- data/vendor/rails/activesupport/test/i18n_test.rb +0 -98
- data/vendor/rails/activesupport/test/inflector_test.rb +0 -298
- data/vendor/rails/activesupport/test/inflector_test_cases.rb +0 -252
- data/vendor/rails/activesupport/test/json/decoding_test.rb +0 -73
- data/vendor/rails/activesupport/test/json/encoding_test.rb +0 -160
- data/vendor/rails/activesupport/test/memoizable_test.rb +0 -247
- data/vendor/rails/activesupport/test/message_encryptor_test.rb +0 -46
- data/vendor/rails/activesupport/test/message_verifier_test.rb +0 -31
- data/vendor/rails/activesupport/test/multibyte_chars_test.rb +0 -606
- data/vendor/rails/activesupport/test/multibyte_conformance.rb +0 -129
- data/vendor/rails/activesupport/test/multibyte_test_helpers.rb +0 -19
- data/vendor/rails/activesupport/test/multibyte_unicode_database_test.rb +0 -22
- data/vendor/rails/activesupport/test/multibyte_utils_test.rb +0 -137
- data/vendor/rails/activesupport/test/option_merger_test.rb +0 -85
- data/vendor/rails/activesupport/test/ordered_hash_test.rb +0 -201
- data/vendor/rails/activesupport/test/ordered_options_test.rb +0 -53
- data/vendor/rails/activesupport/test/rescuable_test.rb +0 -75
- data/vendor/rails/activesupport/test/secure_random_test.rb +0 -19
- data/vendor/rails/activesupport/test/string_inquirer_test.rb +0 -15
- data/vendor/rails/activesupport/test/test_test.rb +0 -148
- data/vendor/rails/activesupport/test/time_zone_test.rb +0 -266
- data/vendor/rails/activesupport/test/whiny_nil_test.rb +0 -50
- data/vendor/rails/activesupport/test/xml_mini/jdom_engine_test.rb +0 -153
- data/vendor/rails/activesupport/test/xml_mini/nokogiri_engine_test.rb +0 -168
- data/vendor/rails/activesupport/test/xml_mini/rexml_engine_test.rb +0 -15
- data/vendor/rails/ci/ci_build.rb +0 -119
- data/vendor/rails/ci/ci_setup_notes.txt +0 -131
- data/vendor/rails/ci/cruise_config.rb +0 -9
- data/vendor/rails/ci/geminstaller.yml +0 -24
- data/vendor/rails/ci/site.css +0 -13
- data/vendor/rails/ci/site_config.rb +0 -72
- data/vendor/rails/doc/template/horo.rb +0 -613
- data/vendor/rails/pushgems.rb +0 -14
- data/vendor/rails/railties/pkg/railties-3.0.pre.gem +0 -0
- data/vendor/rails/railties/test/abstract_unit.rb +0 -27
- data/vendor/rails/railties/test/backtrace_cleaner_test.rb +0 -61
- data/vendor/rails/railties/test/boot_test.rb +0 -178
- data/vendor/rails/railties/test/console_app_test.rb +0 -42
- data/vendor/rails/railties/test/fcgi_dispatcher_test.rb +0 -266
- data/vendor/rails/railties/test/fixtures/about_yml_plugins/bad_about_yml/about.yml +0 -1
- data/vendor/rails/railties/test/fixtures/about_yml_plugins/bad_about_yml/init.rb +0 -1
- data/vendor/rails/railties/test/fixtures/about_yml_plugins/plugin_without_about_yml/init.rb +0 -1
- data/vendor/rails/railties/test/fixtures/eager/zoo.rb +0 -3
- data/vendor/rails/railties/test/fixtures/eager/zoo/reptile_house.rb +0 -2
- data/vendor/rails/railties/test/fixtures/environment_with_constant.rb +0 -1
- 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 +0 -2
- data/vendor/rails/railties/test/fixtures/metal/multiplemetals/app/metal/metal_a.rb +0 -5
- data/vendor/rails/railties/test/fixtures/metal/multiplemetals/app/metal/metal_b.rb +0 -5
- data/vendor/rails/railties/test/fixtures/metal/pluralmetal/app/metal/legacy_routes.rb +0 -5
- data/vendor/rails/railties/test/fixtures/metal/singlemetal/app/metal/foo_metal.rb +0 -5
- data/vendor/rails/railties/test/fixtures/metal/subfolders/app/metal/Folder/metal_a.rb +0 -7
- data/vendor/rails/railties/test/fixtures/metal/subfolders/app/metal/Folder/metal_b.rb +0 -7
- data/vendor/rails/railties/test/fixtures/plugins/alternate/a/generators/a_generator/a_generator.rb +0 -4
- data/vendor/rails/railties/test/fixtures/plugins/default/gemlike/init.rb +0 -1
- data/vendor/rails/railties/test/fixtures/plugins/default/gemlike/lib/gemlike.rb +0 -2
- data/vendor/rails/railties/test/fixtures/plugins/default/gemlike/rails/init.rb +0 -7
- 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 +0 -2
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/generators/stubby_generator/stubby_generator.rb +0 -4
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/init.rb +0 -7
- data/vendor/rails/railties/test/fixtures/plugins/default/stubby/lib/stubby_mixin.rb +0 -2
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/app/controllers/engine_controller.rb +0 -2
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/app/metal/engine_metal.rb +0 -10
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/app/models/engine_model.rb +0 -2
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/config/locales/en.yml +0 -2
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/config/routes.rb +0 -3
- data/vendor/rails/railties/test/fixtures/plugins/engines/engine/init.rb +0 -3
- data/vendor/rails/railties/test/fixtures/public/foo/bar.html +0 -1
- data/vendor/rails/railties/test/fixtures/public/foo/index.html +0 -1
- data/vendor/rails/railties/test/fixtures/public/index.html +0 -1
- data/vendor/rails/railties/test/gem_dependency_test.rb +0 -219
- data/vendor/rails/railties/test/generator_lookup_test.rb +0 -40
- data/vendor/rails/railties/test/generators/generator_test_helper.rb +0 -310
- data/vendor/rails/railties/test/generators/rails_controller_generator_test.rb +0 -44
- data/vendor/rails/railties/test/generators/rails_helper_generator_test.rb +0 -36
- data/vendor/rails/railties/test/generators/rails_mailer_generator_test.rb +0 -29
- data/vendor/rails/railties/test/generators/rails_model_generator_test.rb +0 -96
- data/vendor/rails/railties/test/generators/rails_resource_generator_test.rb +0 -29
- data/vendor/rails/railties/test/generators/rails_scaffold_generator_test.rb +0 -151
- data/vendor/rails/railties/test/generators/rails_template_runner_test.rb +0 -216
- data/vendor/rails/railties/test/initializer_test.rb +0 -416
- data/vendor/rails/railties/test/metal_test.rb +0 -72
- data/vendor/rails/railties/test/mocks/routes.rb +0 -6
- data/vendor/rails/railties/test/plugin_loader_test.rb +0 -172
- data/vendor/rails/railties/test/plugin_locator_test.rb +0 -62
- data/vendor/rails/railties/test/plugin_test.rb +0 -162
- data/vendor/rails/railties/test/plugin_test_helper.rb +0 -29
- data/vendor/rails/railties/test/rack_static_test.rb +0 -46
- data/vendor/rails/railties/test/rails_generator_test.rb +0 -145
- data/vendor/rails/railties/test/rails_info_controller_test.rb +0 -52
- data/vendor/rails/railties/test/rails_info_test.rb +0 -99
- data/vendor/rails/railties/test/secret_key_generation_test.rb +0 -38
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-a-0.4.0/lib/dummy-gem-a.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-b-0.4.0/lib/dummy-gem-b.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-b-0.6.0/lib/dummy-gem-b.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-c-0.4.0/lib/dummy-gem-c.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-c-0.6.0/lib/dummy-gem-c.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-d-1.0.0/lib/dummy-gem-d.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-e-1.0.0/lib/dummy-gem-e.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-f-1.0.0/lib/dummy-gem-f.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-g-1.0.0/lib/dummy-gem-g.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-h-1.0.0/lib/dummy-gem-h.rb +0 -1
- 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 +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-j-1.0.0/lib/dummy-gem-j.rb +0 -1
- data/vendor/rails/railties/test/vendor/gems/dummy-gem-k-1.0.0/lib/dummy-gem-k.rb +0 -1
- data/vendor/rails/release.rb +0 -25
@@ -1,247 +0,0 @@
|
|
1
|
-
require 'abstract_unit'
|
2
|
-
|
3
|
-
class MemoizableTest < Test::Unit::TestCase
|
4
|
-
class Person
|
5
|
-
extend ActiveSupport::Memoizable
|
6
|
-
|
7
|
-
attr_reader :name_calls, :age_calls, :is_developer_calls
|
8
|
-
|
9
|
-
def initialize
|
10
|
-
@name_calls = 0
|
11
|
-
@age_calls = 0
|
12
|
-
@is_developer_calls = 0
|
13
|
-
end
|
14
|
-
|
15
|
-
def name
|
16
|
-
@name_calls += 1
|
17
|
-
"Josh"
|
18
|
-
end
|
19
|
-
|
20
|
-
def name?
|
21
|
-
true
|
22
|
-
end
|
23
|
-
memoize :name?
|
24
|
-
|
25
|
-
def update(name)
|
26
|
-
"Joshua"
|
27
|
-
end
|
28
|
-
memoize :update
|
29
|
-
|
30
|
-
def age
|
31
|
-
@age_calls += 1
|
32
|
-
nil
|
33
|
-
end
|
34
|
-
|
35
|
-
memoize :name, :age
|
36
|
-
|
37
|
-
private
|
38
|
-
|
39
|
-
def is_developer?
|
40
|
-
@is_developer_calls += 1
|
41
|
-
"Yes"
|
42
|
-
end
|
43
|
-
memoize :is_developer?
|
44
|
-
end
|
45
|
-
|
46
|
-
class Company
|
47
|
-
attr_reader :name_calls
|
48
|
-
def initialize
|
49
|
-
@name_calls = 0
|
50
|
-
end
|
51
|
-
|
52
|
-
def name
|
53
|
-
@name_calls += 1
|
54
|
-
"37signals"
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
module Rates
|
59
|
-
extend ActiveSupport::Memoizable
|
60
|
-
|
61
|
-
attr_reader :sales_tax_calls
|
62
|
-
def sales_tax(price)
|
63
|
-
@sales_tax_calls ||= 0
|
64
|
-
@sales_tax_calls += 1
|
65
|
-
price * 0.1025
|
66
|
-
end
|
67
|
-
memoize :sales_tax
|
68
|
-
end
|
69
|
-
|
70
|
-
class Calculator
|
71
|
-
extend ActiveSupport::Memoizable
|
72
|
-
include Rates
|
73
|
-
|
74
|
-
attr_reader :fib_calls
|
75
|
-
def initialize
|
76
|
-
@fib_calls = 0
|
77
|
-
end
|
78
|
-
|
79
|
-
def fib(n)
|
80
|
-
@fib_calls += 1
|
81
|
-
|
82
|
-
if n == 0 || n == 1
|
83
|
-
n
|
84
|
-
else
|
85
|
-
fib(n - 1) + fib(n - 2)
|
86
|
-
end
|
87
|
-
end
|
88
|
-
memoize :fib
|
89
|
-
|
90
|
-
def counter
|
91
|
-
@count ||= 0
|
92
|
-
@count += 1
|
93
|
-
end
|
94
|
-
memoize :counter
|
95
|
-
end
|
96
|
-
|
97
|
-
def setup
|
98
|
-
@person = Person.new
|
99
|
-
@calculator = Calculator.new
|
100
|
-
end
|
101
|
-
|
102
|
-
def test_memoization
|
103
|
-
assert_equal "Josh", @person.name
|
104
|
-
assert_equal 1, @person.name_calls
|
105
|
-
|
106
|
-
3.times { assert_equal "Josh", @person.name }
|
107
|
-
assert_equal 1, @person.name_calls
|
108
|
-
end
|
109
|
-
|
110
|
-
def test_memoization_with_punctuation
|
111
|
-
assert_equal true, @person.name?
|
112
|
-
|
113
|
-
assert_nothing_raised(NameError) do
|
114
|
-
@person.memoize_all
|
115
|
-
@person.unmemoize_all
|
116
|
-
end
|
117
|
-
end
|
118
|
-
|
119
|
-
def test_memoization_with_nil_value
|
120
|
-
assert_equal nil, @person.age
|
121
|
-
assert_equal 1, @person.age_calls
|
122
|
-
|
123
|
-
3.times { assert_equal nil, @person.age }
|
124
|
-
assert_equal 1, @person.age_calls
|
125
|
-
end
|
126
|
-
|
127
|
-
def test_memorized_results_are_immutable
|
128
|
-
assert_equal "Josh", @person.name
|
129
|
-
assert_raise(ActiveSupport::FrozenObjectError) { @person.name.gsub!("Josh", "Gosh") }
|
130
|
-
end
|
131
|
-
|
132
|
-
def test_reloadable
|
133
|
-
counter = @calculator.counter
|
134
|
-
assert_equal 1, @calculator.counter
|
135
|
-
assert_equal 2, @calculator.counter(:reload)
|
136
|
-
assert_equal 2, @calculator.counter
|
137
|
-
assert_equal 3, @calculator.counter(true)
|
138
|
-
assert_equal 3, @calculator.counter
|
139
|
-
end
|
140
|
-
|
141
|
-
def test_flush_cache
|
142
|
-
assert_equal 1, @calculator.counter
|
143
|
-
|
144
|
-
assert @calculator.instance_variable_get(:@_memoized_counter).any?
|
145
|
-
@calculator.flush_cache(:counter)
|
146
|
-
assert @calculator.instance_variable_get(:@_memoized_counter).empty?
|
147
|
-
|
148
|
-
assert_equal 2, @calculator.counter
|
149
|
-
end
|
150
|
-
|
151
|
-
def test_unmemoize_all
|
152
|
-
assert_equal 1, @calculator.counter
|
153
|
-
|
154
|
-
assert @calculator.instance_variable_get(:@_memoized_counter).any?
|
155
|
-
@calculator.unmemoize_all
|
156
|
-
assert @calculator.instance_variable_get(:@_memoized_counter).empty?
|
157
|
-
|
158
|
-
assert_equal 2, @calculator.counter
|
159
|
-
end
|
160
|
-
|
161
|
-
def test_memoize_all
|
162
|
-
@calculator.memoize_all
|
163
|
-
assert @calculator.instance_variable_defined?(:@_memoized_counter)
|
164
|
-
end
|
165
|
-
|
166
|
-
def test_memoization_cache_is_different_for_each_instance
|
167
|
-
assert_equal 1, @calculator.counter
|
168
|
-
assert_equal 2, @calculator.counter(:reload)
|
169
|
-
assert_equal 1, Calculator.new.counter
|
170
|
-
end
|
171
|
-
|
172
|
-
def test_memoized_is_not_affected_by_freeze
|
173
|
-
@person.freeze
|
174
|
-
assert_equal "Josh", @person.name
|
175
|
-
assert_equal "Joshua", @person.update("Joshua")
|
176
|
-
end
|
177
|
-
|
178
|
-
def test_memoization_with_args
|
179
|
-
assert_equal 55, @calculator.fib(10)
|
180
|
-
assert_equal 11, @calculator.fib_calls
|
181
|
-
end
|
182
|
-
|
183
|
-
def test_reloadable_with_args
|
184
|
-
assert_equal 55, @calculator.fib(10)
|
185
|
-
assert_equal 11, @calculator.fib_calls
|
186
|
-
assert_equal 55, @calculator.fib(10, :reload)
|
187
|
-
assert_equal 12, @calculator.fib_calls
|
188
|
-
assert_equal 55, @calculator.fib(10, true)
|
189
|
-
assert_equal 13, @calculator.fib_calls
|
190
|
-
end
|
191
|
-
|
192
|
-
def test_object_memoization
|
193
|
-
[Company.new, Company.new, Company.new].each do |company|
|
194
|
-
company.extend ActiveSupport::Memoizable
|
195
|
-
company.memoize :name
|
196
|
-
|
197
|
-
assert_equal "37signals", company.name
|
198
|
-
assert_equal 1, company.name_calls
|
199
|
-
assert_equal "37signals", company.name
|
200
|
-
assert_equal 1, company.name_calls
|
201
|
-
end
|
202
|
-
end
|
203
|
-
|
204
|
-
def test_memoized_module_methods
|
205
|
-
assert_equal 1.025, @calculator.sales_tax(10)
|
206
|
-
assert_equal 1, @calculator.sales_tax_calls
|
207
|
-
assert_equal 1.025, @calculator.sales_tax(10)
|
208
|
-
assert_equal 1, @calculator.sales_tax_calls
|
209
|
-
assert_equal 2.5625, @calculator.sales_tax(25)
|
210
|
-
assert_equal 2, @calculator.sales_tax_calls
|
211
|
-
end
|
212
|
-
|
213
|
-
def test_object_memoized_module_methods
|
214
|
-
company = Company.new
|
215
|
-
company.extend(Rates)
|
216
|
-
|
217
|
-
assert_equal 1.025, company.sales_tax(10)
|
218
|
-
assert_equal 1, company.sales_tax_calls
|
219
|
-
assert_equal 1.025, company.sales_tax(10)
|
220
|
-
assert_equal 1, company.sales_tax_calls
|
221
|
-
assert_equal 2.5625, company.sales_tax(25)
|
222
|
-
assert_equal 2, company.sales_tax_calls
|
223
|
-
end
|
224
|
-
|
225
|
-
def test_double_memoization
|
226
|
-
assert_raise(RuntimeError) { Person.memoize :name }
|
227
|
-
person = Person.new
|
228
|
-
person.extend ActiveSupport::Memoizable
|
229
|
-
assert_raise(RuntimeError) { person.memoize :name }
|
230
|
-
|
231
|
-
company = Company.new
|
232
|
-
company.extend ActiveSupport::Memoizable
|
233
|
-
company.memoize :name
|
234
|
-
assert_raise(RuntimeError) { company.memoize :name }
|
235
|
-
end
|
236
|
-
|
237
|
-
def test_private_method_memoization
|
238
|
-
person = Person.new
|
239
|
-
|
240
|
-
assert_raise(NoMethodError) { person.is_developer? }
|
241
|
-
assert_equal "Yes", person.send(:is_developer?)
|
242
|
-
assert_equal 1, person.is_developer_calls
|
243
|
-
assert_equal "Yes", person.send(:is_developer?)
|
244
|
-
assert_equal 1, person.is_developer_calls
|
245
|
-
end
|
246
|
-
|
247
|
-
end
|
@@ -1,46 +0,0 @@
|
|
1
|
-
require 'abstract_unit'
|
2
|
-
|
3
|
-
class MessageEncryptorTest < Test::Unit::TestCase
|
4
|
-
def setup
|
5
|
-
@encryptor = ActiveSupport::MessageEncryptor.new(ActiveSupport::SecureRandom.hex(64))
|
6
|
-
@data = {:some=>"data", :now=>Time.now}
|
7
|
-
end
|
8
|
-
|
9
|
-
def test_simple_round_tripping
|
10
|
-
message = @encryptor.encrypt(@data)
|
11
|
-
assert_equal @data, @encryptor.decrypt(message)
|
12
|
-
end
|
13
|
-
|
14
|
-
def test_encrypting_twice_yields_differing_cipher_text
|
15
|
-
first_messqage = @encryptor.encrypt(@data)
|
16
|
-
second_message = @encryptor.encrypt(@data)
|
17
|
-
assert_not_equal first_messqage, second_message
|
18
|
-
end
|
19
|
-
|
20
|
-
def test_messing_with_either_value_causes_failure
|
21
|
-
text, iv = @encryptor.encrypt(@data).split("--")
|
22
|
-
assert_not_decrypted([iv, text] * "--")
|
23
|
-
assert_not_decrypted([text, munge(iv)] * "--")
|
24
|
-
assert_not_decrypted([munge(text), iv] * "--")
|
25
|
-
assert_not_decrypted([munge(text), munge(iv)] * "--")
|
26
|
-
end
|
27
|
-
|
28
|
-
def test_signed_round_tripping
|
29
|
-
message = @encryptor.encrypt_and_sign(@data)
|
30
|
-
assert_equal @data, @encryptor.decrypt_and_verify(message)
|
31
|
-
end
|
32
|
-
|
33
|
-
|
34
|
-
private
|
35
|
-
def assert_not_decrypted(value)
|
36
|
-
assert_raise(ActiveSupport::MessageEncryptor::InvalidMessage) do
|
37
|
-
@encryptor.decrypt(value)
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
def munge(base64_string)
|
42
|
-
bits = ActiveSupport::Base64.decode64(base64_string)
|
43
|
-
bits.reverse!
|
44
|
-
ActiveSupport::Base64.encode64s(bits)
|
45
|
-
end
|
46
|
-
end
|
@@ -1,31 +0,0 @@
|
|
1
|
-
require 'abstract_unit'
|
2
|
-
|
3
|
-
class MessageVerifierTest < Test::Unit::TestCase
|
4
|
-
def setup
|
5
|
-
@verifier = ActiveSupport::MessageVerifier.new("Hey, I'm a secret!")
|
6
|
-
@data = {:some=>"data", :now=>Time.now}
|
7
|
-
end
|
8
|
-
|
9
|
-
def test_simple_round_tripping
|
10
|
-
message = @verifier.generate(@data)
|
11
|
-
assert_equal @data, @verifier.verify(message)
|
12
|
-
end
|
13
|
-
|
14
|
-
def test_missing_signature_raises
|
15
|
-
assert_not_verified(nil)
|
16
|
-
assert_not_verified("")
|
17
|
-
end
|
18
|
-
|
19
|
-
def test_tampered_data_raises
|
20
|
-
data, hash = @verifier.generate(@data).split("--")
|
21
|
-
assert_not_verified("#{data.reverse}--#{hash}")
|
22
|
-
assert_not_verified("#{data}--#{hash.reverse}")
|
23
|
-
assert_not_verified("purejunk")
|
24
|
-
end
|
25
|
-
|
26
|
-
def assert_not_verified(message)
|
27
|
-
assert_raise(ActiveSupport::MessageVerifier::InvalidSignature) do
|
28
|
-
@verifier.verify(message)
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
@@ -1,606 +0,0 @@
|
|
1
|
-
# encoding: utf-8
|
2
|
-
|
3
|
-
require 'abstract_unit'
|
4
|
-
require 'multibyte_test_helpers'
|
5
|
-
|
6
|
-
class String
|
7
|
-
def __method_for_multibyte_testing_with_integer_result; 1; end
|
8
|
-
def __method_for_multibyte_testing; 'result'; end
|
9
|
-
def __method_for_multibyte_testing!; 'result'; end
|
10
|
-
end
|
11
|
-
|
12
|
-
class MultibyteCharsTest < Test::Unit::TestCase
|
13
|
-
include MultibyteTestHelpers
|
14
|
-
|
15
|
-
def setup
|
16
|
-
@proxy_class = ActiveSupport::Multibyte::Chars
|
17
|
-
@chars = @proxy_class.new UNICODE_STRING
|
18
|
-
end
|
19
|
-
|
20
|
-
def test_wraps_the_original_string
|
21
|
-
assert_equal UNICODE_STRING, @chars.to_s
|
22
|
-
assert_equal UNICODE_STRING, @chars.wrapped_string
|
23
|
-
end
|
24
|
-
|
25
|
-
def test_should_allow_method_calls_to_string
|
26
|
-
assert_nothing_raised do
|
27
|
-
@chars.__method_for_multibyte_testing
|
28
|
-
end
|
29
|
-
assert_raise NoMethodError do
|
30
|
-
@chars.__unknown_method
|
31
|
-
end
|
32
|
-
end
|
33
|
-
|
34
|
-
def test_forwarded_method_calls_should_return_new_chars_instance
|
35
|
-
assert @chars.__method_for_multibyte_testing.kind_of?(@proxy_class)
|
36
|
-
assert_not_equal @chars.object_id, @chars.__method_for_multibyte_testing.object_id
|
37
|
-
end
|
38
|
-
|
39
|
-
def test_forwarded_bang_method_calls_should_return_the_original_chars_instance
|
40
|
-
assert @chars.__method_for_multibyte_testing!.kind_of?(@proxy_class)
|
41
|
-
assert_equal @chars.object_id, @chars.__method_for_multibyte_testing!.object_id
|
42
|
-
end
|
43
|
-
|
44
|
-
def test_methods_are_forwarded_to_wrapped_string_for_byte_strings
|
45
|
-
assert_equal BYTE_STRING.class, BYTE_STRING.mb_chars.class
|
46
|
-
end
|
47
|
-
|
48
|
-
def test_forwarded_method_with_non_string_result_should_be_returned_vertabim
|
49
|
-
assert_equal ''.__method_for_multibyte_testing_with_integer_result, @chars.__method_for_multibyte_testing_with_integer_result
|
50
|
-
end
|
51
|
-
|
52
|
-
def test_should_concatenate
|
53
|
-
assert_equal 'ab', 'a'.mb_chars + 'b'
|
54
|
-
assert_equal 'ab', 'a' + 'b'.mb_chars
|
55
|
-
assert_equal 'ab', 'a'.mb_chars + 'b'.mb_chars
|
56
|
-
|
57
|
-
assert_equal 'ab', 'a'.mb_chars << 'b'
|
58
|
-
assert_equal 'ab', 'a' << 'b'.mb_chars
|
59
|
-
assert_equal 'ab', 'a'.mb_chars << 'b'.mb_chars
|
60
|
-
end
|
61
|
-
|
62
|
-
def test_consumes_utf8_strings
|
63
|
-
assert @proxy_class.consumes?(UNICODE_STRING)
|
64
|
-
assert @proxy_class.consumes?(ASCII_STRING)
|
65
|
-
assert !@proxy_class.consumes?(BYTE_STRING)
|
66
|
-
end
|
67
|
-
|
68
|
-
def test_unpack_utf8_strings
|
69
|
-
assert_equal 4, @proxy_class.u_unpack(UNICODE_STRING).length
|
70
|
-
assert_equal 5, @proxy_class.u_unpack(ASCII_STRING).length
|
71
|
-
end
|
72
|
-
|
73
|
-
def test_unpack_raises_encoding_error_on_broken_strings
|
74
|
-
assert_raise(ActiveSupport::Multibyte::EncodingError) do
|
75
|
-
@proxy_class.u_unpack(BYTE_STRING)
|
76
|
-
end
|
77
|
-
end
|
78
|
-
|
79
|
-
if RUBY_VERSION < '1.9'
|
80
|
-
def test_concatenation_should_return_a_proxy_class_instance
|
81
|
-
assert_equal ActiveSupport::Multibyte.proxy_class, ('a'.mb_chars + 'b').class
|
82
|
-
assert_equal ActiveSupport::Multibyte.proxy_class, ('a'.mb_chars << 'b').class
|
83
|
-
end
|
84
|
-
|
85
|
-
def test_ascii_strings_are_treated_at_utf8_strings
|
86
|
-
assert_equal ActiveSupport::Multibyte.proxy_class, ASCII_STRING.mb_chars.class
|
87
|
-
end
|
88
|
-
|
89
|
-
def test_concatenate_should_return_proxy_instance
|
90
|
-
assert(('a'.mb_chars + 'b').kind_of?(@proxy_class))
|
91
|
-
assert(('a'.mb_chars + 'b'.mb_chars).kind_of?(@proxy_class))
|
92
|
-
assert(('a'.mb_chars << 'b').kind_of?(@proxy_class))
|
93
|
-
assert(('a'.mb_chars << 'b'.mb_chars).kind_of?(@proxy_class))
|
94
|
-
end
|
95
|
-
end
|
96
|
-
end
|
97
|
-
|
98
|
-
class MultibyteCharsUTF8BehaviourTest < Test::Unit::TestCase
|
99
|
-
include MultibyteTestHelpers
|
100
|
-
|
101
|
-
def setup
|
102
|
-
@chars = UNICODE_STRING.dup.mb_chars
|
103
|
-
|
104
|
-
# NEWLINE, SPACE, EM SPACE
|
105
|
-
@whitespace = "\n#{[32, 8195].pack('U*')}"
|
106
|
-
|
107
|
-
# Ruby 1.9 doesn't recognize EM SPACE as whitespace!
|
108
|
-
if @whitespace.respond_to?(:force_encoding)
|
109
|
-
@whitespace.slice!(2)
|
110
|
-
@whitespace.force_encoding(Encoding::UTF_8)
|
111
|
-
end
|
112
|
-
|
113
|
-
@byte_order_mark = [65279].pack('U')
|
114
|
-
end
|
115
|
-
|
116
|
-
if RUBY_VERSION < '1.9'
|
117
|
-
def test_split_should_return_an_array_of_chars_instances
|
118
|
-
@chars.split(//).each do |character|
|
119
|
-
assert character.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
120
|
-
end
|
121
|
-
end
|
122
|
-
|
123
|
-
def test_indexed_insert_accepts_fixnums
|
124
|
-
@chars[2] = 32
|
125
|
-
assert_equal 'こに わ', @chars
|
126
|
-
end
|
127
|
-
|
128
|
-
def test_overridden_bang_methods_return_self
|
129
|
-
[:rstrip!, :lstrip!, :strip!, :reverse!, :upcase!, :downcase!, :capitalize!].each do |method|
|
130
|
-
assert_equal @chars.object_id, @chars.send(method).object_id
|
131
|
-
end
|
132
|
-
end
|
133
|
-
|
134
|
-
def test_overridden_bang_methods_change_wrapped_string
|
135
|
-
[:rstrip!, :lstrip!, :strip!, :reverse!, :upcase!, :downcase!].each do |method|
|
136
|
-
original = ' Café '
|
137
|
-
proxy = chars(original.dup)
|
138
|
-
proxy.send(method)
|
139
|
-
assert_not_equal original, proxy.to_s
|
140
|
-
end
|
141
|
-
proxy = chars('òu')
|
142
|
-
proxy.capitalize!
|
143
|
-
assert_equal 'Òu', proxy.to_s
|
144
|
-
end
|
145
|
-
end
|
146
|
-
|
147
|
-
if RUBY_VERSION >= '1.9'
|
148
|
-
def test_unicode_string_should_have_utf8_encoding
|
149
|
-
assert_equal Encoding::UTF_8, UNICODE_STRING.encoding
|
150
|
-
end
|
151
|
-
end
|
152
|
-
|
153
|
-
def test_identity
|
154
|
-
assert_equal @chars, @chars
|
155
|
-
assert @chars.eql?(@chars)
|
156
|
-
if RUBY_VERSION <= '1.9'
|
157
|
-
assert !@chars.eql?(UNICODE_STRING)
|
158
|
-
else
|
159
|
-
assert @chars.eql?(UNICODE_STRING)
|
160
|
-
end
|
161
|
-
end
|
162
|
-
|
163
|
-
def test_string_methods_are_chainable
|
164
|
-
assert chars('').insert(0, '').kind_of?(ActiveSupport::Multibyte.proxy_class)
|
165
|
-
assert chars('').rjust(1).kind_of?(ActiveSupport::Multibyte.proxy_class)
|
166
|
-
assert chars('').ljust(1).kind_of?(ActiveSupport::Multibyte.proxy_class)
|
167
|
-
assert chars('').center(1).kind_of?(ActiveSupport::Multibyte.proxy_class)
|
168
|
-
assert chars('').rstrip.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
169
|
-
assert chars('').lstrip.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
170
|
-
assert chars('').strip.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
171
|
-
assert chars('').reverse.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
172
|
-
assert chars(' ').slice(0).kind_of?(ActiveSupport::Multibyte.proxy_class)
|
173
|
-
assert chars('').upcase.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
174
|
-
assert chars('').downcase.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
175
|
-
assert chars('').capitalize.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
176
|
-
assert chars('').normalize.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
177
|
-
assert chars('').decompose.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
178
|
-
assert chars('').compose.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
179
|
-
assert chars('').tidy_bytes.kind_of?(ActiveSupport::Multibyte.proxy_class)
|
180
|
-
end
|
181
|
-
|
182
|
-
def test_should_be_equal_to_the_wrapped_string
|
183
|
-
assert_equal UNICODE_STRING, @chars
|
184
|
-
assert_equal @chars, UNICODE_STRING
|
185
|
-
end
|
186
|
-
|
187
|
-
def test_should_not_be_equal_to_an_other_string
|
188
|
-
assert_not_equal @chars, 'other'
|
189
|
-
assert_not_equal 'other', @chars
|
190
|
-
end
|
191
|
-
|
192
|
-
def test_sortability
|
193
|
-
words = %w(builder armor zebra).map(&:mb_chars).sort
|
194
|
-
assert_equal %w(armor builder zebra), words
|
195
|
-
end
|
196
|
-
|
197
|
-
def test_should_return_character_offset_for_regexp_matches
|
198
|
-
assert_nil(@chars =~ /wrong/u)
|
199
|
-
assert_equal 0, (@chars =~ /こ/u)
|
200
|
-
assert_equal 1, (@chars =~ /に/u)
|
201
|
-
assert_equal 3, (@chars =~ /わ/u)
|
202
|
-
end
|
203
|
-
|
204
|
-
def test_should_use_character_offsets_for_insert_offsets
|
205
|
-
assert_equal '', ''.mb_chars.insert(0, '')
|
206
|
-
assert_equal 'こわにちわ', @chars.insert(1, 'わ')
|
207
|
-
assert_equal 'こわわわにちわ', @chars.insert(2, 'わわ')
|
208
|
-
assert_equal 'わこわわわにちわ', @chars.insert(0, 'わ')
|
209
|
-
assert_equal 'わこわわわにちわ', @chars.wrapped_string if RUBY_VERSION < '1.9'
|
210
|
-
end
|
211
|
-
|
212
|
-
def test_insert_should_be_destructive
|
213
|
-
@chars.insert(1, 'わ')
|
214
|
-
assert_equal 'こわにちわ', @chars
|
215
|
-
end
|
216
|
-
|
217
|
-
def test_insert_throws_index_error
|
218
|
-
assert_raise(IndexError) { @chars.insert(-12, 'わ')}
|
219
|
-
assert_raise(IndexError) { @chars.insert(12, 'わ') }
|
220
|
-
end
|
221
|
-
|
222
|
-
def test_should_know_if_one_includes_the_other
|
223
|
-
assert @chars.include?('')
|
224
|
-
assert @chars.include?('ち')
|
225
|
-
assert @chars.include?('わ')
|
226
|
-
assert !@chars.include?('こちわ')
|
227
|
-
assert !@chars.include?('a')
|
228
|
-
end
|
229
|
-
|
230
|
-
def test_include_raises_type_error_when_nil_is_passed
|
231
|
-
assert_raise(TypeError) do
|
232
|
-
@chars.include?(nil)
|
233
|
-
end
|
234
|
-
end
|
235
|
-
|
236
|
-
def test_index_should_return_character_offset
|
237
|
-
assert_nil @chars.index('u')
|
238
|
-
assert_equal 0, @chars.index('こに')
|
239
|
-
assert_equal 2, @chars.index('ち')
|
240
|
-
assert_equal 2, @chars.index('ち', -2)
|
241
|
-
assert_equal nil, @chars.index('ち', -1)
|
242
|
-
assert_equal 3, @chars.index('わ')
|
243
|
-
assert_equal 5, 'ééxééx'.mb_chars.index('x', 4)
|
244
|
-
end
|
245
|
-
|
246
|
-
def test_rindex_should_return_character_offset
|
247
|
-
assert_nil @chars.rindex('u')
|
248
|
-
assert_equal 1, @chars.rindex('に')
|
249
|
-
assert_equal 2, @chars.rindex('ち', -2)
|
250
|
-
assert_nil @chars.rindex('ち', -3)
|
251
|
-
assert_equal 6, 'Café périferôl'.mb_chars.rindex('é')
|
252
|
-
assert_equal 13, 'Café périferôl'.mb_chars.rindex(/\w/u)
|
253
|
-
end
|
254
|
-
|
255
|
-
def test_indexed_insert_should_take_character_offsets
|
256
|
-
@chars[2] = 'a'
|
257
|
-
assert_equal 'こにaわ', @chars
|
258
|
-
@chars[2] = 'ηη'
|
259
|
-
assert_equal 'こにηηわ', @chars
|
260
|
-
@chars[3, 2] = 'λλλ'
|
261
|
-
assert_equal 'こにηλλλ', @chars
|
262
|
-
@chars[1, 0] = "λ"
|
263
|
-
assert_equal 'こλにηλλλ', @chars
|
264
|
-
@chars[4..6] = "ηη"
|
265
|
-
assert_equal 'こλにηηη', @chars
|
266
|
-
@chars[/ηη/] = "λλλ"
|
267
|
-
assert_equal 'こλにλλλη', @chars
|
268
|
-
@chars[/(λλ)(.)/, 2] = "α"
|
269
|
-
assert_equal 'こλにλλαη', @chars
|
270
|
-
@chars["α"] = "¢"
|
271
|
-
assert_equal 'こλにλλ¢η', @chars
|
272
|
-
@chars["λλ"] = "ααα"
|
273
|
-
assert_equal 'こλにααα¢η', @chars
|
274
|
-
end
|
275
|
-
|
276
|
-
def test_indexed_insert_should_raise_on_index_overflow
|
277
|
-
before = @chars.to_s
|
278
|
-
assert_raise(IndexError) { @chars[10] = 'a' }
|
279
|
-
assert_raise(IndexError) { @chars[10, 4] = 'a' }
|
280
|
-
assert_raise(IndexError) { @chars[/ii/] = 'a' }
|
281
|
-
assert_raise(IndexError) { @chars[/()/, 10] = 'a' }
|
282
|
-
assert_equal before, @chars
|
283
|
-
end
|
284
|
-
|
285
|
-
def test_indexed_insert_should_raise_on_range_overflow
|
286
|
-
before = @chars.to_s
|
287
|
-
assert_raise(RangeError) { @chars[10..12] = 'a' }
|
288
|
-
assert_equal before, @chars
|
289
|
-
end
|
290
|
-
|
291
|
-
def test_rjust_should_raise_argument_errors_on_bad_arguments
|
292
|
-
assert_raise(ArgumentError) { @chars.rjust(10, '') }
|
293
|
-
assert_raise(ArgumentError) { @chars.rjust }
|
294
|
-
end
|
295
|
-
|
296
|
-
def test_rjust_should_count_characters_instead_of_bytes
|
297
|
-
assert_equal UNICODE_STRING, @chars.rjust(-3)
|
298
|
-
assert_equal UNICODE_STRING, @chars.rjust(0)
|
299
|
-
assert_equal UNICODE_STRING, @chars.rjust(4)
|
300
|
-
assert_equal " #{UNICODE_STRING}", @chars.rjust(5)
|
301
|
-
assert_equal " #{UNICODE_STRING}", @chars.rjust(7)
|
302
|
-
assert_equal "---#{UNICODE_STRING}", @chars.rjust(7, '-')
|
303
|
-
assert_equal "ααα#{UNICODE_STRING}", @chars.rjust(7, 'α')
|
304
|
-
assert_equal "aba#{UNICODE_STRING}", @chars.rjust(7, 'ab')
|
305
|
-
assert_equal "αηα#{UNICODE_STRING}", @chars.rjust(7, 'αη')
|
306
|
-
assert_equal "αηαη#{UNICODE_STRING}", @chars.rjust(8, 'αη')
|
307
|
-
end
|
308
|
-
|
309
|
-
def test_ljust_should_raise_argument_errors_on_bad_arguments
|
310
|
-
assert_raise(ArgumentError) { @chars.ljust(10, '') }
|
311
|
-
assert_raise(ArgumentError) { @chars.ljust }
|
312
|
-
end
|
313
|
-
|
314
|
-
def test_ljust_should_count_characters_instead_of_bytes
|
315
|
-
assert_equal UNICODE_STRING, @chars.ljust(-3)
|
316
|
-
assert_equal UNICODE_STRING, @chars.ljust(0)
|
317
|
-
assert_equal UNICODE_STRING, @chars.ljust(4)
|
318
|
-
assert_equal "#{UNICODE_STRING} ", @chars.ljust(5)
|
319
|
-
assert_equal "#{UNICODE_STRING} ", @chars.ljust(7)
|
320
|
-
assert_equal "#{UNICODE_STRING}---", @chars.ljust(7, '-')
|
321
|
-
assert_equal "#{UNICODE_STRING}ααα", @chars.ljust(7, 'α')
|
322
|
-
assert_equal "#{UNICODE_STRING}aba", @chars.ljust(7, 'ab')
|
323
|
-
assert_equal "#{UNICODE_STRING}αηα", @chars.ljust(7, 'αη')
|
324
|
-
assert_equal "#{UNICODE_STRING}αηαη", @chars.ljust(8, 'αη')
|
325
|
-
end
|
326
|
-
|
327
|
-
def test_center_should_raise_argument_errors_on_bad_arguments
|
328
|
-
assert_raise(ArgumentError) { @chars.center(10, '') }
|
329
|
-
assert_raise(ArgumentError) { @chars.center }
|
330
|
-
end
|
331
|
-
|
332
|
-
def test_center_should_count_charactes_instead_of_bytes
|
333
|
-
assert_equal UNICODE_STRING, @chars.center(-3)
|
334
|
-
assert_equal UNICODE_STRING, @chars.center(0)
|
335
|
-
assert_equal UNICODE_STRING, @chars.center(4)
|
336
|
-
assert_equal "#{UNICODE_STRING} ", @chars.center(5)
|
337
|
-
assert_equal " #{UNICODE_STRING} ", @chars.center(6)
|
338
|
-
assert_equal " #{UNICODE_STRING} ", @chars.center(7)
|
339
|
-
assert_equal "--#{UNICODE_STRING}--", @chars.center(8, '-')
|
340
|
-
assert_equal "--#{UNICODE_STRING}---", @chars.center(9, '-')
|
341
|
-
assert_equal "αα#{UNICODE_STRING}αα", @chars.center(8, 'α')
|
342
|
-
assert_equal "αα#{UNICODE_STRING}ααα", @chars.center(9, 'α')
|
343
|
-
assert_equal "a#{UNICODE_STRING}ab", @chars.center(7, 'ab')
|
344
|
-
assert_equal "ab#{UNICODE_STRING}ab", @chars.center(8, 'ab')
|
345
|
-
assert_equal "abab#{UNICODE_STRING}abab", @chars.center(12, 'ab')
|
346
|
-
assert_equal "α#{UNICODE_STRING}αη", @chars.center(7, 'αη')
|
347
|
-
assert_equal "αη#{UNICODE_STRING}αη", @chars.center(8, 'αη')
|
348
|
-
end
|
349
|
-
|
350
|
-
def test_lstrip_strips_whitespace_from_the_left_of_the_string
|
351
|
-
assert_equal UNICODE_STRING, UNICODE_STRING.mb_chars.lstrip
|
352
|
-
assert_equal UNICODE_STRING, (@whitespace + UNICODE_STRING).mb_chars.lstrip
|
353
|
-
assert_equal UNICODE_STRING + @whitespace, (@whitespace + UNICODE_STRING + @whitespace).mb_chars.lstrip
|
354
|
-
end
|
355
|
-
|
356
|
-
def test_rstrip_strips_whitespace_from_the_right_of_the_string
|
357
|
-
assert_equal UNICODE_STRING, UNICODE_STRING.mb_chars.rstrip
|
358
|
-
assert_equal UNICODE_STRING, (UNICODE_STRING + @whitespace).mb_chars.rstrip
|
359
|
-
assert_equal @whitespace + UNICODE_STRING, (@whitespace + UNICODE_STRING + @whitespace).mb_chars.rstrip
|
360
|
-
end
|
361
|
-
|
362
|
-
def test_strip_strips_whitespace
|
363
|
-
assert_equal UNICODE_STRING, UNICODE_STRING.mb_chars.strip
|
364
|
-
assert_equal UNICODE_STRING, (@whitespace + UNICODE_STRING).mb_chars.strip
|
365
|
-
assert_equal UNICODE_STRING, (UNICODE_STRING + @whitespace).mb_chars.strip
|
366
|
-
assert_equal UNICODE_STRING, (@whitespace + UNICODE_STRING + @whitespace).mb_chars.strip
|
367
|
-
end
|
368
|
-
|
369
|
-
def test_stripping_whitespace_leaves_whitespace_within_the_string_intact
|
370
|
-
string_with_whitespace = UNICODE_STRING + @whitespace + UNICODE_STRING
|
371
|
-
assert_equal string_with_whitespace, string_with_whitespace.mb_chars.strip
|
372
|
-
assert_equal string_with_whitespace, string_with_whitespace.mb_chars.lstrip
|
373
|
-
assert_equal string_with_whitespace, string_with_whitespace.mb_chars.rstrip
|
374
|
-
end
|
375
|
-
|
376
|
-
def test_size_returns_characters_instead_of_bytes
|
377
|
-
assert_equal 0, ''.mb_chars.size
|
378
|
-
assert_equal 4, @chars.size
|
379
|
-
assert_equal 4, @chars.length
|
380
|
-
assert_equal 5, ASCII_STRING.mb_chars.size
|
381
|
-
end
|
382
|
-
|
383
|
-
def test_reverse_reverses_characters
|
384
|
-
assert_equal '', ''.mb_chars.reverse
|
385
|
-
assert_equal 'わちにこ', @chars.reverse
|
386
|
-
end
|
387
|
-
|
388
|
-
def test_reverse_should_work_with_normalized_strings
|
389
|
-
str = 'bös'
|
390
|
-
reversed_str = 'söb'
|
391
|
-
assert_equal chars(reversed_str).normalize(:kc), chars(str).normalize(:kc).reverse
|
392
|
-
assert_equal chars(reversed_str).normalize(:c), chars(str).normalize(:c).reverse
|
393
|
-
assert_equal chars(reversed_str).normalize(:d), chars(str).normalize(:d).reverse
|
394
|
-
assert_equal chars(reversed_str).normalize(:kd), chars(str).normalize(:kd).reverse
|
395
|
-
assert_equal chars(reversed_str).decompose, chars(str).decompose.reverse
|
396
|
-
assert_equal chars(reversed_str).compose, chars(str).compose.reverse
|
397
|
-
end
|
398
|
-
|
399
|
-
def test_slice_should_take_character_offsets
|
400
|
-
assert_equal nil, ''.mb_chars.slice(0)
|
401
|
-
assert_equal 'こ', @chars.slice(0)
|
402
|
-
assert_equal 'わ', @chars.slice(3)
|
403
|
-
assert_equal nil, ''.mb_chars.slice(-1..1)
|
404
|
-
assert_equal '', ''.mb_chars.slice(0..10)
|
405
|
-
assert_equal 'にちわ', @chars.slice(1..3)
|
406
|
-
assert_equal 'にちわ', @chars.slice(1, 3)
|
407
|
-
assert_equal 'こ', @chars.slice(0, 1)
|
408
|
-
assert_equal 'ちわ', @chars.slice(2..10)
|
409
|
-
assert_equal '', @chars.slice(4..10)
|
410
|
-
assert_equal 'に', @chars.slice(/に/u)
|
411
|
-
assert_equal 'にち', @chars.slice(/に./u)
|
412
|
-
assert_equal nil, @chars.slice(/unknown/u)
|
413
|
-
assert_equal 'にち', @chars.slice(/(にち)/u, 1)
|
414
|
-
assert_equal nil, @chars.slice(/(にち)/u, 2)
|
415
|
-
assert_equal nil, @chars.slice(7..6)
|
416
|
-
end
|
417
|
-
|
418
|
-
def test_slice_bang_returns_sliced_out_substring
|
419
|
-
assert_equal 'にち', @chars.slice!(1..2)
|
420
|
-
end
|
421
|
-
|
422
|
-
def test_slice_bang_removes_the_slice_from_the_receiver
|
423
|
-
@chars.slice!(1..2)
|
424
|
-
assert_equal 'こわ', @chars
|
425
|
-
end
|
426
|
-
|
427
|
-
def test_slice_should_throw_exceptions_on_invalid_arguments
|
428
|
-
assert_raise(TypeError) { @chars.slice(2..3, 1) }
|
429
|
-
assert_raise(TypeError) { @chars.slice(1, 2..3) }
|
430
|
-
assert_raise(ArgumentError) { @chars.slice(1, 1, 1) }
|
431
|
-
end
|
432
|
-
|
433
|
-
def test_ord_should_return_unicode_value_for_first_character
|
434
|
-
assert_equal 12371, @chars.ord
|
435
|
-
end
|
436
|
-
|
437
|
-
def test_upcase_should_upcase_ascii_characters
|
438
|
-
assert_equal '', ''.mb_chars.upcase
|
439
|
-
assert_equal 'ABC', 'aBc'.mb_chars.upcase
|
440
|
-
end
|
441
|
-
|
442
|
-
def test_downcase_should_downcase_ascii_characters
|
443
|
-
assert_equal '', ''.mb_chars.downcase
|
444
|
-
assert_equal 'abc', 'aBc'.mb_chars.downcase
|
445
|
-
end
|
446
|
-
|
447
|
-
def test_capitalize_should_work_on_ascii_characters
|
448
|
-
assert_equal '', ''.mb_chars.capitalize
|
449
|
-
assert_equal 'Abc', 'abc'.mb_chars.capitalize
|
450
|
-
end
|
451
|
-
|
452
|
-
def test_respond_to_knows_which_methods_the_proxy_responds_to
|
453
|
-
assert ''.mb_chars.respond_to?(:slice) # Defined on Chars
|
454
|
-
assert ''.mb_chars.respond_to?(:capitalize!) # Defined on Chars
|
455
|
-
assert ''.mb_chars.respond_to?(:gsub) # Defined on String
|
456
|
-
assert !''.mb_chars.respond_to?(:undefined_method) # Not defined
|
457
|
-
end
|
458
|
-
|
459
|
-
def test_acts_like_string
|
460
|
-
assert 'Bambi'.mb_chars.acts_like_string?
|
461
|
-
end
|
462
|
-
end
|
463
|
-
|
464
|
-
# The default Multibyte Chars proxy has more features than the normal string implementation. Tests
|
465
|
-
# for the implementation of these features should run on all Ruby versions and shouldn't be tested
|
466
|
-
# through the proxy methods.
|
467
|
-
class MultibyteCharsExtrasTest < Test::Unit::TestCase
|
468
|
-
include MultibyteTestHelpers
|
469
|
-
|
470
|
-
if RUBY_VERSION >= '1.9'
|
471
|
-
def test_tidy_bytes_is_broken_on_1_9_0
|
472
|
-
assert_raise(ArgumentError) do
|
473
|
-
assert_equal_codepoints [0xfffd].pack('U'), chars("\xef\xbf\xbd").tidy_bytes
|
474
|
-
end
|
475
|
-
end
|
476
|
-
end
|
477
|
-
|
478
|
-
def test_upcase_should_be_unicode_aware
|
479
|
-
assert_equal "АБВГД\0F", chars("аБвгд\0f").upcase
|
480
|
-
assert_equal 'こにちわ', chars('こにちわ').upcase
|
481
|
-
end
|
482
|
-
|
483
|
-
def test_downcase_should_be_unicode_aware
|
484
|
-
assert_equal "абвгд\0f", chars("аБвгд\0f").downcase
|
485
|
-
assert_equal 'こにちわ', chars('こにちわ').downcase
|
486
|
-
end
|
487
|
-
|
488
|
-
def test_capitalize_should_be_unicode_aware
|
489
|
-
{ 'аБвг аБвг' => 'Абвг абвг',
|
490
|
-
'аБвг АБВГ' => 'Абвг абвг',
|
491
|
-
'АБВГ АБВГ' => 'Абвг абвг',
|
492
|
-
'' => '' }.each do |f,t|
|
493
|
-
assert_equal t, chars(f).capitalize
|
494
|
-
end
|
495
|
-
end
|
496
|
-
|
497
|
-
def test_composition_exclusion_is_set_up_properly
|
498
|
-
# Normalization of DEVANAGARI LETTER QA breaks when composition exclusion isn't used correctly
|
499
|
-
qa = [0x915, 0x93c].pack('U*')
|
500
|
-
assert_equal qa, chars(qa).normalize(:c)
|
501
|
-
end
|
502
|
-
|
503
|
-
# Test for the Public Review Issue #29, bad explanation of composition might lead to a
|
504
|
-
# bad implementation: http://www.unicode.org/review/pr-29.html
|
505
|
-
def test_normalization_C_pri_29
|
506
|
-
[
|
507
|
-
[0x0B47, 0x0300, 0x0B3E],
|
508
|
-
[0x1100, 0x0300, 0x1161]
|
509
|
-
].map { |c| c.pack('U*') }.each do |c|
|
510
|
-
assert_equal_codepoints c, chars(c).normalize(:c)
|
511
|
-
end
|
512
|
-
end
|
513
|
-
|
514
|
-
def test_normalization_shouldnt_strip_null_bytes
|
515
|
-
null_byte_str = "Test\0test"
|
516
|
-
|
517
|
-
assert_equal null_byte_str, chars(null_byte_str).normalize(:kc)
|
518
|
-
assert_equal null_byte_str, chars(null_byte_str).normalize(:c)
|
519
|
-
assert_equal null_byte_str, chars(null_byte_str).normalize(:d)
|
520
|
-
assert_equal null_byte_str, chars(null_byte_str).normalize(:kd)
|
521
|
-
assert_equal null_byte_str, chars(null_byte_str).decompose
|
522
|
-
assert_equal null_byte_str, chars(null_byte_str).compose
|
523
|
-
end
|
524
|
-
|
525
|
-
def test_simple_normalization
|
526
|
-
comp_str = [
|
527
|
-
44, # LATIN CAPITAL LETTER D
|
528
|
-
307, # COMBINING DOT ABOVE
|
529
|
-
328, # COMBINING OGONEK
|
530
|
-
323 # COMBINING DOT BELOW
|
531
|
-
].pack("U*")
|
532
|
-
|
533
|
-
assert_equal_codepoints '', chars('').normalize
|
534
|
-
assert_equal_codepoints [44,105,106,328,323].pack("U*"), chars(comp_str).normalize(:kc).to_s
|
535
|
-
assert_equal_codepoints [44,307,328,323].pack("U*"), chars(comp_str).normalize(:c).to_s
|
536
|
-
assert_equal_codepoints [44,307,110,780,78,769].pack("U*"), chars(comp_str).normalize(:d).to_s
|
537
|
-
assert_equal_codepoints [44,105,106,110,780,78,769].pack("U*"), chars(comp_str).normalize(:kd).to_s
|
538
|
-
end
|
539
|
-
|
540
|
-
def test_should_compute_grapheme_length
|
541
|
-
[
|
542
|
-
['', 0],
|
543
|
-
['abc', 3],
|
544
|
-
['こにちわ', 4],
|
545
|
-
[[0x0924, 0x094D, 0x0930].pack('U*'), 2],
|
546
|
-
[%w(cr lf), 1],
|
547
|
-
[%w(l l), 1],
|
548
|
-
[%w(l v), 1],
|
549
|
-
[%w(l lv), 1],
|
550
|
-
[%w(l lvt), 1],
|
551
|
-
[%w(lv v), 1],
|
552
|
-
[%w(lv t), 1],
|
553
|
-
[%w(v v), 1],
|
554
|
-
[%w(v t), 1],
|
555
|
-
[%w(lvt t), 1],
|
556
|
-
[%w(t t), 1],
|
557
|
-
[%w(n extend), 1],
|
558
|
-
[%w(n n), 2],
|
559
|
-
[%w(n cr lf n), 3],
|
560
|
-
[%w(n l v t), 2]
|
561
|
-
].each do |input, expected_length|
|
562
|
-
if input.kind_of?(Array)
|
563
|
-
str = string_from_classes(input)
|
564
|
-
else
|
565
|
-
str = input
|
566
|
-
end
|
567
|
-
assert_equal expected_length, chars(str).g_length
|
568
|
-
end
|
569
|
-
end
|
570
|
-
|
571
|
-
def test_tidy_bytes_should_tidy_bytes
|
572
|
-
byte_string = "\270\236\010\210\245"
|
573
|
-
tidy_string = [0xb8, 0x17e, 0x8, 0x2c6, 0xa5].pack('U*')
|
574
|
-
ascii_padding = 'aa'
|
575
|
-
utf8_padding = 'éé'
|
576
|
-
|
577
|
-
assert_equal_codepoints tidy_string, chars(byte_string).tidy_bytes
|
578
|
-
|
579
|
-
assert_equal_codepoints ascii_padding.dup.insert(1, tidy_string),
|
580
|
-
chars(ascii_padding.dup.insert(1, byte_string)).tidy_bytes
|
581
|
-
assert_equal_codepoints utf8_padding.dup.insert(2, tidy_string),
|
582
|
-
chars(utf8_padding.dup.insert(2, byte_string)).tidy_bytes
|
583
|
-
assert_nothing_raised { chars(byte_string).tidy_bytes.to_s.unpack('U*') }
|
584
|
-
|
585
|
-
assert_equal_codepoints "\xC3\xA7", chars("\xE7").tidy_bytes # iso_8859_1: small c cedilla
|
586
|
-
assert_equal_codepoints "\xE2\x80\x9C", chars("\x93").tidy_bytes # win_1252: left smart quote
|
587
|
-
assert_equal_codepoints "\xE2\x82\xAC", chars("\x80").tidy_bytes # win_1252: euro
|
588
|
-
assert_equal_codepoints "\x00", chars("\x00").tidy_bytes # null char
|
589
|
-
assert_equal_codepoints [0xfffd].pack('U'), chars("\xef\xbf\xbd").tidy_bytes # invalid char
|
590
|
-
rescue ArgumentError => e
|
591
|
-
raise e if RUBY_VERSION < '1.9'
|
592
|
-
end
|
593
|
-
|
594
|
-
private
|
595
|
-
|
596
|
-
def string_from_classes(classes)
|
597
|
-
# Characters from the character classes as described in UAX #29
|
598
|
-
character_from_class = {
|
599
|
-
:l => 0x1100, :v => 0x1160, :t => 0x11A8, :lv => 0xAC00, :lvt => 0xAC01, :cr => 0x000D, :lf => 0x000A,
|
600
|
-
:extend => 0x094D, :n => 0x64
|
601
|
-
}
|
602
|
-
classes.collect do |k|
|
603
|
-
character_from_class[k.intern]
|
604
|
-
end.pack('U*')
|
605
|
-
end
|
606
|
-
end
|