comfortable_mexican_sofa 1.12.11 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.codeclimate.yml +4 -0
- data/.gitattributes +2 -0
- data/.github/issue_template.md +22 -0
- data/.github/pull_request_template.md +6 -0
- data/.gitignore +3 -0
- data/.rubocop.yml +5 -0
- data/.rubocop_todo.yml +974 -0
- data/.travis.yml +2 -10
- data/Gemfile +5 -7
- data/README.md +40 -39
- data/Rakefile +1 -31
- data/app/assets/javascripts/comfy/admin/cms/application.js.coffee +7 -4
- data/app/assets/javascripts/comfy/admin/cms/base.js.coffee +23 -33
- data/app/assets/javascripts/comfy/admin/cms/lib/diff/pretty_text_diff.js +76 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr.min.js +2 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/ar.js +52 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/bg.js +65 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/bn.js +65 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/cat.js +83 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/cs.js +70 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/cy.js +92 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/da.js +71 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/de.js +70 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/default.js +80 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/eo.js +73 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/es.js +69 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/et.js +73 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/fa.js +68 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/fi.js +69 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/fr.js +75 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/gr.js +74 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/he.js +57 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/hi.js +65 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/hr.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/hu.js +72 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/id.js +61 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/it.js +70 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/ja.js +57 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/ko.js +60 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/lt.js +72 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/lv.js +67 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/mk.js +69 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/mn.js +67 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/ms.js +68 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/my.js +69 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/nl.js +75 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/no.js +73 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/pa.js +65 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/pl.js +68 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/pt-BR.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/pt.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/ro.js +69 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/ru.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/si.js +65 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/sk.js +70 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/sl.js +70 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/sq.js +65 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/sr.js +69 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/sv.js +70 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/th.js +72 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/tr.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/uk.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/vn.js +66 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/zh-CN.js +61 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/flatpickr/i18n/zh-TW.js +61 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/redactor.js +9 -3
- data/app/assets/javascripts/comfy/admin/cms/uploader.js.coffee +9 -10
- data/app/assets/stylesheets/comfy/admin/cms/application.sass +4 -4
- data/app/assets/stylesheets/comfy/admin/cms/base.sass +215 -338
- data/app/assets/stylesheets/comfy/admin/cms/lib/flatpickr.min.css +13 -0
- data/app/assets/stylesheets/comfy/admin/cms/redactor_overrides.sass +2 -2
- data/app/controllers/comfy/admin/base_controller.rb +20 -0
- data/app/controllers/comfy/admin/cms/base_controller.rb +9 -22
- data/app/controllers/comfy/admin/cms/categories_controller.rb +2 -3
- data/app/controllers/comfy/admin/cms/files_controller.rb +50 -31
- data/app/controllers/comfy/admin/cms/layouts_controller.rb +12 -13
- data/app/controllers/comfy/admin/cms/pages_controller.rb +28 -28
- data/app/controllers/comfy/admin/cms/revisions_controller.rb +23 -14
- data/app/controllers/comfy/admin/cms/sites_controller.rb +9 -10
- data/app/controllers/comfy/admin/cms/snippets_controller.rb +11 -11
- data/app/controllers/comfy/admin/cms/translations_controller.rb +98 -0
- data/app/controllers/comfy/cms/assets_controller.rb +9 -10
- data/app/controllers/comfy/cms/base_controller.rb +0 -2
- data/app/controllers/comfy/cms/content_controller.rb +50 -31
- data/app/controllers/concerns/comfy/paginate.rb +2 -2
- data/app/helpers/comfy/admin/cms_helper.rb +29 -0
- data/app/helpers/comfy/cms_helper.rb +40 -60
- data/app/models/comfy/cms/categorization.rb +8 -11
- data/app/models/comfy/cms/category.rb +10 -14
- data/app/models/comfy/cms/file.rb +31 -47
- data/app/models/comfy/cms/fragment.rb +55 -0
- data/app/models/comfy/cms/layout.rb +45 -40
- data/app/models/comfy/cms/page.rb +47 -36
- data/app/models/comfy/cms/revision.rb +5 -8
- data/app/models/comfy/cms/site.rb +26 -51
- data/app/models/comfy/cms/snippet.rb +20 -24
- data/app/models/comfy/cms/translation.rb +37 -0
- data/app/models/concerns/comfy/cms/with_categories.rb +38 -0
- data/app/models/concerns/comfy/cms/with_fragments.rb +121 -0
- data/app/views/comfy/admin/cms/categories/_categories.html.haml +2 -1
- data/app/views/comfy/admin/cms/categories/_edit.html.haml +7 -6
- data/app/views/comfy/admin/cms/categories/_form.html.haml +8 -5
- data/app/views/comfy/admin/cms/categories/_index.html.haml +24 -20
- data/app/views/comfy/admin/cms/categories/_show.html.haml +10 -9
- data/app/views/comfy/admin/cms/categories/create.js.erb +2 -2
- data/app/views/comfy/admin/cms/categories/edit.js.erb +1 -1
- data/app/views/comfy/admin/cms/categories/update.js.erb +2 -2
- data/app/views/comfy/admin/cms/files/_file.html.haml +31 -25
- data/app/views/comfy/admin/cms/files/_form.html.haml +16 -12
- data/app/views/comfy/admin/cms/files/edit.html.haml +1 -1
- data/app/views/comfy/admin/cms/files/index.html.haml +17 -19
- data/app/views/comfy/admin/cms/files/new.html.haml +1 -1
- data/app/views/comfy/admin/cms/layouts/_form.html.haml +10 -10
- data/app/views/comfy/admin/cms/layouts/_index_branch.html.haml +21 -19
- data/app/views/comfy/admin/cms/layouts/edit.html.haml +5 -5
- data/app/views/comfy/admin/cms/layouts/index.html.haml +4 -7
- data/app/views/comfy/admin/cms/pages/_form.html.haml +15 -21
- data/app/views/comfy/admin/cms/pages/_form_fragments.html.haml +40 -0
- data/app/views/comfy/admin/cms/pages/_fragment_attachments.html.haml +10 -0
- data/app/views/comfy/admin/cms/pages/_index_branch.html.haml +34 -26
- data/app/views/comfy/admin/cms/pages/edit.html.haml +19 -5
- data/app/views/comfy/admin/cms/pages/form_fragments.js.erb +1 -0
- data/app/views/comfy/admin/cms/pages/index.html.haml +5 -8
- data/app/views/comfy/admin/cms/pages/new.html.haml +1 -1
- data/app/views/comfy/admin/cms/revisions/show.html.haml +29 -27
- data/app/views/comfy/admin/cms/sites/_form.html.haml +6 -8
- data/app/views/comfy/admin/cms/sites/edit.html.haml +1 -1
- data/app/views/comfy/admin/cms/sites/index.html.haml +23 -22
- data/app/views/comfy/admin/cms/sites/new.html.haml +1 -1
- data/app/views/comfy/admin/cms/snippets/_form.html.haml +9 -9
- data/app/views/comfy/admin/cms/snippets/edit.html.haml +6 -5
- data/app/views/comfy/admin/cms/snippets/index.html.haml +25 -25
- data/app/views/comfy/admin/cms/snippets/new.html.haml +1 -1
- data/app/views/comfy/admin/cms/translations/_form.html.haml +21 -0
- data/app/views/comfy/admin/cms/translations/edit.html.haml +9 -0
- data/app/views/comfy/admin/cms/translations/form_fragments.js.erb +1 -0
- data/app/views/comfy/admin/cms/translations/new.html.haml +5 -0
- data/app/views/kaminari/comfy/_first_page.html.haml +3 -2
- data/app/views/kaminari/comfy/_gap.html.haml +2 -2
- data/app/views/kaminari/comfy/_last_page.html.haml +3 -2
- data/app/views/kaminari/comfy/_next_page.html.haml +2 -2
- data/app/views/kaminari/comfy/_page.html.haml +2 -2
- data/app/views/kaminari/comfy/_prev_page.html.haml +1 -1
- data/app/views/layouts/comfy/admin/cms/_body.html.haml +13 -15
- data/app/views/layouts/comfy/admin/cms/_footer_js.html.haml +10 -3
- data/app/views/layouts/comfy/admin/cms/_head.html.haml +7 -10
- data/app/views/layouts/comfy/admin/cms/_left.html.haml +33 -15
- data/app/views/layouts/comfy/admin/cms/_right.html.haml +2 -2
- data/comfortable_mexican_sofa.gemspec +19 -19
- data/config/application.rb +14 -8
- data/config/boot.rb +2 -2
- data/config/cms_routes.rb +3 -3
- data/config/environments/development.rb +37 -4
- data/config/environments/test.rb +12 -14
- data/config/initializers/comfortable_mexican_sofa.rb +5 -12
- data/config/locales/cs.yml +33 -7
- data/config/locales/da.yml +33 -7
- data/config/locales/de.yml +32 -6
- data/config/locales/en.yml +33 -7
- data/config/locales/es.yml +33 -7
- data/config/locales/fr.yml +33 -7
- data/config/locales/it.yml +33 -7
- data/config/locales/ja.yml +33 -7
- data/config/locales/nb.yml +33 -7
- data/config/locales/nl.yml +33 -7
- data/config/locales/pl.yml +33 -7
- data/config/locales/pt-BR.yml +33 -7
- data/config/locales/ru.yml +33 -7
- data/config/locales/sk.yml +33 -7
- data/config/locales/sv.yml +33 -7
- data/config/locales/tr.yml +33 -7
- data/config/locales/uk.yml +33 -7
- data/config/locales/zh-CN.yml +33 -7
- data/config/locales/zh-TW.yml +33 -7
- data/config/storage.yml +35 -0
- data/db/cms_seeds/sample-site/files/_default.jpg.yml +5 -0
- data/db/{cms_fixtures/sample-site/files/sample.jpg → cms_seeds/sample-site/files/default.jpg} +0 -0
- data/db/cms_seeds/sample-site/layouts/default/content.html +16 -0
- data/db/cms_seeds/sample-site/layouts/default/nested/content.html +14 -0
- data/db/cms_seeds/sample-site/pages/index/child_a/content.html +7 -0
- data/db/cms_seeds/sample-site/pages/index/child_b/content.html +6 -0
- data/db/cms_seeds/sample-site/pages/index/content.es.html +6 -0
- data/db/cms_seeds/sample-site/pages/index/content.fr.html +6 -0
- data/db/cms_seeds/sample-site/pages/index/content.html +24 -0
- data/db/{cms_fixtures/sample-site/pages/index/child/thumbnail.png → cms_seeds/sample-site/pages/index/footer.png} +0 -0
- data/db/cms_seeds/sample-site/pages/index/header.png +0 -0
- data/db/cms_seeds/sample-site/snippets/default.html +8 -0
- data/db/migrate/00_create_active_storage_tables.active_storage.rb +26 -0
- data/db/migrate/01_create_cms.rb +113 -104
- data/doc/preview.jpg +0 -0
- data/lib/comfortable_mexican_sofa.rb +10 -14
- data/lib/comfortable_mexican_sofa/configuration.rb +9 -13
- data/lib/comfortable_mexican_sofa/content.rb +28 -0
- data/lib/comfortable_mexican_sofa/content/block.rb +11 -0
- data/lib/comfortable_mexican_sofa/content/params_parser.rb +80 -0
- data/lib/comfortable_mexican_sofa/content/renderer.rb +125 -0
- data/lib/comfortable_mexican_sofa/content/tag.rb +37 -0
- data/lib/comfortable_mexican_sofa/content/tags/asset.rb +56 -0
- data/lib/comfortable_mexican_sofa/content/tags/checkbox.rb +21 -0
- data/lib/comfortable_mexican_sofa/content/tags/date.rb +22 -0
- data/lib/comfortable_mexican_sofa/content/tags/datetime.rb +22 -0
- data/lib/comfortable_mexican_sofa/content/tags/file.rb +77 -0
- data/lib/comfortable_mexican_sofa/content/tags/file_link.rb +66 -0
- data/lib/comfortable_mexican_sofa/content/tags/files.rb +39 -0
- data/lib/comfortable_mexican_sofa/content/tags/fragment.rb +54 -0
- data/lib/comfortable_mexican_sofa/content/tags/helper.rb +52 -0
- data/lib/comfortable_mexican_sofa/content/tags/markdown.rb +21 -0
- data/lib/comfortable_mexican_sofa/content/tags/number.rb +17 -0
- data/lib/comfortable_mexican_sofa/content/tags/partial.rb +42 -0
- data/lib/comfortable_mexican_sofa/content/tags/snippet.rb +31 -0
- data/lib/comfortable_mexican_sofa/content/tags/template.rb +41 -0
- data/lib/comfortable_mexican_sofa/content/tags/text.rb +17 -0
- data/lib/comfortable_mexican_sofa/content/tags/textarea.rb +17 -0
- data/lib/comfortable_mexican_sofa/content/tags/wysiwyg.rb +18 -0
- data/lib/comfortable_mexican_sofa/engine.rb +3 -2
- data/lib/comfortable_mexican_sofa/extensions/acts_as_tree.rb +33 -30
- data/lib/comfortable_mexican_sofa/extensions/has_revisions.rb +27 -23
- data/lib/comfortable_mexican_sofa/form_builder.rb +32 -104
- data/lib/comfortable_mexican_sofa/render_methods.rb +24 -21
- data/lib/comfortable_mexican_sofa/routes/cms.rb +6 -14
- data/lib/comfortable_mexican_sofa/routes/cms_admin.rb +39 -29
- data/lib/comfortable_mexican_sofa/routing.rb +1 -1
- data/lib/comfortable_mexican_sofa/seeds.rb +102 -0
- data/lib/comfortable_mexican_sofa/seeds/file/exporter.rb +40 -0
- data/lib/comfortable_mexican_sofa/seeds/file/importer.rb +61 -0
- data/lib/comfortable_mexican_sofa/seeds/layout/exporter.rb +37 -0
- data/lib/comfortable_mexican_sofa/seeds/layout/importer.rb +59 -0
- data/lib/comfortable_mexican_sofa/seeds/page/exporter.rb +88 -0
- data/lib/comfortable_mexican_sofa/seeds/page/importer.rb +213 -0
- data/lib/comfortable_mexican_sofa/seeds/snippet/exporter.rb +31 -0
- data/lib/comfortable_mexican_sofa/seeds/snippet/importer.rb +48 -0
- data/lib/comfortable_mexican_sofa/version.rb +1 -1
- data/lib/comfortable_mexican_sofa/view_hooks.rb +0 -1
- data/lib/generators/comfy/cms/assets_generator.rb +0 -1
- data/lib/generators/comfy/cms/cms_generator.rb +15 -5
- data/lib/generators/comfy/scaffold/scaffold_generator.rb +26 -20
- data/lib/generators/comfy/scaffold/templates/{controller.rb → controller.rb.tt} +10 -10
- data/lib/generators/comfy/scaffold/templates/{migration.rb → migration.rb.tt} +2 -3
- data/lib/generators/comfy/scaffold/templates/{model.rb → model.rb.tt} +7 -7
- data/lib/generators/comfy/scaffold/templates/tests/{controller.rb → controller.rb.tt} +37 -24
- data/lib/generators/comfy/scaffold/templates/tests/{fixture.yml → fixture.yml.tt} +0 -0
- data/lib/generators/comfy/scaffold/templates/tests/{model.rb → model.rb.tt} +3 -4
- data/lib/generators/comfy/scaffold/templates/views/_form.haml.tt +7 -0
- data/lib/generators/comfy/scaffold/templates/views/{edit.haml → edit.haml.tt} +1 -1
- data/lib/generators/comfy/scaffold/templates/views/index.haml.tt +21 -0
- data/lib/generators/comfy/scaffold/templates/views/{new.haml → new.haml.tt} +1 -1
- data/lib/generators/comfy/scaffold/templates/views/{show.haml → show.haml.tt} +2 -2
- data/lib/tasks/cms_seeds.rake +37 -0
- data/test/controllers/comfy/admin/cms/base_controller_test.rb +5 -6
- data/test/controllers/comfy/admin/cms/categories_controller_test.rb +27 -24
- data/test/controllers/comfy/admin/cms/files_controller_test.rb +97 -97
- data/test/controllers/comfy/admin/cms/layouts_controller_test.rb +32 -31
- data/test/controllers/comfy/admin/cms/pages_controller_test.rb +317 -263
- data/test/controllers/comfy/admin/cms/revisions_controller_test.rb +175 -65
- data/test/controllers/comfy/admin/cms/sites_controller_test.rb +27 -29
- data/test/controllers/comfy/admin/cms/snippets_controller_test.rb +54 -51
- data/test/controllers/comfy/admin/cms/translations_controller_test.rb +181 -0
- data/test/controllers/comfy/cms/assets_controller_test.rb +24 -22
- data/test/controllers/comfy/cms/content_controller_test.rb +126 -140
- data/test/fixtures/active_storage/attachments.yml +9 -0
- data/test/fixtures/active_storage/blobs.yml +13 -0
- data/test/fixtures/comfy/cms/files.yml +2 -6
- data/test/fixtures/comfy/cms/fragments.yml +25 -0
- data/test/fixtures/comfy/cms/layouts.yml +7 -13
- data/test/fixtures/comfy/cms/pages.yml +2 -17
- data/test/fixtures/comfy/cms/revisions.yml +16 -8
- data/test/fixtures/comfy/cms/sites.yml +0 -1
- data/test/fixtures/comfy/cms/snippets.yml +1 -1
- data/test/fixtures/comfy/cms/translations.yml +7 -0
- data/test/fixtures/generators/cms/application.rb +7 -0
- data/test/fixtures/generators/cms/routes.rb +4 -7
- data/test/fixtures/generators/scaffold/controller.rb +10 -10
- data/test/fixtures/generators/scaffold/migration.rb +2 -3
- data/test/fixtures/generators/scaffold/model.rb +7 -7
- data/test/fixtures/generators/scaffold/routes.rb +1 -2
- data/test/fixtures/generators/scaffold/tests/controller.rb +37 -24
- data/test/fixtures/generators/scaffold/tests/model.rb +3 -4
- data/test/fixtures/generators/scaffold/views/_form.haml +3 -2
- data/test/fixtures/generators/scaffold/views/edit.haml +1 -1
- data/test/fixtures/generators/scaffold/views/index.haml +15 -13
- data/test/fixtures/generators/scaffold/views/new.haml +1 -1
- data/test/fixtures/generators/scaffold/views/show.haml +2 -2
- data/test/gemfiles/Gemfile.rails.5.2 +32 -0
- data/test/generators/cms_assets_generator_test.rb +1 -2
- data/test/generators/cms_generator_test.rb +3 -1
- data/test/generators/cms_views_generator_test.rb +1 -1
- data/test/generators/scaffold_generator_test.rb +2 -2
- data/test/helpers/cms_helper_test.rb +52 -73
- data/test/integration/access_control_test.rb +35 -28
- data/test/integration/js_variables_test.rb +1 -2
- data/test/integration/render_cms_test.rb +37 -37
- data/test/integration/routing_test.rb +4 -5
- data/test/integration/seeds_test.rb +76 -0
- data/test/integration/sites_test.rb +35 -49
- data/test/integration/view_hooks_test.rb +12 -13
- data/test/lib/configuration_test.rb +3 -4
- data/test/lib/content/block_test.rb +26 -0
- data/test/lib/content/params_parser_test.rb +125 -0
- data/test/lib/content/renderer_test.rb +240 -0
- data/test/lib/content/tag_test.rb +48 -0
- data/test/lib/content/tags/asset_test.rb +79 -0
- data/test/lib/content/tags/checkbox_test.rb +20 -0
- data/test/lib/content/tags/date_test.rb +20 -0
- data/test/lib/content/tags/datetime_test.rb +20 -0
- data/test/lib/content/tags/file_link_test.rb +78 -0
- data/test/lib/content/tags/file_test.rb +60 -0
- data/test/lib/content/tags/files_test.rb +49 -0
- data/test/lib/content/tags/fragment_test.rb +63 -0
- data/test/lib/content/tags/helper_test.rb +52 -0
- data/test/lib/content/tags/markdown_test.rb +33 -0
- data/test/lib/content/tags/number_test.rb +13 -0
- data/test/lib/content/tags/partial_test.rb +43 -0
- data/test/lib/content/tags/snippet_test.rb +36 -0
- data/test/lib/content/tags/template_test.rb +35 -0
- data/test/lib/content/tags/text_test.rb +13 -0
- data/test/lib/content/tags/textarea_test.rb +13 -0
- data/test/lib/content/tags/wysiwyg_test.rb +13 -0
- data/test/lib/revisions_test.rb +146 -111
- data/test/lib/seeds/files_test.rb +96 -0
- data/test/lib/seeds/layouts_test.rb +155 -0
- data/test/lib/seeds/pages_test.rb +227 -0
- data/test/lib/seeds/snippets_test.rb +98 -0
- data/test/lib/seeds_test.rb +50 -0
- data/test/models/categorization_test.rb +37 -38
- data/test/models/category_test.rb +14 -14
- data/test/models/file_test.rb +23 -96
- data/test/models/fragment_test.rb +131 -0
- data/test/models/layout_test.rb +105 -74
- data/test/models/page_test.rb +352 -97
- data/test/models/site_test.rb +101 -90
- data/test/models/snippet_test.rb +29 -23
- data/test/models/translation_test.rb +60 -0
- data/test/tasks/cms_seeds_test.rb +33 -0
- data/test/test_helper.rb +49 -32
- metadata +235 -210
- data/_config.yml +0 -1
- data/app/assets/images/comfy/admin/cms/arrow_bottom.gif +0 -0
- data/app/assets/images/comfy/admin/cms/arrow_right.gif +0 -0
- data/app/assets/images/comfy/admin/cms/checkerboard.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_draft.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_file.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_layout.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_move.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_page.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_site.gif +0 -0
- data/app/assets/images/comfy/admin/cms/icon_snippet.gif +0 -0
- data/app/assets/javascripts/comfy/admin/cms/lib/bootstrap-datetimepicker.js +0 -29
- data/app/assets/javascripts/comfy/admin/cms/lib/diff.js.coffee +0 -9
- data/app/assets/javascripts/comfy/admin/cms/lib/diff/pretty_text_diff.min.js +0 -5
- data/app/assets/stylesheets/comfy/admin/cms/bootstrap_overrides.sass +0 -32
- data/app/assets/stylesheets/comfy/admin/cms/lib/bootstrap-datetimepicker.css +0 -9
- data/app/models/comfy/cms/block.rb +0 -63
- data/app/views/comfy/admin/cms/files/_page_form.html.haml +0 -10
- data/app/views/comfy/admin/cms/pages/_form_blocks.html.haml +0 -32
- data/app/views/comfy/admin/cms/pages/form_blocks.js.erb +0 -1
- data/app/views/comfy/admin/cms/partials/_body_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_file_form_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_file_form_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_files_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_files_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_html_footer.html.haml +0 -2
- data/app/views/comfy/admin/cms/partials/_html_head.html.haml +0 -2
- data/app/views/comfy/admin/cms/partials/_layout_form_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_layout_form_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_layouts_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_layouts_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_navigation_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_navigation_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_navigation_inner.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_page_form_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_page_form_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_page_form_inner.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_pages_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_pages_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_right_column_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_right_column_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_site_form_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_site_form_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_sites_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_sites_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_snippet_form_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_snippet_form_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_snippets_after.html.haml +0 -3
- data/app/views/comfy/admin/cms/partials/_snippets_before.html.haml +0 -3
- data/app/views/comfy/admin/cms/sites/_mirrors.html.haml +0 -18
- data/app/views/comfy/cms/content/render_sitemap.xml.builder +0 -14
- data/app/views/layouts/comfy/admin/cms/_footer.html.haml +0 -3
- data/config/initializers/paperclip.rb +0 -3
- data/config/initializers/secret_token.rb +0 -15
- data/db/cms_fixtures/sample-site/categories/files.yml +0 -1
- data/db/cms_fixtures/sample-site/categories/pages.yml +0 -1
- data/db/cms_fixtures/sample-site/categories/snippets.yml +0 -1
- data/db/cms_fixtures/sample-site/files/_sample.jpg.yml +0 -5
- data/db/cms_fixtures/sample-site/layouts/default/attributes.yml +0 -1
- data/db/cms_fixtures/sample-site/layouts/default/content.html +0 -5
- data/db/cms_fixtures/sample-site/layouts/default/javascript.js +0 -1
- data/db/cms_fixtures/sample-site/layouts/default/nested/attributes.yml +0 -2
- data/db/cms_fixtures/sample-site/layouts/default/nested/content.haml +0 -3
- data/db/cms_fixtures/sample-site/layouts/default/nested/javascript.js +0 -1
- data/db/cms_fixtures/sample-site/layouts/default/nested/stylesheet.css +0 -1
- data/db/cms_fixtures/sample-site/layouts/default/stylesheet.css +0 -1
- data/db/cms_fixtures/sample-site/pages/index/attributes.yml +0 -6
- data/db/cms_fixtures/sample-site/pages/index/child/attributes.yml +0 -3
- data/db/cms_fixtures/sample-site/pages/index/child/left.haml +0 -1
- data/db/cms_fixtures/sample-site/pages/index/child/right.html +0 -1
- data/db/cms_fixtures/sample-site/pages/index/content.html +0 -2
- data/db/cms_fixtures/sample-site/snippets/default/attributes.yml +0 -4
- data/db/cms_fixtures/sample-site/snippets/default/content.html +0 -1
- data/db/seeds.rb +0 -7
- data/db/upgrade_migrations/02_upgrade_to_1_1_0.rb +0 -19
- data/db/upgrade_migrations/03_upgrade_to_1_2_0.rb +0 -15
- data/db/upgrade_migrations/04_upgrade_to_1_3_0.rb +0 -23
- data/db/upgrade_migrations/05_upgrade_to_1_4_0.rb +0 -33
- data/db/upgrade_migrations/06_upgrade_to_1_5_0.rb +0 -21
- data/db/upgrade_migrations/07_upgrade_to_1_6_0.rb +0 -25
- data/db/upgrade_migrations/08_upgrade_to_1_12_0.rb +0 -83
- data/doc/preview.png +0 -0
- data/lib/comfortable_mexican_sofa/extensions/cms_manageable.rb +0 -106
- data/lib/comfortable_mexican_sofa/extensions/is_categorized.rb +0 -49
- data/lib/comfortable_mexican_sofa/extensions/is_mirrored.rb +0 -86
- data/lib/comfortable_mexican_sofa/extensions/rails.rb +0 -17
- data/lib/comfortable_mexican_sofa/fixture.rb +0 -82
- data/lib/comfortable_mexican_sofa/fixture/category.rb +0 -42
- data/lib/comfortable_mexican_sofa/fixture/file.rb +0 -85
- data/lib/comfortable_mexican_sofa/fixture/layout.rb +0 -95
- data/lib/comfortable_mexican_sofa/fixture/page.rb +0 -129
- data/lib/comfortable_mexican_sofa/fixture/snippet.rb +0 -75
- data/lib/comfortable_mexican_sofa/tag.rb +0 -154
- data/lib/comfortable_mexican_sofa/tags/asset.rb +0 -30
- data/lib/comfortable_mexican_sofa/tags/collection.rb +0 -64
- data/lib/comfortable_mexican_sofa/tags/field_boolean.rb +0 -17
- data/lib/comfortable_mexican_sofa/tags/field_datetime.rb +0 -17
- data/lib/comfortable_mexican_sofa/tags/field_integer.rb +0 -17
- data/lib/comfortable_mexican_sofa/tags/field_rich_text.rb +0 -17
- data/lib/comfortable_mexican_sofa/tags/field_string.rb +0 -17
- data/lib/comfortable_mexican_sofa/tags/field_text.rb +0 -17
- data/lib/comfortable_mexican_sofa/tags/file.rb +0 -29
- data/lib/comfortable_mexican_sofa/tags/helper.rb +0 -24
- data/lib/comfortable_mexican_sofa/tags/page_datetime.rb +0 -13
- data/lib/comfortable_mexican_sofa/tags/page_file.rb +0 -62
- data/lib/comfortable_mexican_sofa/tags/page_files.rb +0 -51
- data/lib/comfortable_mexican_sofa/tags/page_integer.rb +0 -13
- data/lib/comfortable_mexican_sofa/tags/page_markdown.rb +0 -16
- data/lib/comfortable_mexican_sofa/tags/page_rich_text.rb +0 -13
- data/lib/comfortable_mexican_sofa/tags/page_string.rb +0 -13
- data/lib/comfortable_mexican_sofa/tags/page_text.rb +0 -13
- data/lib/comfortable_mexican_sofa/tags/partial.rb +0 -23
- data/lib/comfortable_mexican_sofa/tags/snippet.rb +0 -19
- data/lib/comfortable_mexican_sofa/tags/template.rb +0 -22
- data/lib/generators/comfy/scaffold/templates/views/_form.haml +0 -6
- data/lib/generators/comfy/scaffold/templates/views/index.haml +0 -23
- data/lib/tasks/comfortable_mexican_sofa.rake +0 -37
- data/test/fixtures/comfy/cms/blocks.yml +0 -12
- data/test/gemfiles/Gemfile.rails.4.1 +0 -22
- data/test/gemfiles/Gemfile.rails.4.2 +0 -22
- data/test/gemfiles/Gemfile.rails.5.0 +0 -23
- data/test/gemfiles/Gemfile.rails.master +0 -23
- data/test/integration/fixtures_test.rb +0 -65
- data/test/integration/mirrors_test.rb +0 -72
- data/test/lib/fixtures/categories_test.rb +0 -36
- data/test/lib/fixtures/files_test.rb +0 -109
- data/test/lib/fixtures/layouts_test.rb +0 -135
- data/test/lib/fixtures/pages_test.rb +0 -168
- data/test/lib/fixtures/snippets_test.rb +0 -106
- data/test/lib/fixtures_test.rb +0 -43
- data/test/lib/mirrors_test.rb +0 -254
- data/test/lib/tag_test.rb +0 -309
- data/test/lib/tags/asset_test.rb +0 -95
- data/test/lib/tags/collection_test.rb +0 -117
- data/test/lib/tags/field_boolean_test.rb +0 -49
- data/test/lib/tags/field_datetime_test.rb +0 -50
- data/test/lib/tags/field_integer_test.rb +0 -49
- data/test/lib/tags/field_rich_text_test.rb +0 -49
- data/test/lib/tags/field_string_test.rb +0 -52
- data/test/lib/tags/field_text_test.rb +0 -48
- data/test/lib/tags/file_test.rb +0 -67
- data/test/lib/tags/helper_test.rb +0 -86
- data/test/lib/tags/page_datetime_test.rb +0 -50
- data/test/lib/tags/page_file_test.rb +0 -119
- data/test/lib/tags/page_files_test.rb +0 -117
- data/test/lib/tags/page_integer_test.rb +0 -49
- data/test/lib/tags/page_markdown_test.rb +0 -48
- data/test/lib/tags/page_rich_text_test.rb +0 -49
- data/test/lib/tags/page_string_test.rb +0 -49
- data/test/lib/tags/page_text_test.rb +0 -52
- data/test/lib/tags/partial_test.rb +0 -76
- data/test/lib/tags/snippet_test.rb +0 -45
- data/test/lib/tags/template_test.rb +0 -56
- data/test/models/block_test.rb +0 -233
data/test/models/site_test.rb
CHANGED
@@ -1,7 +1,11 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../test_helper"
|
2
2
|
|
3
3
|
class CmsSiteTest < ActiveSupport::TestCase
|
4
4
|
|
5
|
+
setup do
|
6
|
+
@site = comfy_cms_sites(:default)
|
7
|
+
end
|
8
|
+
|
5
9
|
def test_fixtures_validity
|
6
10
|
Comfy::Cms::Site.all.each do |site|
|
7
11
|
assert site.valid?, site.errors.inspect
|
@@ -13,82 +17,90 @@ class CmsSiteTest < ActiveSupport::TestCase
|
|
13
17
|
assert site.invalid?
|
14
18
|
assert_has_errors_on site, [:identifier, :label, :hostname]
|
15
19
|
|
16
|
-
site = Comfy::Cms::Site.new(:
|
20
|
+
site = Comfy::Cms::Site.new(identifier: "test", hostname: "http://site.host")
|
17
21
|
assert site.invalid?
|
18
22
|
assert_has_errors_on site, :hostname
|
19
23
|
|
20
|
-
site = Comfy::Cms::Site.new(:
|
24
|
+
site = Comfy::Cms::Site.new(identifier: @site.identifier, hostname: "site.host")
|
21
25
|
assert site.invalid?
|
22
26
|
assert_has_errors_on site, :identifier
|
23
27
|
|
24
|
-
site = Comfy::Cms::Site.new(:
|
28
|
+
site = Comfy::Cms::Site.new(identifier: "test", hostname: "site.host")
|
25
29
|
assert site.valid?, site.errors.inspect
|
26
30
|
|
27
|
-
site = Comfy::Cms::Site.new(:
|
31
|
+
site = Comfy::Cms::Site.new(identifier: "test", hostname: "localhost:3000")
|
28
32
|
assert site.valid?, site.errors.inspect
|
29
33
|
end
|
30
34
|
|
31
35
|
def test_validation_path_uniqueness
|
32
|
-
s1 =
|
36
|
+
s1 = @site
|
33
37
|
s2 = Comfy::Cms::Site.new(
|
34
|
-
:
|
35
|
-
:
|
36
|
-
:
|
38
|
+
identifier: "test",
|
39
|
+
hostname: s1.hostname,
|
40
|
+
path: s1.path
|
37
41
|
)
|
38
42
|
assert s2.invalid?
|
39
43
|
assert_has_errors_on s2, :hostname
|
40
44
|
|
41
45
|
s2 = Comfy::Cms::Site.new(
|
42
|
-
:
|
43
|
-
:
|
44
|
-
:
|
46
|
+
identifier: "test",
|
47
|
+
hostname: s1.hostname,
|
48
|
+
path: "/en"
|
45
49
|
)
|
46
50
|
assert s2.valid?
|
47
51
|
end
|
48
52
|
|
49
53
|
def test_identifier_assignment
|
50
|
-
site = Comfy::Cms::Site.new(:
|
54
|
+
site = Comfy::Cms::Site.new(hostname: "my-site.host")
|
51
55
|
assert site.valid?
|
52
|
-
assert_equal
|
56
|
+
assert_equal "my-site-host", site.identifier
|
53
57
|
end
|
54
58
|
|
55
59
|
def test_hostname_assignment
|
56
|
-
site = Comfy::Cms::Site.new(:
|
60
|
+
site = Comfy::Cms::Site.new(identifier: "test-site")
|
57
61
|
assert site.valid?
|
58
|
-
assert_equal
|
62
|
+
assert_equal "test-site", site.hostname
|
59
63
|
end
|
60
64
|
|
61
65
|
def test_label_assignment
|
62
|
-
site = Comfy::Cms::Site.new(:
|
66
|
+
site = Comfy::Cms::Site.new(identifier: "test", hostname: "my-site.host")
|
63
67
|
assert site.valid?
|
64
|
-
assert_equal
|
68
|
+
assert_equal "Test", site.label
|
65
69
|
end
|
66
70
|
|
67
71
|
def test_clean_path
|
68
|
-
site = Comfy::Cms::Site.create!(
|
69
|
-
|
72
|
+
site = Comfy::Cms::Site.create!(
|
73
|
+
identifier: "test_a",
|
74
|
+
hostname: "test.host",
|
75
|
+
path: "/en///test//"
|
76
|
+
)
|
77
|
+
assert_equal "/en/test", site.path
|
70
78
|
|
71
|
-
site = Comfy::Cms::Site.create!(
|
72
|
-
|
79
|
+
site = Comfy::Cms::Site.create!(
|
80
|
+
identifier: "test_b",
|
81
|
+
hostname: "my-site.host",
|
82
|
+
path: "/"
|
83
|
+
)
|
84
|
+
assert_nil site.path
|
73
85
|
end
|
74
86
|
|
75
87
|
def test_creation
|
76
|
-
assert_difference
|
88
|
+
assert_difference "Comfy::Cms::Site.count" do
|
77
89
|
Comfy::Cms::Site.create!(
|
78
|
-
:
|
79
|
-
:
|
80
|
-
:
|
90
|
+
identifier: "test",
|
91
|
+
label: "Test Site",
|
92
|
+
hostname: "test.test"
|
81
93
|
)
|
82
94
|
end
|
83
95
|
end
|
84
96
|
|
85
97
|
def test_cascading_destroy
|
86
|
-
assert_difference
|
87
|
-
assert_difference
|
88
|
-
assert_difference
|
89
|
-
assert_difference
|
90
|
-
assert_difference
|
91
|
-
|
98
|
+
assert_difference "Comfy::Cms::Site.count", -1 do
|
99
|
+
assert_difference "Comfy::Cms::Layout.count", -3 do
|
100
|
+
assert_difference "Comfy::Cms::Page.count", -2 do
|
101
|
+
assert_difference "Comfy::Cms::Snippet.count", -1 do
|
102
|
+
assert_difference "Comfy::Cms::Category.count", -1 do
|
103
|
+
@site.destroy
|
92
104
|
end
|
93
105
|
end
|
94
106
|
end
|
@@ -96,83 +108,82 @@ class CmsSiteTest < ActiveSupport::TestCase
|
|
96
108
|
end
|
97
109
|
end
|
98
110
|
|
99
|
-
def test_scope_mirrored
|
100
|
-
site = comfy_cms_sites(:default)
|
101
|
-
assert !site.is_mirrored
|
102
|
-
assert_equal 0, Comfy::Cms::Site.mirrored.count
|
103
|
-
site.update_columns(:is_mirrored => true)
|
104
|
-
assert_equal 1, Comfy::Cms::Site.mirrored.count
|
105
|
-
end
|
106
|
-
|
107
111
|
def test_find_site
|
108
|
-
site_a =
|
109
|
-
assert_equal
|
112
|
+
site_a = @site
|
113
|
+
assert_equal "test.host", site_a.hostname
|
110
114
|
assert_nil site_a.path
|
111
115
|
|
112
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
113
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
114
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
116
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("test.host")
|
117
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("test.host", "/some/path")
|
118
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("test99.host", "/some/path")
|
115
119
|
|
116
|
-
site_b = Comfy::Cms::Site.create!(:
|
117
|
-
site_c = Comfy::Cms::Site.create!(:
|
120
|
+
site_b = Comfy::Cms::Site.create!(identifier: "test_a", hostname: "test2.host", path: "en")
|
121
|
+
site_c = Comfy::Cms::Site.create!(identifier: "test_b", hostname: "test2.host", path: "fr")
|
118
122
|
|
119
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
120
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
121
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
122
|
-
assert_nil Comfy::Cms::Site.find_site(
|
123
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("test.host")
|
124
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("test.host", "/some/path")
|
125
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("test.host", "/some/path")
|
126
|
+
assert_nil Comfy::Cms::Site.find_site("test99.host", "/some/path")
|
123
127
|
|
124
|
-
assert_nil Comfy::Cms::Site.find_site(
|
125
|
-
assert_nil Comfy::Cms::Site.find_site(
|
126
|
-
assert_equal site_b, Comfy::Cms::Site.find_site(
|
127
|
-
assert_equal site_b, Comfy::Cms::Site.find_site(
|
128
|
-
assert_equal site_b, Comfy::Cms::Site.find_site(
|
128
|
+
assert_nil Comfy::Cms::Site.find_site("test2.host")
|
129
|
+
assert_nil Comfy::Cms::Site.find_site("test2.host", "/some/path")
|
130
|
+
assert_equal site_b, Comfy::Cms::Site.find_site("test2.host", "/en")
|
131
|
+
assert_equal site_b, Comfy::Cms::Site.find_site("test2.host", "/en?a=b")
|
132
|
+
assert_equal site_b, Comfy::Cms::Site.find_site("test2.host", "/en/some/path?a=b")
|
129
133
|
|
130
|
-
assert_nil Comfy::Cms::Site.find_site(
|
134
|
+
assert_nil Comfy::Cms::Site.find_site("test2.host", "/english/some/path")
|
131
135
|
|
132
|
-
assert_equal site_c, Comfy::Cms::Site.find_site(
|
133
|
-
assert_equal site_c, Comfy::Cms::Site.find_site(
|
134
|
-
assert_equal site_c, Comfy::Cms::Site.find_site(
|
135
|
-
assert_equal site_c, Comfy::Cms::Site.find_site(
|
136
|
+
assert_equal site_c, Comfy::Cms::Site.find_site("test2.host", "/fr")
|
137
|
+
assert_equal site_c, Comfy::Cms::Site.find_site("test2.host", "/fr?a=b")
|
138
|
+
assert_equal site_c, Comfy::Cms::Site.find_site("test2.host", "/fr/some/path")
|
139
|
+
assert_equal site_c, Comfy::Cms::Site.find_site("test2.host", "/fr/some/path?a=b")
|
136
140
|
end
|
137
141
|
|
138
|
-
def
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
assert_nil
|
147
|
-
|
148
|
-
|
149
|
-
assert_equal
|
150
|
-
|
151
|
-
|
152
|
-
|
142
|
+
def test_find_site_with_public_cms_path
|
143
|
+
ComfortableMexicanSofa.config.public_cms_path = '/custom'
|
144
|
+
assert_equal '//test.host/custom', comfy_cms_sites(:default).url
|
145
|
+
|
146
|
+
site_a = Comfy::Cms::Site.create!(identifier: 'test_a', hostname: 'test2.host', path: 'en')
|
147
|
+
site_b = Comfy::Cms::Site.create!(identifier: 'test_b', hostname: 'test2.host', path: 'fr')
|
148
|
+
|
149
|
+
assert_nil Comfy::Cms::Site.find_site('test2.host')
|
150
|
+
assert_nil Comfy::Cms::Site.find_site('test2.host', '/custom/some/path')
|
151
|
+
assert_equal site_a, Comfy::Cms::Site.find_site('test2.host', '/custom/en')
|
152
|
+
assert_equal site_a, Comfy::Cms::Site.find_site('test2.host', '/custom/en?a=b')
|
153
|
+
assert_equal site_a, Comfy::Cms::Site.find_site('test2.host', '/custom/en/some/path?a=b')
|
154
|
+
|
155
|
+
assert_nil Comfy::Cms::Site.find_site('test2.host', '/custom/english/some/path')
|
156
|
+
|
157
|
+
assert_equal site_b, Comfy::Cms::Site.find_site('test2.host', '/custom/fr')
|
158
|
+
assert_equal site_b, Comfy::Cms::Site.find_site('test2.host', '/custom/fr?a=b')
|
159
|
+
assert_equal site_b, Comfy::Cms::Site.find_site('test2.host', '/custom/fr/some/path')
|
160
|
+
assert_equal site_b, Comfy::Cms::Site.find_site('test2.host', '/custom/fr/some/path?a=b')
|
153
161
|
end
|
154
162
|
|
155
163
|
def test_find_site_with_site_alias
|
156
|
-
site_a =
|
157
|
-
site_b = Comfy::Cms::Site.create!(:
|
164
|
+
site_a = @site
|
165
|
+
site_b = Comfy::Cms::Site.create!(identifier: "site_b", hostname: "test2.host")
|
158
166
|
|
159
167
|
ComfortableMexicanSofa.config.hostname_aliases = {
|
160
|
-
|
161
|
-
|
168
|
+
"test.host" => "alias_a.host",
|
169
|
+
"test2.host" => %w(alias_b.host alias_c.host)
|
162
170
|
}
|
163
171
|
|
164
|
-
assert_equal site_a, Comfy::Cms::Site.find_site(
|
165
|
-
assert_equal site_b, Comfy::Cms::Site.find_site(
|
166
|
-
assert_equal site_b, Comfy::Cms::Site.find_site(
|
172
|
+
assert_equal site_a, Comfy::Cms::Site.find_site("alias_a.host")
|
173
|
+
assert_equal site_b, Comfy::Cms::Site.find_site("alias_b.host")
|
174
|
+
assert_equal site_b, Comfy::Cms::Site.find_site("alias_c.host")
|
167
175
|
end
|
168
176
|
|
169
177
|
def test_url
|
170
|
-
assert_equal
|
171
|
-
|
178
|
+
assert_equal "//test.host", @site.url
|
179
|
+
assert_nil @site.url(relative: true)
|
172
180
|
|
173
|
-
|
174
|
-
|
175
|
-
assert_equal '//test.host/custom/', comfy_cms_sites(:default).url
|
176
|
-
end
|
181
|
+
@site.update_column(:path, "/site-path")
|
182
|
+
assert_equal "//test.host/site-path", @site.url
|
177
183
|
|
178
|
-
|
184
|
+
ComfortableMexicanSofa.config.public_cms_path = "cms"
|
185
|
+
assert_equal "//test.host/cms/site-path", @site.url
|
186
|
+
|
187
|
+
assert_equal "/cms/site-path", @site.url(relative: true)
|
188
|
+
end
|
189
|
+
end
|
data/test/models/snippet_test.rb
CHANGED
@@ -1,49 +1,55 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../test_helper"
|
2
2
|
|
3
3
|
class CmsSnippetTest < ActiveSupport::TestCase
|
4
|
-
|
4
|
+
|
5
|
+
setup do
|
6
|
+
@site = comfy_cms_sites(:default)
|
7
|
+
end
|
8
|
+
|
5
9
|
def test_fixtures_validity
|
6
10
|
Comfy::Cms::Snippet.all.each do |snippet|
|
7
11
|
assert snippet.valid?, snippet.errors.full_messages.to_s
|
8
12
|
end
|
9
13
|
end
|
10
|
-
|
14
|
+
|
11
15
|
def test_validations
|
12
16
|
snippet = Comfy::Cms::Snippet.new
|
13
17
|
snippet.save
|
14
18
|
assert snippet.invalid?
|
15
|
-
assert_has_errors_on snippet, :
|
19
|
+
assert_has_errors_on snippet, :site, :label, :identifier
|
16
20
|
end
|
17
|
-
|
21
|
+
|
18
22
|
def test_label_assignment
|
19
|
-
snippet =
|
20
|
-
:
|
23
|
+
snippet = @site.snippets.new(
|
24
|
+
identifier: "test"
|
21
25
|
)
|
22
26
|
assert snippet.valid?
|
23
|
-
assert_equal
|
27
|
+
assert_equal "Test", snippet.label
|
24
28
|
end
|
25
|
-
|
29
|
+
|
26
30
|
def test_create
|
27
|
-
assert_difference
|
28
|
-
snippet =
|
29
|
-
:
|
30
|
-
:
|
31
|
-
:
|
31
|
+
assert_difference "Comfy::Cms::Snippet.count" do
|
32
|
+
snippet = @site.snippets.create(
|
33
|
+
label: "Test Snippet",
|
34
|
+
identifier: "test",
|
35
|
+
content: "Test Content"
|
32
36
|
)
|
33
|
-
assert_equal
|
34
|
-
assert_equal
|
35
|
-
assert_equal
|
37
|
+
assert_equal "Test Snippet", snippet.label
|
38
|
+
assert_equal "test", snippet.identifier
|
39
|
+
assert_equal "Test Content", snippet.content
|
36
40
|
assert_equal 1, snippet.position
|
37
41
|
end
|
38
42
|
end
|
39
|
-
|
43
|
+
|
40
44
|
def test_update_forces_page_content_reload
|
41
45
|
snippet = comfy_cms_snippets(:default)
|
42
|
-
page
|
43
|
-
|
44
|
-
|
46
|
+
page = comfy_cms_pages(:default)
|
47
|
+
comfy_cms_fragments(:default).update_column(:content, "{{cms:snippet default}}")
|
48
|
+
page.clear_content_cache!
|
49
|
+
|
50
|
+
assert_equal "snippet content", page.content_cache
|
51
|
+
snippet.update_attributes(content: "new snippet content")
|
45
52
|
page.reload
|
46
|
-
|
53
|
+
assert_equal "new snippet content", page.content_cache
|
47
54
|
end
|
48
|
-
|
49
55
|
end
|
@@ -0,0 +1,60 @@
|
|
1
|
+
require_relative '../test_helper'
|
2
|
+
|
3
|
+
class CmsPageTest < ActiveSupport::TestCase
|
4
|
+
|
5
|
+
setup do
|
6
|
+
@page = comfy_cms_pages(:default)
|
7
|
+
end
|
8
|
+
|
9
|
+
def test_fixtures_validity
|
10
|
+
Comfy::Cms::Translation.all.each do |translation|
|
11
|
+
assert translation.valid?, translation.errors.full_messages.to_s
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
def test_validations
|
16
|
+
translation = Comfy::Cms::Translation.new
|
17
|
+
translation.save
|
18
|
+
assert translation.invalid?
|
19
|
+
assert_has_errors_on translation, :page, :layout, :locale, :label
|
20
|
+
end
|
21
|
+
|
22
|
+
def test_validation_on_locale_uniqueness
|
23
|
+
translation = @page.translations.new(
|
24
|
+
label: "Test",
|
25
|
+
locale: comfy_cms_translations(:default).locale
|
26
|
+
)
|
27
|
+
assert translation.invalid?
|
28
|
+
assert_has_errors_on translation, :locale
|
29
|
+
end
|
30
|
+
|
31
|
+
def test_validation_on_locale_uniqueness_against_site
|
32
|
+
translation = @page.translations.new(
|
33
|
+
label: "Test",
|
34
|
+
locale: comfy_cms_sites(:default).locale
|
35
|
+
)
|
36
|
+
assert translation.invalid?
|
37
|
+
assert_has_errors_on translation, :locale
|
38
|
+
end
|
39
|
+
|
40
|
+
def test_creation
|
41
|
+
assert_count_difference [Comfy::Cms::Translation, Comfy::Cms::Fragment] do
|
42
|
+
translation = @page.translations.create(
|
43
|
+
locale: "test",
|
44
|
+
label: "Test Translation",
|
45
|
+
fragments_attributes: [
|
46
|
+
{ identifier: "content",
|
47
|
+
tag: "text",
|
48
|
+
content: "test" }
|
49
|
+
]
|
50
|
+
)
|
51
|
+
assert_equal @page.layout, translation.layout
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
def test_scope_published
|
56
|
+
assert_equal 1, Comfy::Cms::Translation.published.count
|
57
|
+
comfy_cms_translations(:default).update_columns(is_published: false)
|
58
|
+
assert_equal 0, Comfy::Cms::Translation.published.count
|
59
|
+
end
|
60
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
require_relative "../test_helper"
|
2
|
+
require "rake"
|
3
|
+
|
4
|
+
class CmsSeedsTaskTest < ActiveSupport::TestCase
|
5
|
+
|
6
|
+
setup do
|
7
|
+
@rake = Rake::Application.new
|
8
|
+
Rake.application = @rake
|
9
|
+
# We force rake file reload by passing empty array as the last parameter
|
10
|
+
Rake.application.rake_require("tasks/cms_seeds", $LOAD_PATH, [])
|
11
|
+
Rake::Task.define_task(:environment)
|
12
|
+
end
|
13
|
+
|
14
|
+
def test_import
|
15
|
+
importer = mock()
|
16
|
+
ComfortableMexicanSofa::Seeds::Importer.expects(:new).with("from_folder", "to_site").returns(importer)
|
17
|
+
importer.expects(:import!)
|
18
|
+
|
19
|
+
with_captured_stout do
|
20
|
+
@rake["comfy:cms_seeds:import"].invoke("from_folder", "to_site")
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
def test_export
|
25
|
+
exporter = mock()
|
26
|
+
ComfortableMexicanSofa::Seeds::Exporter.expects(:new).with("from_site", "to_folder").returns(exporter)
|
27
|
+
exporter.expects(:export!)
|
28
|
+
|
29
|
+
with_captured_stout do
|
30
|
+
@rake["comfy:cms_seeds:export"].invoke("from_site", "to_folder")
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
data/test/test_helper.rb
CHANGED
@@ -1,4 +1,3 @@
|
|
1
|
-
# encoding: utf-8
|
2
1
|
ENV['RAILS_ENV'] = 'test'
|
3
2
|
|
4
3
|
require 'simplecov'
|
@@ -14,8 +13,8 @@ require 'rails/test_help'
|
|
14
13
|
require 'rails/generators'
|
15
14
|
require 'mocha/setup'
|
16
15
|
|
17
|
-
|
18
|
-
|
16
|
+
Rails.backtrace_cleaner.remove_silencers!
|
17
|
+
|
19
18
|
|
20
19
|
class ActiveSupport::TestCase
|
21
20
|
|
@@ -24,8 +23,7 @@ class ActiveSupport::TestCase
|
|
24
23
|
fixtures :all
|
25
24
|
|
26
25
|
setup :reset_config,
|
27
|
-
:reset_locale
|
28
|
-
:stub_paperclip
|
26
|
+
:reset_locale
|
29
27
|
|
30
28
|
# resetting default configuration
|
31
29
|
def reset_config
|
@@ -36,17 +34,16 @@ class ActiveSupport::TestCase
|
|
36
34
|
config.public_auth = 'ComfortableMexicanSofa::AccessControl::PublicAuthentication'
|
37
35
|
config.public_authorization = 'ComfortableMexicanSofa::AccessControl::PublicAuthorization'
|
38
36
|
config.admin_route_redirect = ''
|
39
|
-
config.
|
40
|
-
config.
|
37
|
+
config.enable_seeds = false
|
38
|
+
config.seeds_path = File.expand_path('db/cms_seeds', Rails.root)
|
41
39
|
config.revisions_limit = 25
|
42
40
|
config.locales = {
|
43
41
|
'en' => 'English',
|
44
42
|
'es' => 'Español'
|
45
43
|
}
|
46
44
|
config.admin_locale = nil
|
47
|
-
config.upload_file_options = { }
|
48
45
|
config.admin_cache_sweeper = nil
|
49
|
-
config.
|
46
|
+
config.allow_erb = false
|
50
47
|
config.allowed_helpers = nil
|
51
48
|
config.allowed_partials = nil
|
52
49
|
config.allowed_templates = nil
|
@@ -93,31 +90,35 @@ class ActiveSupport::TestCase
|
|
93
90
|
end
|
94
91
|
|
95
92
|
def assert_no_select(selector, value = nil)
|
96
|
-
assert_select(selector, :
|
93
|
+
assert_select(selector, text: value, count: 0)
|
97
94
|
end
|
98
95
|
|
99
|
-
|
100
|
-
|
101
|
-
|
96
|
+
def assert_count_difference(models, number = 1, &block)
|
97
|
+
counts = [models].flatten.map{|m| "#{m}.count"}
|
98
|
+
assert_difference counts, number do
|
99
|
+
yield
|
100
|
+
end
|
102
101
|
end
|
103
102
|
|
104
|
-
def
|
105
|
-
|
106
|
-
|
107
|
-
|
103
|
+
def assert_count_no_difference(*models, &block)
|
104
|
+
counts = [models].flatten.map{|m| "#{m}.count"}
|
105
|
+
assert_no_difference counts do
|
106
|
+
yield
|
107
|
+
end
|
108
108
|
end
|
109
109
|
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
110
|
+
# Capturing STDOUT into a string
|
111
|
+
def with_captured_stout
|
112
|
+
old = $stdout
|
113
|
+
$stdout = StringIO.new
|
114
|
+
yield
|
115
|
+
$stdout.string
|
116
|
+
ensure
|
117
|
+
$stdout = old
|
118
118
|
end
|
119
119
|
end
|
120
120
|
|
121
|
+
|
121
122
|
class ActionDispatch::IntegrationTest
|
122
123
|
|
123
124
|
setup :setup_host
|
@@ -127,16 +128,21 @@ class ActionDispatch::IntegrationTest
|
|
127
128
|
end
|
128
129
|
|
129
130
|
# Attaching http_auth stuff with request. Example use:
|
130
|
-
#
|
131
|
-
def
|
132
|
-
|
131
|
+
# r :get, '/cms-admin/pages'
|
132
|
+
def r(method, path, options = {})
|
133
|
+
headers = options[:headers] || {}
|
134
|
+
headers['HTTP_AUTHORIZATION'] = ActionController::HttpAuthentication::Basic.encode_credentials(
|
135
|
+
ComfortableMexicanSofa::AccessControl::AdminAuthentication.username,
|
136
|
+
ComfortableMexicanSofa::AccessControl::AdminAuthentication.password
|
137
|
+
)
|
138
|
+
options.merge!(headers: headers)
|
139
|
+
send(method, path, options)
|
133
140
|
end
|
134
141
|
|
135
|
-
# Overriding helper method as it doesn't really work for integration tests by default
|
136
142
|
def with_routing(&block)
|
137
143
|
yield ComfortableMexicanSofa::Application.routes
|
138
144
|
ensure
|
139
|
-
|
145
|
+
ComfortableMexicanSofa::Application.routes_reloader.reload!
|
140
146
|
end
|
141
147
|
end
|
142
148
|
|
@@ -150,10 +156,22 @@ class Rails::Generators::TestCase
|
|
150
156
|
def prepare_files
|
151
157
|
config_path = File.join(self.destination_root, 'config')
|
152
158
|
routes_path = File.join(config_path, 'routes.rb')
|
159
|
+
app_path = File.join(config_path, 'application.rb')
|
153
160
|
FileUtils.mkdir_p(config_path)
|
154
161
|
FileUtils.touch(routes_path)
|
155
162
|
File.open(routes_path, 'w') do |f|
|
156
|
-
f.write
|
163
|
+
f.write <<-RUBY.strip_heredoc
|
164
|
+
Test::Application.routes.draw do
|
165
|
+
end
|
166
|
+
RUBY
|
167
|
+
end
|
168
|
+
File.open(app_path, 'w') do |f|
|
169
|
+
f.write <<-RUBY.strip_heredoc
|
170
|
+
module TestApp
|
171
|
+
class Application < Rails::Application
|
172
|
+
end
|
173
|
+
end
|
174
|
+
RUBY
|
157
175
|
end
|
158
176
|
end
|
159
177
|
|
@@ -165,5 +183,4 @@ class Rails::Generators::TestCase
|
|
165
183
|
)
|
166
184
|
)
|
167
185
|
end
|
168
|
-
|
169
186
|
end
|