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.
- checksums.yaml +4 -4
- data/app/assets/images/decidim/dummy.svg +1 -4
- data/app/assets/images/decidim/gamification/badges/test.svg +1 -145
- data/app/commands/decidim/dummy_resources/create_dummy_resource.rb +48 -0
- data/app/controllers/decidim/dummy_resources/dummy_resources_controller.rb +1 -0
- data/app/forms/decidim/dummy_resources/dummy_resource_form.rb +3 -0
- data/app/views/decidim/dummy_resources/dummy_resources/show.html.erb +4 -0
- data/config/locales/am-ET.yml +1 -0
- data/config/locales/bg-BG.yml +56 -0
- data/config/locales/bg.yml +56 -0
- data/config/locales/ca.yml +15 -0
- data/config/locales/cs.yml +16 -1
- data/config/locales/da-DK.yml +1 -0
- data/config/locales/da.yml +1 -0
- data/config/locales/de.yml +16 -0
- data/config/locales/el-GR.yml +1 -0
- data/config/locales/el.yml +56 -0
- data/config/locales/en.yml +15 -0
- data/config/locales/eo.yml +1 -0
- data/config/locales/es-MX.yml +15 -0
- data/config/locales/es-PY.yml +15 -0
- data/config/locales/es.yml +15 -0
- data/config/locales/et-EE.yml +1 -0
- data/config/locales/et.yml +1 -0
- data/config/locales/fi-plain.yml +15 -0
- data/config/locales/fi.yml +15 -0
- data/config/locales/fr-CA.yml +56 -0
- data/config/locales/fr.yml +15 -0
- data/config/locales/ga-IE.yml +1 -0
- data/config/locales/hr-HR.yml +1 -0
- data/config/locales/hr.yml +1 -0
- data/config/locales/hu.yml +11 -2
- data/config/locales/is-IS.yml +21 -0
- data/config/locales/is.yml +21 -0
- data/config/locales/it.yml +17 -2
- data/config/locales/ja-JP.yml +56 -0
- data/config/locales/ja.yml +56 -0
- data/config/locales/ko-KR.yml +1 -0
- data/config/locales/ko.yml +1 -0
- data/config/locales/lt-LT.yml +1 -0
- data/config/locales/lt.yml +1 -0
- data/config/locales/lv.yml +54 -0
- data/config/locales/mt-MT.yml +1 -0
- data/config/locales/mt.yml +1 -0
- data/config/locales/nl.yml +15 -0
- data/config/locales/no.yml +31 -0
- data/config/locales/om-ET.yml +1 -0
- data/config/locales/pl.yml +26 -10
- data/config/locales/pt-BR.yml +1 -1
- data/config/locales/pt.yml +26 -10
- data/config/locales/ro-RO.yml +56 -0
- data/config/locales/sk-SK.yml +47 -0
- data/config/locales/sk.yml +47 -0
- data/config/locales/sl.yml +5 -0
- data/config/locales/so-SO.yml +1 -0
- data/config/locales/sr-CS.yml +8 -0
- data/config/locales/sv.yml +15 -0
- data/config/locales/ti-ER.yml +1 -0
- data/config/locales/vi-VN.yml +1 -0
- data/config/locales/vi.yml +1 -0
- data/config/locales/zh-CN.yml +56 -0
- data/config/locales/zh-TW.yml +1 -0
- data/lib/decidim/dev.rb +2 -0
- data/lib/decidim/dev/assets/assemblies.json +816 -0
- data/lib/decidim/dev/assets/assemblies_with_null.json +135 -0
- data/lib/decidim/dev/assets/city.jpeg +0 -0
- data/lib/decidim/dev/assets/city2.jpeg +0 -0
- data/lib/decidim/dev/assets/city3.jpeg +0 -0
- data/lib/decidim/dev/assets/geocoder_result_here.json +72 -0
- data/lib/decidim/dev/assets/geocoder_result_osm.json +150 -0
- data/lib/decidim/dev/assets/import_participatory_space_private_users_nok.csv +2 -0
- data/lib/decidim/dev/assets/participatory_processes.json +434 -0
- data/lib/decidim/dev/assets/participatory_processes_with_null.json +103 -0
- data/lib/decidim/dev/dummy_translator.rb +32 -0
- data/lib/decidim/dev/test/base_spec_helper.rb +14 -0
- data/lib/decidim/dev/test/rspec_support/authorization.rb +3 -0
- data/lib/decidim/dev/test/rspec_support/capybara.rb +6 -2
- data/lib/decidim/dev/test/rspec_support/capybara_data_picker.rb +15 -5
- data/lib/decidim/dev/test/rspec_support/capybara_scopes_picker.rb +5 -5
- data/lib/decidim/dev/test/rspec_support/comments.rb +2 -2
- data/lib/decidim/dev/test/rspec_support/component.rb +104 -5
- data/lib/decidim/dev/test/rspec_support/component_context.rb +1 -2
- data/lib/decidim/dev/test/rspec_support/confirmation_helpers.rb +60 -0
- data/lib/decidim/dev/test/rspec_support/content_processing.rb +4 -4
- data/lib/decidim/dev/test/rspec_support/frontend.rb +20 -0
- data/lib/decidim/dev/test/rspec_support/geocoder.rb +150 -7
- data/lib/decidim/dev/test/rspec_support/helpers.rb +2 -2
- data/lib/decidim/dev/test/rspec_support/organization.rb +7 -0
- data/lib/decidim/dev/test/rspec_support/rake_tasks.rb +75 -0
- data/lib/decidim/dev/test/rspec_support/timezone.rb +7 -0
- data/lib/decidim/dev/test/rspec_support/translation_helpers.rb +2 -0
- data/lib/decidim/dev/version.rb +1 -1
- data/lib/tasks/generators.rake +2 -1
- data/lib/tasks/locale_checker.rake +1 -1
- metadata +94 -16
- 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:
|
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", "
|
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("
|
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
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
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).
|
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").
|
20
|
+
find("ul.dropdown.menu").click
|
21
21
|
yield
|
22
22
|
end
|
23
23
|
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
|
@@ -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
|
|
data/lib/decidim/dev/version.rb
CHANGED
data/lib/tasks/generators.rake
CHANGED
@@ -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"] || "
|
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
|
|