decidim-dev 0.19.1 → 0.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. checksums.yaml +4 -4
  2. data/app/assets/images/decidim/dummy.svg +1 -4
  3. data/app/assets/images/decidim/gamification/badges/test.svg +1 -145
  4. data/app/commands/decidim/dummy_resources/create_dummy_resource.rb +48 -0
  5. data/app/controllers/decidim/dummy_resources/dummy_resources_controller.rb +1 -0
  6. data/app/forms/decidim/dummy_resources/dummy_resource_form.rb +3 -0
  7. data/app/views/decidim/dummy_resources/dummy_resources/show.html.erb +4 -0
  8. data/config/locales/am-ET.yml +1 -0
  9. data/config/locales/bg-BG.yml +56 -0
  10. data/config/locales/bg.yml +56 -0
  11. data/config/locales/ca.yml +15 -0
  12. data/config/locales/cs.yml +16 -1
  13. data/config/locales/da-DK.yml +1 -0
  14. data/config/locales/da.yml +1 -0
  15. data/config/locales/de.yml +16 -0
  16. data/config/locales/el-GR.yml +1 -0
  17. data/config/locales/el.yml +56 -0
  18. data/config/locales/en.yml +15 -0
  19. data/config/locales/eo.yml +1 -0
  20. data/config/locales/es-MX.yml +15 -0
  21. data/config/locales/es-PY.yml +15 -0
  22. data/config/locales/es.yml +15 -0
  23. data/config/locales/et-EE.yml +1 -0
  24. data/config/locales/et.yml +1 -0
  25. data/config/locales/fi-plain.yml +15 -0
  26. data/config/locales/fi.yml +15 -0
  27. data/config/locales/fr-CA.yml +56 -0
  28. data/config/locales/fr.yml +15 -0
  29. data/config/locales/ga-IE.yml +1 -0
  30. data/config/locales/hr-HR.yml +1 -0
  31. data/config/locales/hr.yml +1 -0
  32. data/config/locales/hu.yml +11 -2
  33. data/config/locales/is-IS.yml +21 -0
  34. data/config/locales/is.yml +21 -0
  35. data/config/locales/it.yml +17 -2
  36. data/config/locales/ja-JP.yml +56 -0
  37. data/config/locales/ja.yml +56 -0
  38. data/config/locales/ko-KR.yml +1 -0
  39. data/config/locales/ko.yml +1 -0
  40. data/config/locales/lt-LT.yml +1 -0
  41. data/config/locales/lt.yml +1 -0
  42. data/config/locales/lv.yml +54 -0
  43. data/config/locales/mt-MT.yml +1 -0
  44. data/config/locales/mt.yml +1 -0
  45. data/config/locales/nl.yml +15 -0
  46. data/config/locales/no.yml +31 -0
  47. data/config/locales/om-ET.yml +1 -0
  48. data/config/locales/pl.yml +26 -10
  49. data/config/locales/pt-BR.yml +1 -1
  50. data/config/locales/pt.yml +26 -10
  51. data/config/locales/ro-RO.yml +56 -0
  52. data/config/locales/sk-SK.yml +47 -0
  53. data/config/locales/sk.yml +47 -0
  54. data/config/locales/sl.yml +5 -0
  55. data/config/locales/so-SO.yml +1 -0
  56. data/config/locales/sr-CS.yml +8 -0
  57. data/config/locales/sv.yml +15 -0
  58. data/config/locales/ti-ER.yml +1 -0
  59. data/config/locales/vi-VN.yml +1 -0
  60. data/config/locales/vi.yml +1 -0
  61. data/config/locales/zh-CN.yml +56 -0
  62. data/config/locales/zh-TW.yml +1 -0
  63. data/lib/decidim/dev.rb +2 -0
  64. data/lib/decidim/dev/assets/assemblies.json +816 -0
  65. data/lib/decidim/dev/assets/assemblies_with_null.json +135 -0
  66. data/lib/decidim/dev/assets/city.jpeg +0 -0
  67. data/lib/decidim/dev/assets/city2.jpeg +0 -0
  68. data/lib/decidim/dev/assets/city3.jpeg +0 -0
  69. data/lib/decidim/dev/assets/geocoder_result_here.json +72 -0
  70. data/lib/decidim/dev/assets/geocoder_result_osm.json +150 -0
  71. data/lib/decidim/dev/assets/import_participatory_space_private_users_nok.csv +2 -0
  72. data/lib/decidim/dev/assets/participatory_processes.json +434 -0
  73. data/lib/decidim/dev/assets/participatory_processes_with_null.json +103 -0
  74. data/lib/decidim/dev/dummy_translator.rb +32 -0
  75. data/lib/decidim/dev/test/base_spec_helper.rb +14 -0
  76. data/lib/decidim/dev/test/rspec_support/authorization.rb +3 -0
  77. data/lib/decidim/dev/test/rspec_support/capybara.rb +6 -2
  78. data/lib/decidim/dev/test/rspec_support/capybara_data_picker.rb +15 -5
  79. data/lib/decidim/dev/test/rspec_support/capybara_scopes_picker.rb +5 -5
  80. data/lib/decidim/dev/test/rspec_support/comments.rb +2 -2
  81. data/lib/decidim/dev/test/rspec_support/component.rb +104 -5
  82. data/lib/decidim/dev/test/rspec_support/component_context.rb +1 -2
  83. data/lib/decidim/dev/test/rspec_support/confirmation_helpers.rb +60 -0
  84. data/lib/decidim/dev/test/rspec_support/content_processing.rb +4 -4
  85. data/lib/decidim/dev/test/rspec_support/frontend.rb +20 -0
  86. data/lib/decidim/dev/test/rspec_support/geocoder.rb +150 -7
  87. data/lib/decidim/dev/test/rspec_support/helpers.rb +2 -2
  88. data/lib/decidim/dev/test/rspec_support/organization.rb +7 -0
  89. data/lib/decidim/dev/test/rspec_support/rake_tasks.rb +75 -0
  90. data/lib/decidim/dev/test/rspec_support/timezone.rb +7 -0
  91. data/lib/decidim/dev/test/rspec_support/translation_helpers.rb +2 -0
  92. data/lib/decidim/dev/version.rb +1 -1
  93. data/lib/tasks/generators.rake +2 -1
  94. data/lib/tasks/locale_checker.rake +1 -1
  95. metadata +94 -16
  96. data/lib/decidim/dev/test/rspec_support/capybara_proposals_picker.rb +0 -51
@@ -19,8 +19,7 @@ shared_context "with a component" do
19
19
  participatory_space: participatory_space)
20
20
  end
21
21
 
22
- let!(:category) { create :category, participatory_space: participatory_process }
23
-
22
+ let!(:category) { create :category, participatory_space: participatory_space }
24
23
  let!(:scope) { create :scope, organization: organization }
25
24
 
26
25
  before do
@@ -0,0 +1,60 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Helpers that get automatically included in component specs.
4
+ module ConfirmationHelpers
5
+ # Overrides the Capybara default accept_confirm because we have replaced the
6
+ # system's own confirmation modal with foundation based modal.
7
+ #
8
+ # See:
9
+ # https://github.com/teamcapybara/capybara/blob/44621209496fe4dd352709799a0061a80d97d562/lib/capybara/session.rb#L647
10
+ def accept_confirm(_text = nil, **_options)
11
+ yield if block_given?
12
+
13
+ # The test can already be "within", so find the body using xpath
14
+ message = nil
15
+ body = find(:xpath, "/html/body")
16
+ within(body.find(".confirm-reveal")) do
17
+ message = find(".confirm-modal-content").text
18
+ find("a.button[data-confirm-ok]").click
19
+ end
20
+
21
+ message
22
+ end
23
+
24
+ # Overrides the Capybara default dismiss_confirm because we have replaced the
25
+ # system's own confirmation modal with foundation based modal.
26
+ #
27
+ # See:
28
+ # https://github.com/teamcapybara/capybara/blob/44621209496fe4dd352709799a0061a80d97d562/lib/capybara/session.rb#L657
29
+ def dismiss_confirm(_text = nil, **_options)
30
+ yield if block_given?
31
+
32
+ # The test can already be "within", so find the body using xpath
33
+ message = nil
34
+ body = find(:xpath, "/html/body")
35
+ within(body.find(".confirm-reveal")) do
36
+ message = find(".confirm-modal-content").text
37
+ find("a.button[data-confirm-cancel]").click
38
+ end
39
+
40
+ message
41
+ end
42
+
43
+ # Used to accept the "onbeforeunload" event's normal browser confirm modal
44
+ # as this cannot be overridden. Original confirm dismiss implementation in
45
+ # Capybara.
46
+ def accept_page_unload(text = nil, **options, &blk)
47
+ page.send(:accept_modal, :confirm, text, options, &blk)
48
+ end
49
+
50
+ # Used to dismiss the "onbeforeunload" event's normal browser confirm modal
51
+ # as this cannot be overridden. Original confirm dismiss implementation in
52
+ # Capybara.
53
+ def dismiss_page_unload(text = nil, **options, &blk)
54
+ page.send(:dismiss_modal, :confirm, text, options, &blk)
55
+ end
56
+ end
57
+
58
+ RSpec.configure do |config|
59
+ config.include ConfirmationHelpers, type: :system
60
+ end
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  class ContentParsers::DummyFooParser < ContentParsers::BaseParser
5
5
  def rewrite
6
- content.gsub("foo", "*lorem*")
6
+ content.gsub("foo", "%lorem%")
7
7
  end
8
8
 
9
9
  def metadata
@@ -12,8 +12,8 @@ module Decidim
12
12
  end
13
13
 
14
14
  class ContentRenderers::DummyFooRenderer < ContentRenderers::BaseRenderer
15
- def render
16
- content.gsub("*lorem*", "<em>neque dicta enim quasi</em>")
15
+ def render(_options = nil)
16
+ content.gsub("%lorem%", "<em>neque dicta enim quasi</em>")
17
17
  end
18
18
  end
19
19
 
@@ -28,7 +28,7 @@ module Decidim
28
28
  end
29
29
 
30
30
  class ContentRenderers::DummyBarRenderer < ContentRenderers::BaseRenderer
31
- def render
31
+ def render(_options = nil)
32
32
  content.gsub("*ipsum*", "<em>illo qui voluptas</em>")
33
33
  end
34
34
  end
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+
3
+ module FrontendHelpers
4
+ # Thanks to:
5
+ # https://medium.com/@coorasse/catch-javascript-errors-in-your-system-tests-89c2fe6773b1
6
+ def expect_no_js_errors
7
+ errors = page.driver.browser.manage.logs.get(:browser)
8
+ return if errors.blank?
9
+
10
+ aggregate_failures "javascript errors" do
11
+ errors.each do |error|
12
+ expect(error.level).not_to eq("SEVERE"), error.message
13
+ end
14
+ end
15
+ end
16
+ end
17
+
18
+ RSpec.configure do |config|
19
+ config.include FrontendHelpers, type: :system
20
+ end
@@ -8,6 +8,69 @@ module GeocoderHelpers
8
8
  address,
9
9
  result
10
10
  )
11
+ Decidim::Map::Provider::Autocomplete::Test.add_stub(
12
+ address,
13
+ coordinates
14
+ )
15
+ end
16
+
17
+ # Waits for the front-end geocoding request to finish in order to ensure there
18
+ # are no pending requests when proceeding.
19
+ def fill_in_geocoding(attribute, options = {})
20
+ fill_in attribute, options
21
+ expect(page).to have_selector(".tribute-container ul#results", count: 1)
22
+ end
23
+
24
+ module_function
25
+
26
+ public def configure_maps
27
+ # Set maps configuration in test mode
28
+ Decidim.maps = {
29
+ provider: :test,
30
+ api_key: "1234123412341234",
31
+ static: { url: "https://www.example.org/my_static_map" },
32
+ autocomplete: { url: "/photon_api" } # Locally drawn route for the tests
33
+ }
34
+ end
35
+ end
36
+
37
+ module Decidim::Map::Provider
38
+ module Geocoding
39
+ class Test < ::Decidim::Map::Geocoding; end
40
+ end
41
+ module Autocomplete
42
+ class Test < ::Decidim::Map::Autocomplete
43
+ def self.stubs
44
+ @stubs ||= []
45
+ end
46
+
47
+ def self.add_stub(address, coordinates)
48
+ stubs.push(
49
+ properties: address.is_a?(Hash) ? address : { street: address },
50
+ geometry: { coordinates: coordinates }
51
+ )
52
+ end
53
+
54
+ def self.clear_stubs
55
+ @stubs = []
56
+ end
57
+
58
+ def builder_options
59
+ { url: configuration.fetch(:url, nil) }.compact
60
+ end
61
+
62
+ class Builder < Decidim::Map::Autocomplete::Builder
63
+ def javascript_snippets
64
+ template.javascript_include_tag("decidim/geocoding/provider/photon")
65
+ end
66
+ end
67
+ end
68
+ end
69
+ module DynamicMap
70
+ class Test < ::Decidim::Map::DynamicMap; end
71
+ end
72
+ module StaticMap
73
+ class Test < ::Decidim::Map::StaticMap; end
11
74
  end
12
75
  end
13
76
 
@@ -15,17 +78,97 @@ RSpec.configure do |config|
15
78
  config.include GeocoderHelpers
16
79
 
17
80
  config.before(:suite) do
18
- # Set geocoder configuration in test mode
19
- Decidim.geocoder = {
20
- static_map_url: "https://www.example.org/my_static_map",
21
- here_app_id: "1234",
22
- here_app_code: "5678"
23
- }
24
- Geocoder.configure(lookup: :test)
81
+ GeocoderHelpers.configure_maps
82
+ end
83
+
84
+ config.after(:each, :configures_map) do
85
+ # Ensure the initializer is always re-run after the examples because
86
+ # otherwise the utilities could remain unregistered which causes issues with
87
+ # further tests.
88
+ Decidim::Core::Engine.initializers.each do |i|
89
+ next unless i.name == "decidim.maps"
90
+
91
+ i.run
92
+ break
93
+ end
94
+
95
+ # Ensure the utility configuration is reset after each example for it to be
96
+ # reloaded the next time.
97
+ Decidim::Map.reset_utility_configuration!
98
+ configure_maps
25
99
  end
26
100
 
27
101
  config.before(:each, :serves_map) do
28
102
  stub_request(:get, %r{https://www\.example\.org/my_static_map})
29
103
  .to_return(body: "map_data")
30
104
  end
105
+
106
+ config.before(:each, :serves_geocoding_autocomplete) do
107
+ # Clear the autocomplete stubs
108
+ Decidim::Map::Provider::Autocomplete::Test.clear_stubs
109
+
110
+ photon_response = lambda do
111
+ {
112
+ features: [
113
+ {
114
+ properties: {
115
+ name: "Park",
116
+ street: "Street1",
117
+ housenumber: "1",
118
+ postcode: "123456",
119
+ city: "City1",
120
+ state: "State1",
121
+ country: "Country1"
122
+ },
123
+ geometry: {
124
+ coordinates: [1.123, 2.234]
125
+ }
126
+ },
127
+ {
128
+ properties: {
129
+ street: "Street2",
130
+ postcode: "654321",
131
+ city: "City2",
132
+ country: "Country2"
133
+ },
134
+ geometry: {
135
+ coordinates: [3.345, 4.456]
136
+ }
137
+ },
138
+ {
139
+ properties: {
140
+ street: "Street3",
141
+ housenumber: "3",
142
+ postcode: "142536",
143
+ city: "City3",
144
+ country: "Country3"
145
+ },
146
+ geometry: {
147
+ coordinates: [5.567, 6.678]
148
+ }
149
+ }
150
+ ]
151
+ }.tap do |response|
152
+ Decidim::Map::Provider::Autocomplete::Test.stubs.length.positive? &&
153
+ response[:features] = Decidim::Map::Provider::Autocomplete::Test.stubs
154
+ end
155
+ end
156
+
157
+ # The Photon API path needs to be mounted in the application itself because
158
+ # otherwise we would have to run a separate server for the API itself.
159
+ # Mocking the request would not work here because the call to the Photon API
160
+ # is initialized by the front-end to the URL specified for the maps
161
+ # geocoding autocompletion configuration which is not proxied by the
162
+ # headless browser running the Capybara tests.
163
+ Rails.application.routes.disable_clear_and_finalize = true
164
+ Rails.application.routes.draw do
165
+ get "photon_api", to: ->(_) { [200, { "Content-Type" => "application/json" }, [photon_response.call.to_json.to_s]] }
166
+ end
167
+ Rails.application.routes.disable_clear_and_finalize = false
168
+ end
169
+
170
+ config.after(:each, :serves_geocoding_autocomplete) do
171
+ # Reset the routes back to original
172
+ Rails.application.reload_routes!
173
+ end
31
174
  end
@@ -10,14 +10,14 @@ module Decidim::ComponentTestHelpers
10
10
 
11
11
  def within_user_menu
12
12
  within ".topbar__user__logged" do
13
- find("a", text: user.name).hover
13
+ find("a", text: user.name).click
14
14
  yield
15
15
  end
16
16
  end
17
17
 
18
18
  def within_language_menu
19
19
  within ".topbar__dropmenu.language-choose" do
20
- find("ul.dropdown.menu").hover
20
+ find("ul.dropdown.menu").click
21
21
  yield
22
22
  end
23
23
  end
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ RSpec.configure do |config|
4
+ config.after do
5
+ Decidim::OrganizationSettings.reset!
6
+ end
7
+ end
@@ -0,0 +1,75 @@
1
+ # frozen_string_literal: true
2
+
3
+ # File: spec/support/tasks.rb
4
+ require "rake"
5
+
6
+ # Task names should be used in the top-level describe, with an optional
7
+ # "rake "-prefix for better documentation. Both of these will work:
8
+ #
9
+ # 1) describe "foo:bar" do ... end
10
+ #
11
+ # 2) describe "rake foo:bar" do ... end
12
+ #
13
+ # Favor including "rake "-prefix as in the 2nd example above as it produces
14
+ # doc output that makes it clear a rake task is under test and how it is
15
+ # invoked.
16
+ module TaskExampleGroup
17
+ extend ActiveSupport::Concern
18
+
19
+ included do
20
+ # Make the Rake task available as `task` in your examples:
21
+ subject(:task) { tasks[task_name] }
22
+
23
+ let(:task_name) { self.class.top_level_description.sub(/\Arake /, "") }
24
+ let(:tasks) { Rake::Task }
25
+ end
26
+ end
27
+
28
+ # A collection of methods to help dealing with rake tasks output.
29
+ module RakeTaskOutputHelpers
30
+ extend ActiveSupport::Concern
31
+
32
+ included do
33
+ let!(:original_stdout) { $stdout }
34
+
35
+ # rubocop:disable RSpec/ExpectOutput
36
+ before do
37
+ $stdout = StringIO.new
38
+ end
39
+
40
+ after do
41
+ $stdout = original_stdout
42
+ end
43
+ # rubocop:enable RSpec/ExpectOutput
44
+ end
45
+
46
+ def check_no_errors_have_been_printed
47
+ expect($stdout.string).not_to include("ERROR:")
48
+ end
49
+
50
+ def check_some_errors_have_been_printed
51
+ expect($stdout.string).to include("ERROR:")
52
+ end
53
+
54
+ def check_error_printed(type)
55
+ expect($stdout.string).to include("ERROR: [#{type}]")
56
+ end
57
+
58
+ def check_message_printed(message)
59
+ expect($stdout.string).to include(message)
60
+ end
61
+ end
62
+
63
+ RSpec.configure do |config|
64
+ # Tag Rake specs with `:task` metadata or put them in the spec/tasks dir
65
+ config.define_derived_metadata(file_path: %r{/spec/tasks/}) do |metadata|
66
+ metadata[:type] = :task
67
+ end
68
+
69
+ config.include TaskExampleGroup, type: :task
70
+ config.include RakeTaskOutputHelpers, type: :task
71
+
72
+ config.before(:suite) do
73
+ Rails.application.load_tasks
74
+ end
75
+ end
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ RSpec.configure do |config|
4
+ config.around :example, :tz do |example|
5
+ Time.use_zone(example.metadata[:tz]) { example.run }
6
+ end
7
+ end
@@ -13,6 +13,8 @@ module TranslationHelpers
13
13
  # It is intended to be used to avoid the implementation details, so that the
14
14
  # translated attributes implementation can change more easily.
15
15
  def translated(field, locale: I18n.locale)
16
+ return field if field.is_a?(String)
17
+
16
18
  field.try(:[], locale.to_s)
17
19
  end
18
20
 
@@ -4,7 +4,7 @@ module Decidim
4
4
  # This holds the decidim-dev version.
5
5
  module Dev
6
6
  def self.version
7
- "0.19.1"
7
+ "0.23.0"
8
8
  end
9
9
  end
10
10
  end
@@ -44,7 +44,8 @@ namespace :decidim do
44
44
  "..",
45
45
  "--recreate_db",
46
46
  "--seed_db",
47
- "--demo"
47
+ "--demo",
48
+ "--profiling"
48
49
  )
49
50
  end
50
51
  end
@@ -5,7 +5,7 @@ namespace :decidim do
5
5
  task check_locales: :environment do
6
6
  FileUtils.remove_dir("tmp/decidim_repo", true)
7
7
 
8
- branch = ENV["TARGET_BRANCH"] || "master"
8
+ branch = ENV["TARGET_BRANCH"] || "develop"
9
9
  status = system("git clone --depth=1 --single-branch --branch #{branch} https://github.com/decidim/decidim tmp/decidim_repo")
10
10
  return unless status
11
11