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
@@ -1,138 +1,248 @@
|
|
1
1
|
require_relative '../../../../test_helper'
|
2
2
|
|
3
|
-
class Comfy::Admin::Cms::RevisionsControllerTest <
|
4
|
-
|
3
|
+
class Comfy::Admin::Cms::RevisionsControllerTest < ActionDispatch::IntegrationTest
|
4
|
+
|
5
|
+
setup do
|
6
|
+
@site = comfy_cms_sites(:default)
|
7
|
+
@layout = comfy_cms_layouts(:default)
|
8
|
+
@page = comfy_cms_pages(:default)
|
9
|
+
@translation = comfy_cms_translations(:default)
|
10
|
+
@snippet = comfy_cms_snippets(:default)
|
11
|
+
end
|
12
|
+
|
5
13
|
def test_get_index_for_layouts
|
6
|
-
|
14
|
+
r :get, comfy_admin_cms_site_layout_revisions_path(@site, @layout)
|
7
15
|
assert_response :redirect
|
8
|
-
assert_redirected_to :
|
16
|
+
assert_redirected_to action: :show, id: comfy_cms_revisions(:layout)
|
9
17
|
end
|
10
|
-
|
18
|
+
|
11
19
|
def test_get_index_for_pages
|
12
|
-
|
20
|
+
r :get, comfy_admin_cms_site_page_revisions_path(@site, @page)
|
13
21
|
assert_response :redirect
|
14
|
-
assert_redirected_to :
|
22
|
+
assert_redirected_to action: :show, id: comfy_cms_revisions(:page)
|
15
23
|
end
|
16
|
-
|
24
|
+
|
17
25
|
def test_get_index_for_snippets
|
18
|
-
|
26
|
+
r :get, comfy_admin_cms_site_snippet_revisions_path(@site, @snippet)
|
19
27
|
assert_response :redirect
|
20
|
-
assert_redirected_to :
|
28
|
+
assert_redirected_to action: :show, id: comfy_cms_revisions(:snippet)
|
21
29
|
end
|
22
|
-
|
30
|
+
|
31
|
+
def test_get_index_for_translations
|
32
|
+
r :get, comfy_admin_cms_site_page_translation_revisions_path(@site, @page, @translation)
|
33
|
+
assert_response :redirect
|
34
|
+
assert_redirected_to action: :show, id: comfy_cms_revisions(:translation)
|
35
|
+
end
|
36
|
+
|
23
37
|
def test_get_index_for_snippets_with_no_revisions
|
24
38
|
Comfy::Cms::Revision.delete_all
|
25
|
-
|
39
|
+
r :get, comfy_admin_cms_site_snippet_revisions_path(@site, @snippet)
|
26
40
|
assert_response :redirect
|
27
|
-
assert_redirected_to :
|
41
|
+
assert_redirected_to action: :show, id: 0
|
28
42
|
end
|
29
|
-
|
43
|
+
|
30
44
|
def test_get_show_for_layout
|
31
|
-
|
45
|
+
r :get, comfy_admin_cms_site_layout_revision_path(
|
46
|
+
site_id: @site,
|
47
|
+
layout_id: @layout,
|
48
|
+
id: comfy_cms_revisions(:layout))
|
32
49
|
assert_response :success
|
33
50
|
assert assigns(:record)
|
34
51
|
assert assigns(:revision)
|
35
52
|
assert assigns(:record).is_a?(Comfy::Cms::Layout)
|
36
53
|
assert_template :show
|
37
54
|
end
|
38
|
-
|
55
|
+
|
39
56
|
def test_get_show_for_page
|
40
|
-
|
57
|
+
r :get, comfy_admin_cms_site_page_revision_path(
|
58
|
+
site_id: @site,
|
59
|
+
page_id: @page,
|
60
|
+
id: comfy_cms_revisions(:page))
|
41
61
|
assert_response :success
|
42
62
|
assert assigns(:record)
|
43
63
|
assert assigns(:revision)
|
44
64
|
assert assigns(:record).is_a?(Comfy::Cms::Page)
|
45
65
|
assert_template :show
|
46
66
|
end
|
47
|
-
|
67
|
+
|
68
|
+
def test_get_show_for_translation
|
69
|
+
r :get, comfy_admin_cms_site_page_translation_revision_path(
|
70
|
+
site_id: @site,
|
71
|
+
page_id: @page,
|
72
|
+
translation_id: @translation,
|
73
|
+
id: comfy_cms_revisions(:translation))
|
74
|
+
assert_response :success
|
75
|
+
assert assigns(:record)
|
76
|
+
assert assigns(:revision)
|
77
|
+
assert assigns(:record).is_a?(Comfy::Cms::Translation)
|
78
|
+
assert_template :show
|
79
|
+
end
|
80
|
+
|
48
81
|
def test_get_show_for_snippet
|
49
|
-
|
82
|
+
r :get, comfy_admin_cms_site_snippet_revision_path(
|
83
|
+
site_id: @site,
|
84
|
+
snippet_id: @snippet,
|
85
|
+
id: comfy_cms_revisions(:snippet))
|
50
86
|
assert_response :success
|
51
87
|
assert assigns(:record)
|
52
88
|
assert assigns(:revision)
|
53
89
|
assert assigns(:record).is_a?(Comfy::Cms::Snippet)
|
54
90
|
assert_template :show
|
55
91
|
end
|
56
|
-
|
92
|
+
|
57
93
|
def test_get_show_for_bad_type
|
58
|
-
|
94
|
+
r :get, comfy_admin_cms_site_layout_revision_path(
|
95
|
+
site_id: @site,
|
96
|
+
layout_id: 'invalid',
|
97
|
+
id: comfy_cms_revisions(:layout))
|
59
98
|
assert_response :redirect
|
60
99
|
assert_redirected_to comfy_admin_cms_path
|
61
100
|
assert_equal 'Record Not Found', flash[:danger]
|
62
101
|
end
|
63
|
-
|
102
|
+
|
64
103
|
def test_get_show_for_layout_failure
|
65
|
-
|
66
|
-
|
104
|
+
r :get, comfy_admin_cms_site_layout_revision_path(
|
105
|
+
site_id: @site,
|
106
|
+
layout_id: @layout,
|
107
|
+
id: 'invalid')
|
67
108
|
assert_response :redirect
|
68
109
|
assert assigns(:record)
|
69
|
-
assert_redirected_to edit_comfy_admin_cms_site_layout_path(site, assigns(:record))
|
110
|
+
assert_redirected_to edit_comfy_admin_cms_site_layout_path(@site, assigns(:record))
|
70
111
|
assert_equal 'Revision Not Found', flash[:danger]
|
71
112
|
end
|
72
|
-
|
113
|
+
|
73
114
|
def test_get_show_for_page_failure
|
74
|
-
|
75
|
-
|
115
|
+
r :get, comfy_admin_cms_site_page_revision_path(
|
116
|
+
site_id: @site,
|
117
|
+
page_id: @page,
|
118
|
+
id: 'invalid')
|
76
119
|
assert_response :redirect
|
77
120
|
assert assigns(:record)
|
78
|
-
assert_redirected_to edit_comfy_admin_cms_site_page_path(site, assigns(:record))
|
121
|
+
assert_redirected_to edit_comfy_admin_cms_site_page_path(@site, assigns(:record))
|
79
122
|
assert_equal 'Revision Not Found', flash[:danger]
|
80
123
|
end
|
81
|
-
|
124
|
+
|
125
|
+
def test_get_show_for_translation_failure
|
126
|
+
r :get, comfy_admin_cms_site_page_translation_revision_path(
|
127
|
+
site_id: @site,
|
128
|
+
page_id: @page,
|
129
|
+
translation_id: @translation,
|
130
|
+
id: 'invalid')
|
131
|
+
assert_response :redirect
|
132
|
+
assert assigns(:record)
|
133
|
+
assert_redirected_to edit_comfy_admin_cms_site_page_translation_path(@site, @page, assigns(:record))
|
134
|
+
assert_equal 'Revision Not Found', flash[:danger]
|
135
|
+
end
|
136
|
+
|
82
137
|
def test_get_show_for_snippet_failure
|
83
|
-
|
84
|
-
|
138
|
+
r :get, comfy_admin_cms_site_snippet_revision_path(
|
139
|
+
site_id: @site,
|
140
|
+
snippet_id: @snippet,
|
141
|
+
id: 'invalid')
|
85
142
|
assert_response :redirect
|
86
143
|
assert assigns(:record)
|
87
|
-
assert_redirected_to edit_comfy_admin_cms_site_snippet_path(site, assigns(:record))
|
144
|
+
assert_redirected_to edit_comfy_admin_cms_site_snippet_path(@site, assigns(:record))
|
88
145
|
assert_equal 'Revision Not Found', flash[:danger]
|
89
146
|
end
|
90
|
-
|
147
|
+
|
91
148
|
def test_revert_for_layout
|
92
|
-
layout
|
93
|
-
|
94
|
-
|
95
|
-
|
149
|
+
assert_difference -> {@layout.revisions.count} do
|
150
|
+
r :patch, revert_comfy_admin_cms_site_layout_revision_path(
|
151
|
+
site_id: @site,
|
152
|
+
layout_id: @layout,
|
153
|
+
id: comfy_cms_revisions(:layout)
|
154
|
+
)
|
96
155
|
assert_response :redirect
|
97
|
-
assert_redirected_to edit_comfy_admin_cms_site_layout_path(
|
156
|
+
assert_redirected_to edit_comfy_admin_cms_site_layout_path(@site, @layout)
|
98
157
|
assert_equal 'Content Reverted', flash[:success]
|
99
|
-
|
100
|
-
layout.reload
|
101
|
-
assert_equal 'revision {{cms:
|
102
|
-
assert_equal 'revision css', layout.css
|
103
|
-
assert_equal 'revision js', layout.js
|
158
|
+
|
159
|
+
@layout.reload
|
160
|
+
assert_equal 'revision {{cms:fragment content}}', @layout.content
|
161
|
+
assert_equal 'revision css', @layout.css
|
162
|
+
assert_equal 'revision js', @layout.js
|
104
163
|
end
|
105
164
|
end
|
106
|
-
|
165
|
+
|
107
166
|
def test_revert_for_page
|
108
|
-
page
|
109
|
-
|
110
|
-
|
111
|
-
|
167
|
+
assert_difference -> {@page.revisions.count} do
|
168
|
+
r :patch, revert_comfy_admin_cms_site_page_revision_path(
|
169
|
+
site_id: @site,
|
170
|
+
page_id: @page,
|
171
|
+
id: comfy_cms_revisions(:page)
|
172
|
+
)
|
112
173
|
assert_response :redirect
|
113
|
-
assert_redirected_to edit_comfy_admin_cms_site_page_path(
|
174
|
+
assert_redirected_to edit_comfy_admin_cms_site_page_path(@site, @page)
|
114
175
|
assert_equal 'Content Reverted', flash[:success]
|
115
|
-
|
116
|
-
page.reload
|
176
|
+
|
177
|
+
@page.reload
|
178
|
+
|
117
179
|
assert_equal [
|
118
|
-
{
|
119
|
-
|
120
|
-
|
180
|
+
{ identifier: "boolean",
|
181
|
+
tag: "checkbox",
|
182
|
+
content: nil,
|
183
|
+
datetime: nil,
|
184
|
+
boolean: true },
|
185
|
+
{ identifier: "file",
|
186
|
+
tag: "file",
|
187
|
+
content: nil,
|
188
|
+
datetime: nil,
|
189
|
+
boolean: false },
|
190
|
+
{ identifier: "datetime",
|
191
|
+
tag: "datetime",
|
192
|
+
content: nil,
|
193
|
+
datetime: comfy_cms_fragments(:datetime).datetime,
|
194
|
+
boolean: false },
|
195
|
+
{ identifier: "content",
|
196
|
+
tag: "text",
|
197
|
+
content: "old content",
|
198
|
+
datetime: nil,
|
199
|
+
boolean: false },
|
200
|
+
{ identifier: "title",
|
201
|
+
tag: "text",
|
202
|
+
content: "old title",
|
203
|
+
datetime: nil,
|
204
|
+
boolean: false }
|
205
|
+
], @page.fragments_attributes
|
121
206
|
end
|
122
207
|
end
|
123
|
-
|
208
|
+
|
209
|
+
def test_revert_for_page
|
210
|
+
assert_difference -> {@translation.revisions.count} do
|
211
|
+
r :patch, revert_comfy_admin_cms_site_page_translation_revision_path(
|
212
|
+
site_id: @site,
|
213
|
+
page_id: @page,
|
214
|
+
translation_id: @translation,
|
215
|
+
id: comfy_cms_revisions(:translation)
|
216
|
+
)
|
217
|
+
assert_response :redirect
|
218
|
+
assert_redirected_to edit_comfy_admin_cms_site_page_translation_path(@site, @page, @translation)
|
219
|
+
assert_equal 'Content Reverted', flash[:success]
|
220
|
+
|
221
|
+
@translation.reload
|
222
|
+
|
223
|
+
assert_equal [
|
224
|
+
{ identifier: "content",
|
225
|
+
tag: "text",
|
226
|
+
content: "old content",
|
227
|
+
datetime: nil,
|
228
|
+
boolean: false }
|
229
|
+
], @translation.fragments_attributes
|
230
|
+
end
|
231
|
+
end
|
232
|
+
|
124
233
|
def test_revert_for_snippet
|
125
|
-
snippet
|
126
|
-
|
127
|
-
|
128
|
-
|
234
|
+
assert_difference -> {@snippet.revisions.count} do
|
235
|
+
r :patch, revert_comfy_admin_cms_site_snippet_revision_path(
|
236
|
+
site_id: @site,
|
237
|
+
snippet_id: @snippet,
|
238
|
+
id: comfy_cms_revisions(:snippet)
|
239
|
+
)
|
129
240
|
assert_response :redirect
|
130
|
-
assert_redirected_to edit_comfy_admin_cms_site_snippet_path(
|
241
|
+
assert_redirected_to edit_comfy_admin_cms_site_snippet_path(@site, @snippet)
|
131
242
|
assert_equal 'Content Reverted', flash[:success]
|
132
|
-
|
133
|
-
snippet.reload
|
134
|
-
assert_equal 'revision content', snippet.content
|
243
|
+
|
244
|
+
@snippet.reload
|
245
|
+
assert_equal 'revision content', @snippet.content
|
135
246
|
end
|
136
247
|
end
|
137
|
-
|
138
248
|
end
|
@@ -1,9 +1,9 @@
|
|
1
1
|
require_relative '../../../../test_helper'
|
2
2
|
|
3
|
-
class Comfy::Admin::Cms::SitesControllerTest <
|
3
|
+
class Comfy::Admin::Cms::SitesControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
5
5
|
def test_get_index
|
6
|
-
get
|
6
|
+
r :get, comfy_admin_cms_sites_path
|
7
7
|
assert_response :success
|
8
8
|
assert assigns(:sites)
|
9
9
|
assert_template :index
|
@@ -11,13 +11,13 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionController::TestCase
|
|
11
11
|
|
12
12
|
def test_get_index_with_no_sites
|
13
13
|
Comfy::Cms::Site.delete_all
|
14
|
-
get
|
14
|
+
r :get, comfy_admin_cms_sites_path
|
15
15
|
assert_response :redirect
|
16
|
-
assert_redirected_to
|
16
|
+
assert_redirected_to new_comfy_admin_cms_site_path
|
17
17
|
end
|
18
18
|
|
19
19
|
def test_get_new
|
20
|
-
get
|
20
|
+
r :get, new_comfy_admin_cms_site_path
|
21
21
|
assert_response :success
|
22
22
|
assert assigns(:site)
|
23
23
|
assert_equal 'test.host', assigns(:site).hostname
|
@@ -27,7 +27,7 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionController::TestCase
|
|
27
27
|
|
28
28
|
def test_get_edit
|
29
29
|
site = comfy_cms_sites(:default)
|
30
|
-
|
30
|
+
r :get, edit_comfy_admin_cms_site_path(id: site)
|
31
31
|
assert_response :success
|
32
32
|
assert assigns(:site)
|
33
33
|
assert_template :edit
|
@@ -35,29 +35,29 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionController::TestCase
|
|
35
35
|
end
|
36
36
|
|
37
37
|
def test_get_edit_failure
|
38
|
-
|
38
|
+
r :get, edit_comfy_admin_cms_site_path(id: 'invalid')
|
39
39
|
assert_response :redirect
|
40
|
-
assert_redirected_to :
|
40
|
+
assert_redirected_to action: :index
|
41
41
|
assert_equal 'Site not found', flash[:danger]
|
42
42
|
end
|
43
43
|
|
44
44
|
def test_create
|
45
45
|
assert_difference 'Comfy::Cms::Site.count' do
|
46
|
-
|
47
|
-
:
|
48
|
-
:
|
49
|
-
:
|
50
|
-
}
|
46
|
+
r :post, comfy_admin_cms_sites_path, params: {site: {
|
47
|
+
label: 'Test Site',
|
48
|
+
identifier: 'test-site',
|
49
|
+
hostname: 'test.site.local'
|
50
|
+
}}
|
51
51
|
assert_response :redirect
|
52
52
|
site = Comfy::Cms::Site.last
|
53
|
-
assert_redirected_to comfy_admin_cms_site_layouts_path(site)
|
53
|
+
assert_redirected_to comfy_admin_cms_site_layouts_path(site_id: site)
|
54
54
|
assert_equal 'Site created', flash[:success]
|
55
55
|
end
|
56
56
|
end
|
57
57
|
|
58
58
|
def test_creation_failure
|
59
59
|
assert_no_difference 'Comfy::Cms::Site.count' do
|
60
|
-
|
60
|
+
r :post, comfy_admin_cms_sites_path, params: {site: {}}
|
61
61
|
assert_response :success
|
62
62
|
assert_template :new
|
63
63
|
assert_equal 'Failed to create site', flash[:danger]
|
@@ -66,27 +66,25 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionController::TestCase
|
|
66
66
|
|
67
67
|
def test_update
|
68
68
|
site = comfy_cms_sites(:default)
|
69
|
-
|
70
|
-
:
|
71
|
-
:
|
72
|
-
:
|
73
|
-
|
74
|
-
}
|
69
|
+
r :put, comfy_admin_cms_site_path(id: site), params: {site: {
|
70
|
+
label: 'New Site',
|
71
|
+
hostname: 'new.site.local',
|
72
|
+
locale: 'es'
|
73
|
+
}}
|
75
74
|
assert_response :redirect
|
76
|
-
assert_redirected_to :
|
75
|
+
assert_redirected_to action: :edit, id: site
|
77
76
|
assert_equal 'Site updated', flash[:success]
|
78
77
|
site.reload
|
79
78
|
assert_equal 'New Site', site.label
|
80
79
|
assert_equal 'new.site.local', site.hostname
|
81
80
|
assert_equal 'es', site.locale
|
82
|
-
assert site.is_mirrored?
|
83
81
|
end
|
84
82
|
|
85
83
|
def test_update_failure
|
86
84
|
site = comfy_cms_sites(:default)
|
87
|
-
|
88
|
-
:
|
89
|
-
}
|
85
|
+
r :put, comfy_admin_cms_site_path(id: site), params: {site: {
|
86
|
+
hostname: ''
|
87
|
+
}}
|
90
88
|
assert_response :success
|
91
89
|
assert_template :edit
|
92
90
|
site.reload
|
@@ -96,10 +94,10 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionController::TestCase
|
|
96
94
|
|
97
95
|
def test_destroy
|
98
96
|
assert_difference 'Comfy::Cms::Site.count', -1 do
|
99
|
-
|
97
|
+
r :delete, comfy_admin_cms_site_path(id: comfy_cms_sites(:default))
|
100
98
|
assert_response :redirect
|
101
|
-
assert_redirected_to :
|
99
|
+
assert_redirected_to action: :index
|
102
100
|
assert_equal 'Site deleted', flash[:success]
|
103
101
|
end
|
104
102
|
end
|
105
|
-
end
|
103
|
+
end
|
@@ -1,9 +1,14 @@
|
|
1
1
|
require_relative '../../../../test_helper'
|
2
2
|
|
3
|
-
class Comfy::Admin::Cms::SnippetsControllerTest <
|
3
|
+
class Comfy::Admin::Cms::SnippetsControllerTest < ActionDispatch::IntegrationTest
|
4
|
+
|
5
|
+
setup do
|
6
|
+
@site = comfy_cms_sites(:default)
|
7
|
+
@snippet = comfy_cms_snippets(:default)
|
8
|
+
end
|
4
9
|
|
5
10
|
def test_get_index
|
6
|
-
|
11
|
+
r :get, comfy_admin_cms_site_snippets_path(site_id: @site)
|
7
12
|
assert_response :success
|
8
13
|
assert assigns(:snippets)
|
9
14
|
assert_template :index
|
@@ -11,19 +16,19 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionController::TestCase
|
|
11
16
|
|
12
17
|
def test_get_index_with_no_snippets
|
13
18
|
Comfy::Cms::Snippet.delete_all
|
14
|
-
|
19
|
+
r :get, comfy_admin_cms_site_snippets_path(site_id: @site)
|
15
20
|
assert_response :redirect
|
16
|
-
assert_redirected_to :
|
21
|
+
assert_redirected_to action: :new
|
17
22
|
end
|
18
23
|
|
19
24
|
def test_get_index_with_category
|
20
|
-
category =
|
21
|
-
:
|
22
|
-
:
|
25
|
+
category = @site.categories.create!(
|
26
|
+
label: 'Test Category',
|
27
|
+
categorized_type: 'Comfy::Cms::Snippet'
|
23
28
|
)
|
24
|
-
category.categorizations.create!(:
|
29
|
+
category.categorizations.create!(categorized: @snippet)
|
25
30
|
|
26
|
-
|
31
|
+
r :get, comfy_admin_cms_site_snippets_path(site_id: @site), params: {categories: category.label}
|
27
32
|
assert_response :success
|
28
33
|
assert assigns(:snippets)
|
29
34
|
assert_equal 1, assigns(:snippets).count
|
@@ -31,63 +36,62 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionController::TestCase
|
|
31
36
|
end
|
32
37
|
|
33
38
|
def test_get_index_with_category_invalid
|
34
|
-
|
39
|
+
r :get, comfy_admin_cms_site_snippets_path(site_id: @site), params: {categories: 'invalid'}
|
35
40
|
assert_response :success
|
36
41
|
assert assigns(:snippets)
|
37
42
|
assert_equal 0, assigns(:snippets).count
|
38
43
|
end
|
39
44
|
|
40
45
|
def test_get_new
|
41
|
-
|
42
|
-
get :new, :site_id => site
|
46
|
+
r :get, new_comfy_admin_cms_site_snippet_path(site_id: @site)
|
43
47
|
assert_response :success
|
44
48
|
assert assigns(:snippet)
|
45
49
|
assert_template :new
|
46
|
-
assert_select "form[action='/admin/sites/#{site.id}/snippets']"
|
50
|
+
assert_select "form[action='/admin/sites/#{@site.id}/snippets']"
|
47
51
|
end
|
48
52
|
|
49
53
|
def test_get_edit
|
50
|
-
|
51
|
-
get :edit, :site_id => snippet.site, :id => snippet
|
54
|
+
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet)
|
52
55
|
assert_response :success
|
53
56
|
assert assigns(:snippet)
|
54
57
|
assert_template :edit
|
55
|
-
assert_select "form[action='/admin/sites/#{
|
58
|
+
assert_select "form[action='/admin/sites/#{@site.id}/snippets/#{@snippet.id}']"
|
56
59
|
end
|
57
60
|
|
58
61
|
def test_get_edit_with_params
|
59
|
-
|
60
|
-
|
62
|
+
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: {snippet: {
|
63
|
+
label: 'New Label'
|
64
|
+
}}
|
61
65
|
assert_response :success
|
62
66
|
assert assigns(:snippet)
|
63
67
|
assert_equal 'New Label', assigns(:snippet).label
|
64
68
|
end
|
65
69
|
|
66
70
|
def test_get_edit_failure
|
67
|
-
|
71
|
+
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id: 'invalid')
|
68
72
|
assert_response :redirect
|
69
|
-
assert_redirected_to :
|
73
|
+
assert_redirected_to action: :index
|
70
74
|
assert_equal 'Snippet not found', flash[:danger]
|
71
75
|
end
|
72
76
|
|
73
77
|
def test_create
|
74
78
|
assert_difference 'Comfy::Cms::Snippet.count' do
|
75
|
-
|
76
|
-
:
|
77
|
-
:
|
78
|
-
:
|
79
|
-
}
|
79
|
+
r :post, comfy_admin_cms_site_snippets_path(site_id: @site), params: {snippet: {
|
80
|
+
label: 'Test Snippet',
|
81
|
+
identifier: 'test-snippet',
|
82
|
+
content: 'Test Content'
|
83
|
+
}}
|
80
84
|
assert_response :redirect
|
81
85
|
snippet = Comfy::Cms::Snippet.last
|
82
|
-
assert_equal
|
83
|
-
assert_redirected_to :
|
86
|
+
assert_equal @site, snippet.site
|
87
|
+
assert_redirected_to action: :edit, id: snippet
|
84
88
|
assert_equal 'Snippet created', flash[:success]
|
85
89
|
end
|
86
90
|
end
|
87
91
|
|
88
92
|
def test_creation_failure
|
89
93
|
assert_no_difference 'Comfy::Cms::Snippet.count' do
|
90
|
-
|
94
|
+
r :post, comfy_admin_cms_site_snippets_path(site_id: @site), params: {snippet: { }}
|
91
95
|
assert_response :success
|
92
96
|
assert_template :new
|
93
97
|
assert_equal 'Failed to create snippet', flash[:danger]
|
@@ -95,50 +99,50 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionController::TestCase
|
|
95
99
|
end
|
96
100
|
|
97
101
|
def test_update
|
98
|
-
|
99
|
-
|
100
|
-
:
|
101
|
-
|
102
|
-
}
|
102
|
+
r :put, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: {snippet: {
|
103
|
+
label: 'New-Snippet',
|
104
|
+
content: 'New Content'
|
105
|
+
}}
|
103
106
|
assert_response :redirect
|
104
|
-
assert_redirected_to :
|
107
|
+
assert_redirected_to action: :edit, site_id: @site, id: @snippet
|
105
108
|
assert_equal 'Snippet updated', flash[:success]
|
106
|
-
snippet.reload
|
107
|
-
assert_equal 'New-Snippet', snippet.label
|
108
|
-
assert_equal 'New Content', snippet.content
|
109
|
+
@snippet.reload
|
110
|
+
assert_equal 'New-Snippet', @snippet.label
|
111
|
+
assert_equal 'New Content', @snippet.content
|
109
112
|
end
|
110
113
|
|
111
114
|
def test_update_failure
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
}
|
115
|
+
r :put, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: {snippet: {
|
116
|
+
identifier: ''
|
117
|
+
}}
|
116
118
|
assert_response :success
|
117
119
|
assert_template :edit
|
118
|
-
snippet.reload
|
119
|
-
assert_not_equal '', snippet.identifier
|
120
|
+
@snippet.reload
|
121
|
+
assert_not_equal '', @snippet.identifier
|
120
122
|
assert_equal 'Failed to update snippet', flash[:danger]
|
121
123
|
end
|
122
124
|
|
123
125
|
def test_destroy
|
124
126
|
assert_difference 'Comfy::Cms::Snippet.count', -1 do
|
125
|
-
|
127
|
+
r :delete, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet)
|
126
128
|
assert_response :redirect
|
127
|
-
assert_redirected_to :
|
129
|
+
assert_redirected_to action: :index
|
128
130
|
assert_equal 'Snippet deleted', flash[:success]
|
129
131
|
end
|
130
132
|
end
|
131
133
|
|
132
134
|
def test_reorder
|
133
|
-
snippet_one =
|
134
|
-
snippet_two =
|
135
|
-
:
|
136
|
-
:
|
135
|
+
snippet_one = @snippet
|
136
|
+
snippet_two = @site.snippets.create!(
|
137
|
+
label: 'test',
|
138
|
+
identifier: 'test'
|
137
139
|
)
|
138
140
|
assert_equal 0, snippet_one.position
|
139
141
|
assert_equal 1, snippet_two.position
|
140
142
|
|
141
|
-
|
143
|
+
r :put, reorder_comfy_admin_cms_site_snippets_path(site_id: @site), params: {
|
144
|
+
comfy_cms_snippet: [snippet_two.id, snippet_one.id]
|
145
|
+
}
|
142
146
|
assert_response :success
|
143
147
|
snippet_one.reload
|
144
148
|
snippet_two.reload
|
@@ -146,5 +150,4 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionController::TestCase
|
|
146
150
|
assert_equal 1, snippet_one.position
|
147
151
|
assert_equal 0, snippet_two.position
|
148
152
|
end
|
149
|
-
|
150
153
|
end
|