Module: ViewComponent::TestHelpers
- Included in:
- SystemTestHelpers, TestCase
- Defined in:
- lib/view_component/test_helpers.rb
Instance Attribute Summary collapse
-
#rendered_content ⇒ ActionView::OutputBuffer
readonly
Returns the result of a render_inline call.
Instance Method Summary collapse
-
#render_in_view_context ⇒ Object
Execute the given block in the view context (using ‘instance_exec`).
-
#render_inline(component, **args, &block) ⇒ Nokogiri::HTML5
Render a component inline.
-
#render_preview(name, from: __vc_test_helpers_preview_class, params: {}) ⇒ Nokogiri::HTML5
Render a preview inline.
-
#rendered_json ⇒ Object
‘JSON.parse`-d component output.
-
#vc_test_controller ⇒ ActionController::Base
Access the controller used by ‘render_inline`:.
-
#vc_test_controller_class ⇒ Object
Set the controller used by ‘render_inline`:.
-
#vc_test_request ⇒ ActionDispatch::TestRequest
Access the request used by ‘render_inline`:.
-
#with_controller_class(klass) ⇒ Object
Set the controller to be used while executing the given block, allowing access to controller-specific methods:.
-
#with_format(*formats) ⇒ Object
Set format of the current request.
-
#with_request_url(full_path, host: nil, method: nil) ⇒ Object
Set the URL of the current request (such as when using request-dependent path helpers):.
-
#with_variant(*variants) ⇒ Object
Set the Action Pack request variant for the given block:.
Instance Attribute Details
#rendered_content ⇒ ActionView::OutputBuffer (readonly)
Returns the result of a render_inline call.
27 28 29 |
# File 'lib/view_component/test_helpers.rb', line 27 def rendered_content @rendered_content end |
Instance Method Details
#render_in_view_context ⇒ Object
Execute the given block in the view context (using ‘instance_exec`). Internally sets `page` to be a `Capybara::Node::Simple`, allowing for Capybara assertions to be used. All arguments are forwarded to the block.
“‘ruby render_in_view_context(arg1, arg2: nil) do |arg1, arg2:|
render(MyComponent.new(arg1, arg2))
end
assert_text(“Hello, World!”) “‘
104 105 106 107 108 |
# File 'lib/view_component/test_helpers.rb', line 104 def render_in_view_context(...) @page = nil @rendered_content = vc_test_controller.view_context.instance_exec(...) Nokogiri::HTML5.fragment(@rendered_content) end |
#render_inline(component, **args, &block) ⇒ Nokogiri::HTML5
Render a component inline. Internally sets ‘page` to be a `Capybara::Node::Simple`, allowing for Capybara assertions to be used:
“‘ruby render_inline(MyComponent.new) assert_text(“Hello, World!”) “`
39 40 41 42 43 44 |
# File 'lib/view_component/test_helpers.rb', line 39 def render_inline(component, **args, &block) @page = nil @rendered_content = vc_test_controller.view_context.render(component, args, &block) Nokogiri::HTML5.fragment(@rendered_content) end |
#render_preview(name, from: __vc_test_helpers_preview_class, params: {}) ⇒ Nokogiri::HTML5
Render a preview inline. Internally sets ‘page` to be a `Capybara::Node::Simple`, allowing for Capybara assertions to be used:
“‘ruby render_preview(:default) assert_text(“Hello, World!”) “`
Note: ‘#rendered_preview` expects a preview to be defined with the same class name as the calling test, but with `Test` replaced with `Preview`:
MyComponentTest -> MyComponentPreview etc.
In RSpec, ‘Preview` is appended to `described_class`.
75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 |
# File 'lib/view_component/test_helpers.rb', line 75 def render_preview(name, from: __vc_test_helpers_preview_class, params: {}) previews_controller = __vc_test_helpers_build_controller(Rails.application.config.view_component.previews.controller.constantize) # From what I can tell, it's not possible to overwrite all request parameters # at once, so we set them individually here. params.each do |k, v| previews_controller.request.params[k] = v end previews_controller.request.params[:path] = "#{from.preview_name}/#{name}" previews_controller.set_response!(ActionDispatch::Response.new) result = previews_controller.previews @rendered_content = result Nokogiri::HTML5.fragment(@rendered_content) end |
#rendered_json ⇒ Object
‘JSON.parse`-d component output.
“‘ruby render_inline(MyJsonComponent.new) assert_equal(rendered_json, “world”) “`
52 53 54 |
# File 'lib/view_component/test_helpers.rb', line 52 def rendered_json JSON.parse(rendered_content) end |
#vc_test_controller ⇒ ActionController::Base
Access the controller used by ‘render_inline`:
“‘ruby test “logged out user sees login link” do
vc_test_controller.expects(:logged_in?).at_least_once.returns(false)
render_inline(LoginComponent.new)
assert_selector("[aria-label='You must be signed in']")
end “‘
235 236 237 |
# File 'lib/view_component/test_helpers.rb', line 235 def vc_test_controller @vc_test_controller ||= __vc_test_helpers_build_controller(vc_test_controller_class) end |
#vc_test_controller_class ⇒ Object
Set the controller used by ‘render_inline`:
“‘ruby def vc_test_controller_class
MyTestController
end “‘
246 247 248 249 250 |
# File 'lib/view_component/test_helpers.rb', line 246 def vc_test_controller_class return @__vc_test_controller_class if defined?(@__vc_test_controller_class) defined?(ApplicationController) ? ApplicationController : ActionController::Base end |
#vc_test_request ⇒ ActionDispatch::TestRequest
Access the request used by ‘render_inline`:
“‘ruby test “component does not render in Firefox” do
request.env["HTTP_USER_AGENT"] = "Mozilla/5.0"
render_inline(NoFirefoxComponent.new)
refute_component_rendered
end “‘
263 264 265 266 267 268 269 270 271 272 |
# File 'lib/view_component/test_helpers.rb', line 263 def vc_test_request require "action_controller/test_case" @vc_test_request ||= begin out = ActionDispatch::TestRequest.create out.session = ActionController::TestSession.new out end end |
#with_controller_class(klass) ⇒ Object
Set the controller to be used while executing the given block, allowing access to controller-specific methods:
“‘ruby with_controller_class(UsersController) do
render_inline(MyComponent.new)
end “‘
138 139 140 141 142 143 144 145 |
# File 'lib/view_component/test_helpers.rb', line 138 def with_controller_class(klass) old_controller = defined?(@vc_test_controller) && @vc_test_controller @vc_test_controller = __vc_test_helpers_build_controller(klass) yield ensure @vc_test_controller = old_controller end |
#with_format(*formats) ⇒ Object
Set format of the current request
“‘ruby with_format(:json) do
render_inline(MyComponent.new)
end “‘
156 157 158 159 160 161 162 163 |
# File 'lib/view_component/test_helpers.rb', line 156 def with_format(*formats) old_formats = vc_test_controller.view_context.lookup_context.formats vc_test_controller.view_context.lookup_context.formats = formats yield ensure vc_test_controller.view_context.lookup_context.formats = old_formats end |
#with_request_url(full_path, host: nil, method: nil) ⇒ Object
Set the URL of the current request (such as when using request-dependent path helpers):
“‘ruby with_request_url(“/users/42”) do
render_inline(MyComponent.new)
end “‘
To use a specific host, pass the host param:
“‘ruby with_request_url(“/users/42”, host: “app.example.com”) do
render_inline(MyComponent.new)
end “‘
To specify a request method, pass the method param:
“‘ruby with_request_url(“/users/42”, method: “POST”) do
render_inline(MyComponent.new)
end “‘
192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 |
# File 'lib/view_component/test_helpers.rb', line 192 def with_request_url(full_path, host: nil, method: nil) old_request_host = vc_test_request.host old_request_method = vc_test_request.request_method old_request_path_info = vc_test_request.path_info old_request_path_parameters = vc_test_request.path_parameters old_request_query_parameters = vc_test_request.query_parameters old_request_query_string = vc_test_request.query_string old_request_format = vc_test_request.format.symbol old_controller = defined?(@vc_test_controller) && @vc_test_controller path, query = full_path.split("?", 2) vc_test_request.instance_variable_set(:@fullpath, full_path) vc_test_request.instance_variable_set(:@original_fullpath, full_path) vc_test_request.host = host if host vc_test_request.request_method = method if method vc_test_request.path_info = path vc_test_request.path_parameters = Rails.application.routes.recognize_path_with_request(vc_test_request, path, {}) vc_test_request.set_header("action_dispatch.request.query_parameters", Rack::Utils.parse_nested_query(query).with_indifferent_access) vc_test_request.set_header(Rack::QUERY_STRING, query) yield ensure vc_test_request.host = old_request_host vc_test_request.request_method = old_request_method vc_test_request.path_info = old_request_path_info vc_test_request.path_parameters = old_request_path_parameters vc_test_request.set_header("action_dispatch.request.query_parameters", old_request_query_parameters) vc_test_request.set_header(Rack::QUERY_STRING, old_request_query_string) vc_test_request.format = old_request_format @vc_test_controller = old_controller end |
#with_variant(*variants) ⇒ Object
Set the Action Pack request variant for the given block:
“‘ruby with_variant(:phone) do
render_inline(MyComponent.new)
end “‘
119 120 121 122 123 124 125 126 |
# File 'lib/view_component/test_helpers.rb', line 119 def with_variant(*variants) old_variants = vc_test_controller.view_context.lookup_context.variants vc_test_controller.view_context.lookup_context.variants += variants yield ensure vc_test_controller.view_context.lookup_context.variants = old_variants end |