comfortable_mexican_sofa 2.0.2 → 2.0.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +95 -4
- data/.travis.yml +2 -1
- data/CONTRIBUTING.md +8 -5
- data/Gemfile +9 -9
- data/Rakefile +1 -1
- data/app/assets/javascripts/comfy/admin/cms/base.js.coffee +1 -0
- data/app/assets/stylesheets/comfy/admin/cms/base.sass +14 -4
- data/app/controllers/application_controller.rb +2 -2
- data/app/controllers/comfy/admin/base_controller.rb +1 -1
- data/app/controllers/comfy/admin/cms/base_controller.rb +7 -6
- data/app/controllers/comfy/admin/cms/categories_controller.rb +2 -1
- data/app/controllers/comfy/admin/cms/files_controller.rb +32 -29
- data/app/controllers/comfy/admin/cms/layouts_controller.rb +10 -9
- data/app/controllers/comfy/admin/cms/pages_controller.rb +31 -27
- data/app/controllers/comfy/admin/cms/revisions/base_controller.rb +5 -4
- data/app/controllers/comfy/admin/cms/revisions/layout_controller.rb +2 -1
- data/app/controllers/comfy/admin/cms/revisions/page_controller.rb +9 -3
- data/app/controllers/comfy/admin/cms/revisions/snippet_controller.rb +2 -1
- data/app/controllers/comfy/admin/cms/revisions/translation_controller.rb +9 -3
- data/app/controllers/comfy/admin/cms/sites_controller.rb +10 -9
- data/app/controllers/comfy/admin/cms/snippets_controller.rb +10 -9
- data/app/controllers/comfy/admin/cms/translations_controller.rb +15 -14
- data/app/controllers/comfy/cms/assets_controller.rb +4 -3
- data/app/controllers/comfy/cms/base_controller.rb +12 -11
- data/app/controllers/comfy/cms/content_controller.rb +8 -7
- data/app/controllers/concerns/comfy/paginate.rb +2 -1
- data/app/helpers/comfy/cms_helper.rb +6 -3
- data/app/models/comfy/cms/categorization.rb +2 -1
- data/app/models/comfy/cms/category.rb +3 -2
- data/app/models/comfy/cms/file.rb +9 -7
- data/app/models/comfy/cms/fragment.rb +8 -6
- data/app/models/comfy/cms/layout.rb +24 -24
- data/app/models/comfy/cms/page.rb +51 -32
- data/app/models/comfy/cms/revision.rb +2 -1
- data/app/models/comfy/cms/site.rb +27 -26
- data/app/models/comfy/cms/snippet.rb +7 -5
- data/app/models/comfy/cms/translation.rb +6 -4
- data/app/models/concerns/comfy/cms/with_categories.rb +9 -7
- data/app/models/concerns/comfy/cms/with_fragments.rb +15 -13
- data/app/views/comfy/admin/cms/categories/_categories.html.haml +1 -1
- data/app/views/comfy/admin/cms/files/_file.html.haml +3 -3
- data/app/views/comfy/admin/cms/files/_modal.html.haml +2 -2
- data/app/views/comfy/admin/cms/{pages/_fragment_attachments.html.haml → fragments/_form_fragment_attachments.html.haml} +0 -0
- data/app/views/comfy/admin/cms/{pages → fragments}/_form_fragments.html.haml +0 -0
- data/app/views/comfy/admin/cms/layouts/_index_branch.html.haml +2 -2
- data/app/views/comfy/admin/cms/pages/_form.html.haml +7 -7
- data/app/views/comfy/admin/cms/pages/_index_branch.html.haml +16 -15
- data/app/views/comfy/admin/cms/pages/form_fragments.js.erb +1 -1
- data/app/views/comfy/admin/cms/pages/toggle_branch.js.erb +1 -1
- data/app/views/comfy/admin/cms/snippets/index.html.haml +3 -3
- data/app/views/comfy/admin/cms/translations/_form.html.haml +1 -1
- data/app/views/comfy/admin/cms/translations/form_fragments.js.erb +1 -1
- data/app/views/layouts/comfy/admin/cms/_body.html.haml +1 -4
- data/app/views/layouts/comfy/admin/cms.html.haml +1 -1
- data/bin/bundle +3 -0
- data/bin/rails +4 -0
- data/bin/rake +4 -0
- data/bin/setup +36 -0
- data/bin/update +31 -0
- data/bin/yarn +11 -0
- data/comfortable_mexican_sofa.gemspec +14 -14
- data/config/application.rb +4 -3
- data/config/boot.rb +3 -3
- data/config/cms_routes.rb +1 -1
- data/config/environment.rb +1 -1
- data/config/environments/development.rb +2 -2
- data/config/environments/test.rb +1 -1
- data/config/initializers/comfortable_mexican_sofa.rb +2 -5
- data/config/locales/cs.yml +2 -1
- data/config/locales/da.yml +2 -1
- data/config/locales/de.yml +2 -1
- data/config/locales/en.yml +2 -1
- data/config/locales/es.yml +2 -1
- data/config/locales/fr.yml +2 -1
- data/config/locales/it.yml +2 -1
- data/config/locales/ja.yml +2 -1
- data/config/locales/nb.yml +2 -1
- data/config/locales/nl.yml +2 -1
- data/config/locales/pl.yml +2 -1
- data/config/locales/pt-BR.yml +2 -1
- data/config/locales/ru.yml +2 -1
- data/config/locales/sk.yml +2 -1
- data/config/locales/sv.yml +2 -1
- data/config/locales/tr.yml +2 -1
- data/config/locales/uk.yml +2 -1
- data/config/locales/zh-CN.yml +2 -1
- data/config/locales/zh-TW.yml +2 -1
- data/config.ru +1 -1
- data/lib/comfortable_mexican_sofa/access_control/admin_authentication.rb +2 -1
- data/lib/comfortable_mexican_sofa/access_control/admin_authorization.rb +2 -0
- data/lib/comfortable_mexican_sofa/access_control/public_authentication.rb +3 -1
- data/lib/comfortable_mexican_sofa/access_control/public_authorization.rb +2 -0
- data/lib/comfortable_mexican_sofa/configuration.rb +27 -29
- data/lib/comfortable_mexican_sofa/content/block.rb +2 -1
- data/lib/comfortable_mexican_sofa/content/params_parser.rb +22 -21
- data/lib/comfortable_mexican_sofa/content/renderer.rb +10 -8
- data/lib/comfortable_mexican_sofa/content/tag.rb +1 -0
- data/lib/comfortable_mexican_sofa/content/tags/asset.rb +4 -3
- data/lib/comfortable_mexican_sofa/content/tags/checkbox.rb +3 -2
- data/lib/comfortable_mexican_sofa/content/tags/date.rb +4 -3
- data/lib/comfortable_mexican_sofa/content/tags/datetime.rb +4 -3
- data/lib/comfortable_mexican_sofa/content/tags/file.rb +15 -13
- data/lib/comfortable_mexican_sofa/content/tags/file_link.rb +8 -7
- data/lib/comfortable_mexican_sofa/content/tags/files.rb +15 -13
- data/lib/comfortable_mexican_sofa/content/tags/fragment.rb +7 -6
- data/lib/comfortable_mexican_sofa/content/tags/helper.rb +2 -1
- data/lib/comfortable_mexican_sofa/content/tags/markdown.rb +5 -4
- data/lib/comfortable_mexican_sofa/content/tags/number.rb +4 -3
- data/lib/comfortable_mexican_sofa/content/tags/partial.rb +1 -0
- data/lib/comfortable_mexican_sofa/content/tags/snippet.rb +3 -2
- data/lib/comfortable_mexican_sofa/content/tags/template.rb +1 -0
- data/lib/comfortable_mexican_sofa/content/tags/text.rb +4 -3
- data/lib/comfortable_mexican_sofa/content/tags/textarea.rb +4 -3
- data/lib/comfortable_mexican_sofa/content/tags/wysiwyg.rb +4 -3
- data/lib/comfortable_mexican_sofa/content.rb +21 -21
- data/lib/comfortable_mexican_sofa/engine.rb +17 -15
- data/lib/comfortable_mexican_sofa/error.rb +12 -6
- data/lib/comfortable_mexican_sofa/extensions/acts_as_tree.rb +17 -11
- data/lib/comfortable_mexican_sofa/extensions/has_revisions.rb +14 -13
- data/lib/comfortable_mexican_sofa/form_builder.rb +2 -2
- data/lib/comfortable_mexican_sofa/render_methods.rb +74 -76
- data/lib/comfortable_mexican_sofa/routes/cms.rb +4 -4
- data/lib/comfortable_mexican_sofa/routes/cms_admin.rb +2 -1
- data/lib/comfortable_mexican_sofa/routing.rb +4 -2
- data/lib/comfortable_mexican_sofa/seeds/file/exporter.rb +7 -6
- data/lib/comfortable_mexican_sofa/seeds/file/importer.rb +9 -9
- data/lib/comfortable_mexican_sofa/seeds/layout/exporter.rb +8 -7
- data/lib/comfortable_mexican_sofa/seeds/layout/importer.rb +11 -10
- data/lib/comfortable_mexican_sofa/seeds/page/exporter.rb +25 -23
- data/lib/comfortable_mexican_sofa/seeds/page/importer.rb +47 -43
- data/lib/comfortable_mexican_sofa/seeds/snippet/exporter.rb +7 -6
- data/lib/comfortable_mexican_sofa/seeds/snippet/importer.rb +7 -6
- data/lib/comfortable_mexican_sofa/seeds.rb +16 -9
- data/lib/comfortable_mexican_sofa/version.rb +4 -2
- data/lib/comfortable_mexican_sofa/view_hooks.rb +10 -9
- data/lib/comfortable_mexican_sofa.rb +30 -30
- data/lib/generators/comfy/cms/assets_generator.rb +6 -4
- data/lib/generators/comfy/cms/cms_generator.rb +14 -14
- data/lib/generators/comfy/cms/controllers_generator.rb +5 -3
- data/lib/generators/comfy/cms/models_generator.rb +5 -3
- data/lib/generators/comfy/cms/views_generator.rb +5 -3
- data/lib/generators/comfy/scaffold/scaffold_generator.rb +19 -18
- data/lib/tasks/cms_seeds.rake +4 -5
- data/test/controllers/comfy/admin/cms/base_controller_test.rb +4 -3
- data/test/controllers/comfy/admin/cms/categories_controller_test.rb +19 -18
- data/test/controllers/comfy/admin/cms/files_controller_test.rb +19 -19
- data/test/controllers/comfy/admin/cms/layouts_controller_test.rb +33 -32
- data/test/controllers/comfy/admin/cms/pages_controller_test.rb +99 -98
- data/test/controllers/comfy/admin/cms/revisions/layout_controller_test.rb +9 -9
- data/test/controllers/comfy/admin/cms/revisions/page_controller_test.rb +6 -6
- data/test/controllers/comfy/admin/cms/revisions/snippet_controller_test.rb +9 -8
- data/test/controllers/comfy/admin/cms/revisions/translation_controller_test.rb +6 -7
- data/test/controllers/comfy/admin/cms/sites_controller_test.rb +31 -30
- data/test/controllers/comfy/admin/cms/snippets_controller_test.rb +38 -37
- data/test/controllers/comfy/admin/cms/translations_controller_test.rb +21 -20
- data/test/controllers/comfy/cms/assets_controller_test.rb +14 -13
- data/test/controllers/comfy/cms/content_controller_test.rb +58 -57
- data/test/gemfiles/Gemfile.rails.5.2 +5 -4
- data/test/generators/cms_assets_generator_test.rb +6 -4
- data/test/generators/cms_controllers_generator_test.rb +7 -5
- data/test/generators/cms_generator_test.rb +12 -10
- data/test/generators/cms_models_generator_test.rb +7 -5
- data/test/generators/cms_views_generator_test.rb +6 -4
- data/test/generators/scaffold_generator_test.rb +18 -16
- data/test/helpers/cms_helper_test.rb +5 -2
- data/test/integration/access_control_test.rb +29 -20
- data/test/integration/i18n_test.rb +8 -7
- data/test/integration/js_variables_test.rb +2 -1
- data/test/integration/render_cms_test.rb +93 -88
- data/test/integration/routing_test.rb +4 -3
- data/test/integration/seeds_test.rb +21 -22
- data/test/integration/sites_test.rb +26 -25
- data/test/integration/view_hooks_test.rb +15 -14
- data/test/lib/configuration_test.rb +13 -15
- data/test/lib/content/block_test.rb +1 -1
- data/test/lib/content/params_parser_test.rb +11 -10
- data/test/lib/content/renderer_test.rb +16 -11
- data/test/lib/content/tag_test.rb +7 -3
- data/test/lib/content/tags/asset_test.rb +4 -3
- data/test/lib/content/tags/checkbox_test.rb +2 -1
- data/test/lib/content/tags/date_test.rb +2 -1
- data/test/lib/content/tags/datetime_test.rb +2 -1
- data/test/lib/content/tags/file_link_test.rb +3 -2
- data/test/lib/content/tags/file_test.rb +3 -2
- data/test/lib/content/tags/files_test.rb +4 -3
- data/test/lib/content/tags/fragment_test.rb +2 -1
- data/test/lib/content/tags/helper_test.rb +4 -3
- data/test/lib/content/tags/markdown_test.rb +2 -1
- data/test/lib/content/tags/number_test.rb +2 -1
- data/test/lib/content/tags/partial_test.rb +4 -3
- data/test/lib/content/tags/snippet_test.rb +2 -1
- data/test/lib/content/tags/template_test.rb +2 -1
- data/test/lib/content/tags/text_test.rb +2 -1
- data/test/lib/content/tags/textarea_test.rb +2 -1
- data/test/lib/content/tags/wysiwyg_test.rb +2 -1
- data/test/lib/revisions_test.rb +44 -42
- data/test/lib/seeds/files_test.rb +30 -29
- data/test/lib/seeds/layouts_test.rb +13 -12
- data/test/lib/seeds/pages_test.rb +32 -29
- data/test/lib/seeds/snippets_test.rb +21 -20
- data/test/lib/seeds_test.rb +9 -8
- data/test/models/categorization_test.rb +10 -9
- data/test/models/category_test.rb +1 -1
- data/test/models/file_test.rb +1 -1
- data/test/models/fragment_test.rb +11 -10
- data/test/models/layout_test.rb +71 -70
- data/test/models/page_test.rb +170 -159
- data/test/models/site_test.rb +17 -16
- data/test/models/snippet_test.rb +1 -0
- data/test/models/translation_test.rb +2 -1
- data/test/tasks/cms_seeds_test.rb +3 -2
- data/test/test_helper.rb +42 -40
- metadata +55 -51
- data/.rubocop_todo.yml +0 -974
- data/script/rails +0 -6
@@ -1,4 +1,4 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../../../../../test_helper"
|
2
2
|
|
3
3
|
class Comfy::Admin::Cms::Revisions::SnippetControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
@@ -34,26 +34,27 @@ class Comfy::Admin::Cms::Revisions::SnippetControllerTest < ActionDispatch::Inte
|
|
34
34
|
r :get, comfy_admin_cms_site_snippet_revision_path(@site, "invalid", @revision)
|
35
35
|
assert_response :redirect
|
36
36
|
assert_redirected_to comfy_admin_cms_site_snippets_path(@site)
|
37
|
-
assert_equal
|
37
|
+
assert_equal "Record Not Found", flash[:danger]
|
38
38
|
end
|
39
39
|
|
40
40
|
def test_get_show_failure
|
41
|
-
r :get, comfy_admin_cms_site_snippet_revision_path(@site, @snippet,
|
41
|
+
r :get, comfy_admin_cms_site_snippet_revision_path(@site, @snippet, "invalid")
|
42
42
|
assert_response :redirect
|
43
43
|
assert assigns(:record)
|
44
44
|
assert_redirected_to edit_comfy_admin_cms_site_snippet_path(@site, assigns(:record))
|
45
|
-
assert_equal
|
45
|
+
assert_equal "Revision Not Found", flash[:danger]
|
46
46
|
end
|
47
47
|
|
48
|
-
|
49
|
-
assert_difference -> {@snippet.revisions.count} do
|
48
|
+
def test_revert
|
49
|
+
assert_difference -> { @snippet.revisions.count } do
|
50
50
|
r :patch, revert_comfy_admin_cms_site_snippet_revision_path(@site, @snippet, @revision)
|
51
51
|
assert_response :redirect
|
52
52
|
assert_redirected_to edit_comfy_admin_cms_site_snippet_path(@site, @snippet)
|
53
|
-
assert_equal
|
53
|
+
assert_equal "Content Reverted", flash[:success]
|
54
54
|
|
55
55
|
@snippet.reload
|
56
|
-
assert_equal
|
56
|
+
assert_equal "revision content", @snippet.content
|
57
57
|
end
|
58
58
|
end
|
59
|
+
|
59
60
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../../../../../test_helper"
|
2
2
|
|
3
3
|
class Comfy::Admin::Cms::Revisions::TranslationControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
@@ -35,24 +35,23 @@ class Comfy::Admin::Cms::Revisions::TranslationControllerTest < ActionDispatch::
|
|
35
35
|
r :get, comfy_admin_cms_site_page_translation_revision_path(@site, @page, "invalid", @revision)
|
36
36
|
assert_response :redirect
|
37
37
|
assert_redirected_to comfy_admin_cms_site_pages_path(@site)
|
38
|
-
assert_equal
|
38
|
+
assert_equal "Record Not Found", flash[:danger]
|
39
39
|
end
|
40
40
|
|
41
|
-
|
42
41
|
def test_get_show_failure
|
43
|
-
r :get, comfy_admin_cms_site_page_translation_revision_path(@site, @page, @translation,
|
42
|
+
r :get, comfy_admin_cms_site_page_translation_revision_path(@site, @page, @translation, "invalid")
|
44
43
|
assert_response :redirect
|
45
44
|
assert assigns(:record)
|
46
45
|
assert_redirected_to edit_comfy_admin_cms_site_page_translation_path(@site, @page, assigns(:record))
|
47
|
-
assert_equal
|
46
|
+
assert_equal "Revision Not Found", flash[:danger]
|
48
47
|
end
|
49
48
|
|
50
49
|
def test_revert
|
51
|
-
assert_difference -> {@translation.revisions.count} do
|
50
|
+
assert_difference -> { @translation.revisions.count } do
|
52
51
|
r :patch, revert_comfy_admin_cms_site_page_translation_revision_path(@site, @page, @translation, @revision)
|
53
52
|
assert_response :redirect
|
54
53
|
assert_redirected_to edit_comfy_admin_cms_site_page_translation_path(@site, @page, @translation)
|
55
|
-
assert_equal
|
54
|
+
assert_equal "Content Reverted", flash[:success]
|
56
55
|
|
57
56
|
@translation.reload
|
58
57
|
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../../../../test_helper"
|
2
2
|
|
3
3
|
class Comfy::Admin::Cms::SitesControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
@@ -20,7 +20,7 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionDispatch::IntegrationTest
|
|
20
20
|
r :get, new_comfy_admin_cms_site_path
|
21
21
|
assert_response :success
|
22
22
|
assert assigns(:site)
|
23
|
-
assert_equal
|
23
|
+
assert_equal "test.host", assigns(:site).hostname
|
24
24
|
assert_template :new
|
25
25
|
assert_select "form[action='/admin/sites']"
|
26
26
|
end
|
@@ -35,69 +35,70 @@ class Comfy::Admin::Cms::SitesControllerTest < ActionDispatch::IntegrationTest
|
|
35
35
|
end
|
36
36
|
|
37
37
|
def test_get_edit_failure
|
38
|
-
r :get, edit_comfy_admin_cms_site_path(id:
|
38
|
+
r :get, edit_comfy_admin_cms_site_path(id: "invalid")
|
39
39
|
assert_response :redirect
|
40
40
|
assert_redirected_to action: :index
|
41
|
-
assert_equal
|
41
|
+
assert_equal "Site not found", flash[:danger]
|
42
42
|
end
|
43
43
|
|
44
44
|
def test_create
|
45
|
-
assert_difference
|
46
|
-
r :post, comfy_admin_cms_sites_path, params: {site: {
|
47
|
-
label:
|
48
|
-
identifier:
|
49
|
-
hostname:
|
50
|
-
}}
|
45
|
+
assert_difference "Comfy::Cms::Site.count" do
|
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
53
|
assert_redirected_to comfy_admin_cms_site_layouts_path(site_id: site)
|
54
|
-
assert_equal
|
54
|
+
assert_equal "Site created", flash[:success]
|
55
55
|
end
|
56
56
|
end
|
57
57
|
|
58
58
|
def test_creation_failure
|
59
|
-
assert_no_difference
|
60
|
-
r :post, comfy_admin_cms_sites_path, params: {site: {}}
|
59
|
+
assert_no_difference "Comfy::Cms::Site.count" do
|
60
|
+
r :post, comfy_admin_cms_sites_path, params: { site: {} }
|
61
61
|
assert_response :success
|
62
62
|
assert_template :new
|
63
|
-
assert_equal
|
63
|
+
assert_equal "Failed to create site", flash[:danger]
|
64
64
|
end
|
65
65
|
end
|
66
66
|
|
67
67
|
def test_update
|
68
68
|
site = comfy_cms_sites(:default)
|
69
|
-
r :put, comfy_admin_cms_site_path(id: site), params: {site: {
|
70
|
-
label:
|
71
|
-
hostname:
|
72
|
-
locale:
|
73
|
-
}}
|
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
|
+
} }
|
74
74
|
assert_response :redirect
|
75
75
|
assert_redirected_to action: :edit, id: site
|
76
|
-
assert_equal
|
76
|
+
assert_equal "Site updated", flash[:success]
|
77
77
|
site.reload
|
78
|
-
assert_equal
|
79
|
-
assert_equal
|
80
|
-
assert_equal
|
78
|
+
assert_equal "New Site", site.label
|
79
|
+
assert_equal "new.site.local", site.hostname
|
80
|
+
assert_equal "es", site.locale
|
81
81
|
end
|
82
82
|
|
83
83
|
def test_update_failure
|
84
84
|
site = comfy_cms_sites(:default)
|
85
|
-
r :put, comfy_admin_cms_site_path(id: site), params: {site: {
|
86
|
-
hostname:
|
87
|
-
}}
|
85
|
+
r :put, comfy_admin_cms_site_path(id: site), params: { site: {
|
86
|
+
hostname: ""
|
87
|
+
} }
|
88
88
|
assert_response :success
|
89
89
|
assert_template :edit
|
90
90
|
site.reload
|
91
|
-
assert_not_equal
|
92
|
-
assert_equal
|
91
|
+
assert_not_equal "", site.hostname
|
92
|
+
assert_equal "Failed to update site", flash[:danger]
|
93
93
|
end
|
94
94
|
|
95
95
|
def test_destroy
|
96
|
-
assert_difference
|
96
|
+
assert_difference "Comfy::Cms::Site.count", -1 do
|
97
97
|
r :delete, comfy_admin_cms_site_path(id: comfy_cms_sites(:default))
|
98
98
|
assert_response :redirect
|
99
99
|
assert_redirected_to action: :index
|
100
|
-
assert_equal
|
100
|
+
assert_equal "Site deleted", flash[:success]
|
101
101
|
end
|
102
102
|
end
|
103
|
+
|
103
104
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../../../../test_helper"
|
2
2
|
|
3
3
|
class Comfy::Admin::Cms::SnippetsControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
@@ -23,12 +23,12 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionDispatch::IntegrationTes
|
|
23
23
|
|
24
24
|
def test_get_index_with_category
|
25
25
|
category = @site.categories.create!(
|
26
|
-
label:
|
27
|
-
categorized_type:
|
26
|
+
label: "Test Category",
|
27
|
+
categorized_type: "Comfy::Cms::Snippet"
|
28
28
|
)
|
29
29
|
category.categorizations.create!(categorized: @snippet)
|
30
30
|
|
31
|
-
r :get, comfy_admin_cms_site_snippets_path(site_id: @site), params: {categories: category.label}
|
31
|
+
r :get, comfy_admin_cms_site_snippets_path(site_id: @site), params: { categories: category.label }
|
32
32
|
assert_response :success
|
33
33
|
assert assigns(:snippets)
|
34
34
|
assert_equal 1, assigns(:snippets).count
|
@@ -36,7 +36,7 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionDispatch::IntegrationTes
|
|
36
36
|
end
|
37
37
|
|
38
38
|
def test_get_index_with_category_invalid
|
39
|
-
r :get, comfy_admin_cms_site_snippets_path(site_id: @site), params: {categories:
|
39
|
+
r :get, comfy_admin_cms_site_snippets_path(site_id: @site), params: { categories: "invalid" }
|
40
40
|
assert_response :success
|
41
41
|
assert assigns(:snippets)
|
42
42
|
assert_equal 0, assigns(:snippets).count
|
@@ -59,83 +59,83 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionDispatch::IntegrationTes
|
|
59
59
|
end
|
60
60
|
|
61
61
|
def test_get_edit_with_params
|
62
|
-
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: {snippet: {
|
63
|
-
label:
|
64
|
-
}}
|
62
|
+
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: { snippet: {
|
63
|
+
label: "New Label"
|
64
|
+
} }
|
65
65
|
assert_response :success
|
66
66
|
assert assigns(:snippet)
|
67
|
-
assert_equal
|
67
|
+
assert_equal "New Label", assigns(:snippet).label
|
68
68
|
end
|
69
69
|
|
70
70
|
def test_get_edit_failure
|
71
|
-
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id:
|
71
|
+
r :get, edit_comfy_admin_cms_site_snippet_path(site_id: @site, id: "invalid")
|
72
72
|
assert_response :redirect
|
73
73
|
assert_redirected_to action: :index
|
74
|
-
assert_equal
|
74
|
+
assert_equal "Snippet not found", flash[:danger]
|
75
75
|
end
|
76
76
|
|
77
77
|
def test_create
|
78
|
-
assert_difference
|
79
|
-
r :post, comfy_admin_cms_site_snippets_path(site_id: @site), params: {snippet: {
|
80
|
-
label:
|
81
|
-
identifier:
|
82
|
-
content:
|
83
|
-
}}
|
78
|
+
assert_difference "Comfy::Cms::Snippet.count" do
|
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
|
+
} }
|
84
84
|
assert_response :redirect
|
85
85
|
snippet = Comfy::Cms::Snippet.last
|
86
86
|
assert_equal @site, snippet.site
|
87
87
|
assert_redirected_to action: :edit, id: snippet
|
88
|
-
assert_equal
|
88
|
+
assert_equal "Snippet created", flash[:success]
|
89
89
|
end
|
90
90
|
end
|
91
91
|
|
92
92
|
def test_creation_failure
|
93
|
-
assert_no_difference
|
94
|
-
r :post, comfy_admin_cms_site_snippets_path(site_id: @site), params: {snippet: { }
|
93
|
+
assert_no_difference "Comfy::Cms::Snippet.count" do
|
94
|
+
r :post, comfy_admin_cms_site_snippets_path(site_id: @site), params: { snippet: {} }
|
95
95
|
assert_response :success
|
96
96
|
assert_template :new
|
97
|
-
assert_equal
|
97
|
+
assert_equal "Failed to create snippet", flash[:danger]
|
98
98
|
end
|
99
99
|
end
|
100
100
|
|
101
101
|
def test_update
|
102
|
-
r :put, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: {snippet: {
|
103
|
-
label:
|
104
|
-
content:
|
105
|
-
}}
|
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
|
+
} }
|
106
106
|
assert_response :redirect
|
107
107
|
assert_redirected_to action: :edit, site_id: @site, id: @snippet
|
108
|
-
assert_equal
|
108
|
+
assert_equal "Snippet updated", flash[:success]
|
109
109
|
@snippet.reload
|
110
|
-
assert_equal
|
111
|
-
assert_equal
|
110
|
+
assert_equal "New-Snippet", @snippet.label
|
111
|
+
assert_equal "New Content", @snippet.content
|
112
112
|
end
|
113
113
|
|
114
114
|
def test_update_failure
|
115
|
-
r :put, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: {snippet: {
|
116
|
-
identifier:
|
117
|
-
}}
|
115
|
+
r :put, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet), params: { snippet: {
|
116
|
+
identifier: ""
|
117
|
+
} }
|
118
118
|
assert_response :success
|
119
119
|
assert_template :edit
|
120
120
|
@snippet.reload
|
121
|
-
assert_not_equal
|
122
|
-
assert_equal
|
121
|
+
assert_not_equal "", @snippet.identifier
|
122
|
+
assert_equal "Failed to update snippet", flash[:danger]
|
123
123
|
end
|
124
124
|
|
125
125
|
def test_destroy
|
126
|
-
assert_difference
|
126
|
+
assert_difference "Comfy::Cms::Snippet.count", -1 do
|
127
127
|
r :delete, comfy_admin_cms_site_snippet_path(site_id: @site, id: @snippet)
|
128
128
|
assert_response :redirect
|
129
129
|
assert_redirected_to action: :index
|
130
|
-
assert_equal
|
130
|
+
assert_equal "Snippet deleted", flash[:success]
|
131
131
|
end
|
132
132
|
end
|
133
133
|
|
134
134
|
def test_reorder
|
135
135
|
snippet_one = @snippet
|
136
136
|
snippet_two = @site.snippets.create!(
|
137
|
-
label:
|
138
|
-
identifier:
|
137
|
+
label: "test",
|
138
|
+
identifier: "test"
|
139
139
|
)
|
140
140
|
assert_equal 0, snippet_one.position
|
141
141
|
assert_equal 1, snippet_two.position
|
@@ -150,4 +150,5 @@ class Comfy::Admin::Cms::SnippetsControllerTest < ActionDispatch::IntegrationTes
|
|
150
150
|
assert_equal 1, snippet_one.position
|
151
151
|
assert_equal 0, snippet_two.position
|
152
152
|
end
|
153
|
+
|
153
154
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../../../../test_helper"
|
2
2
|
|
3
3
|
class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
@@ -44,10 +44,10 @@ class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::Integratio
|
|
44
44
|
def test_create
|
45
45
|
assert_count_difference [Comfy::Cms::Translation] do
|
46
46
|
path = comfy_admin_cms_site_page_translations_path(@site, @page)
|
47
|
-
r :post, path, params: {translation: {
|
47
|
+
r :post, path, params: { translation: {
|
48
48
|
locale: "es",
|
49
49
|
label: "Test Translation"
|
50
|
-
}}
|
50
|
+
} }
|
51
51
|
assert_response :redirect
|
52
52
|
translation = Comfy::Cms::Translation.last
|
53
53
|
assert_equal @page, translation.page
|
@@ -59,7 +59,7 @@ class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::Integratio
|
|
59
59
|
def test_creation_failure
|
60
60
|
assert_count_no_difference [Comfy::Cms::Translation] do
|
61
61
|
path = comfy_admin_cms_site_page_translations_path(@site, @page)
|
62
|
-
r :post, path, params: {translation: { }
|
62
|
+
r :post, path, params: { translation: {} }
|
63
63
|
assert_response :success
|
64
64
|
assert_template :new
|
65
65
|
assert_equal "Failed to create translation", flash[:danger]
|
@@ -68,9 +68,9 @@ class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::Integratio
|
|
68
68
|
|
69
69
|
def test_update
|
70
70
|
path = comfy_admin_cms_site_page_translation_path(@site, @page, @translation)
|
71
|
-
r :put, path, params: {translation: {
|
71
|
+
r :put, path, params: { translation: {
|
72
72
|
label: "Updated Translation"
|
73
|
-
}}
|
73
|
+
} }
|
74
74
|
assert_response :redirect
|
75
75
|
assert_redirected_to action: :edit, site_id: @site, page_id: @page, id: @translation
|
76
76
|
assert_equal "Translation updated", flash[:success]
|
@@ -80,9 +80,9 @@ class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::Integratio
|
|
80
80
|
|
81
81
|
def test_update_failure
|
82
82
|
path = comfy_admin_cms_site_page_translation_path(@site, @page, @translation)
|
83
|
-
r :put, path, params: {translation: {
|
83
|
+
r :put, path, params: { translation: {
|
84
84
|
locale: ""
|
85
|
-
}}
|
85
|
+
} }
|
86
86
|
assert_response :success
|
87
87
|
assert_template :edit
|
88
88
|
@translation.reload
|
@@ -132,20 +132,20 @@ class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::Integratio
|
|
132
132
|
def test_creation_preview
|
133
133
|
assert_count_no_difference [Comfy::Cms::Translation] do
|
134
134
|
r :post, comfy_admin_cms_site_page_translations_path(@site, @page), params: {
|
135
|
-
preview:
|
135
|
+
preview: "Preview",
|
136
136
|
translation: {
|
137
137
|
label: "Test Page",
|
138
138
|
layout_id: @layout.id,
|
139
139
|
locale: "fr",
|
140
140
|
fragments_attributes: [
|
141
|
-
{ identifier:
|
142
|
-
content:
|
141
|
+
{ identifier: "content",
|
142
|
+
content: "preview content" }
|
143
143
|
]
|
144
144
|
}
|
145
145
|
}
|
146
146
|
assert_response :success
|
147
|
-
assert_match
|
148
|
-
assert_equal
|
147
|
+
assert_match %r{preview content}, response.body
|
148
|
+
assert_equal "text/html", response.content_type
|
149
149
|
|
150
150
|
assert_equal @site, assigns(:cms_site)
|
151
151
|
assert_equal @layout, assigns(:cms_layout)
|
@@ -159,23 +159,24 @@ class Comfy::Admin::Cms::TranslationsControllerTest < ActionDispatch::Integratio
|
|
159
159
|
def test_update_preview
|
160
160
|
assert_count_no_difference [Comfy::Cms::Page] do
|
161
161
|
r :put, comfy_admin_cms_site_page_translation_path(@site, @page, @translation), params: {
|
162
|
-
preview:
|
162
|
+
preview: "Preview",
|
163
163
|
translation: {
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
164
|
+
label: "Updated Label",
|
165
|
+
fragments_attributes: [
|
166
|
+
{ identifier: "content",
|
167
|
+
content: "preview content" }
|
168
168
|
]
|
169
169
|
}
|
170
170
|
}
|
171
171
|
assert_response :success
|
172
|
-
assert_match
|
172
|
+
assert_match %r{preview content}, response.body
|
173
173
|
@translation.reload
|
174
|
-
assert_not_equal
|
174
|
+
assert_not_equal "Updated Label", @page.label
|
175
175
|
|
176
176
|
assert_equal @page.site, assigns(:cms_site)
|
177
177
|
assert_equal @page.layout, assigns(:cms_layout)
|
178
178
|
assert_equal @page, assigns(:cms_page)
|
179
179
|
end
|
180
180
|
end
|
181
|
+
|
181
182
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
require_relative
|
1
|
+
require_relative "../../../test_helper"
|
2
2
|
|
3
3
|
class Comfy::Cms::AssetsControllerTest < ActionDispatch::IntegrationTest
|
4
4
|
|
@@ -8,53 +8,54 @@ class Comfy::Cms::AssetsControllerTest < ActionDispatch::IntegrationTest
|
|
8
8
|
end
|
9
9
|
|
10
10
|
def test_render_css_with_site_with_path
|
11
|
-
@site.update_column(:path,
|
11
|
+
@site.update_column(:path, "some/path")
|
12
12
|
|
13
13
|
get comfy_cms_render_css_path(site_id: @site, identifier: @layout.identifier)
|
14
14
|
assert_response :success
|
15
|
-
assert_match
|
15
|
+
assert_match "text/css", response.content_type
|
16
16
|
assert_equal @layout.css, response.body
|
17
17
|
end
|
18
18
|
|
19
19
|
def test_render_css_without_cache_buster
|
20
20
|
get comfy_cms_render_css_path(site_id: @site, identifier: @layout.identifier)
|
21
21
|
assert_response :success
|
22
|
-
assert_match
|
23
|
-
assert_equal
|
22
|
+
assert_match "text/css", response.content_type
|
23
|
+
assert_equal "max-age=0, private, must-revalidate", response.headers["Cache-Control"]
|
24
24
|
assert_equal @layout.css, response.body
|
25
25
|
end
|
26
26
|
|
27
27
|
def test_render_css_with_cache_buster
|
28
28
|
get comfy_cms_render_css_path(site_id: @site, identifier: @layout.identifier, cache_buster: @layout.cache_buster)
|
29
29
|
assert_response :success
|
30
|
-
assert_match
|
31
|
-
assert_equal
|
30
|
+
assert_match "text/css", response.content_type
|
31
|
+
assert_equal "max-age=31556952, public", response.headers["Cache-Control"]
|
32
32
|
assert_equal @layout.css, response.body
|
33
33
|
end
|
34
34
|
|
35
35
|
def test_render_css_not_found
|
36
|
-
get comfy_cms_render_css_path(site_id: @site, identifier:
|
36
|
+
get comfy_cms_render_css_path(site_id: @site, identifier: "invalid")
|
37
37
|
assert_response 404
|
38
38
|
end
|
39
39
|
|
40
40
|
def test_render_js_without_cache_buster
|
41
41
|
get comfy_cms_render_js_path(site_id: @site, identifier: @layout.identifier)
|
42
42
|
assert_response :success
|
43
|
-
assert_equal
|
44
|
-
assert_equal
|
43
|
+
assert_equal "application/javascript", response.content_type
|
44
|
+
assert_equal "max-age=0, private, must-revalidate", response.headers["Cache-Control"]
|
45
45
|
assert_equal @layout.js, response.body
|
46
46
|
end
|
47
47
|
|
48
48
|
def test_render_js_with_cache_buster
|
49
49
|
get comfy_cms_render_js_path(site_id: @site, identifier: @layout.identifier, cache_buster: @layout.cache_buster)
|
50
50
|
assert_response :success
|
51
|
-
assert_equal
|
52
|
-
assert_equal
|
51
|
+
assert_equal "application/javascript", response.content_type
|
52
|
+
assert_equal "max-age=31556952, public", response.headers["Cache-Control"]
|
53
53
|
assert_equal @layout.js, response.body
|
54
54
|
end
|
55
55
|
|
56
56
|
def test_render_js_not_found
|
57
|
-
get comfy_cms_render_js_path(site_id: @site, identifier:
|
57
|
+
get comfy_cms_render_js_path(site_id: @site, identifier: "bogus")
|
58
58
|
assert_response 404
|
59
59
|
end
|
60
|
+
|
60
61
|
end
|