-
Notifications
You must be signed in to change notification settings - Fork 97
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Test that all previews render correctly, e.g. in CI #376
Comments
Is it specific to Lookbook, or is it just the "regular" component previews that are breaking? Maybe you can use Previews as test cases in this case, so you'll be able to detect when the previews break? |
Looks like that would work if an equivalent task were to be made in If Lookbook's compatible with that idea of previews as test cases, then maybe it would benefit from this being built into |
Hey guys, sorry for the slow reply, just catching up with myself! @boardfish Lookbook previews are just ViewComponent previews (optionally unobtrusively annotated with some YARD-style comments that don't affect ViewComponent compatibility). So I think it would make sense to do any preview testing without any involvement of Lookbook itself - as @Spone mentions I think previews as test cases is the way to go here (as an aside... I love that feature!). Putting Lookbook into the mix here would just add overhead and if the previews render without Lookbook then they should work just fine when rendered within the Lookbook UI. Does that make sense? I will close this issue now as I don't think this is a Lookbook-specific issue but if I've misunderstood what you are looking for feel free to reopen :-) |
Here is how we proceed to test the previews with ViewComponent: Aside to each
If the Preview look like that: class Button::ComponentPreview < ViewComponent::Preview
def default; end
def primary; end
end the spec file will look like that: RSpec.describe Button::ComponentPreview, type: :component_preview do
it { is_expected.to render_preview_without_exception(:default) }
it { is_expected.to render_preview_without_exception(:primary) }
end
module RenderPreviewWithoutException
extend RSpec::Matchers::DSL
matcher :render_preview_without_exception do |expected_method|
match do |actual|
render_preview(expected_method, from: actual.class)
true
end
end
end
RSpec.configure do
config.include RenderPreviewWithoutException, type: :component_preview
end Test other previewsIt works nice with VIewComponent, but now I try to find another agnostic way to test other previews such as class Badge::ComponentPreview < Lookbook::Preview
def default; end
end matcher :render_preview_without_exception do |expected_method|
match do |actual|
if actual.class <= ViewComponent::Preview
render_preview(expected_method, from: actual.class)
true
else
pending "TODO: handle Lookbook::Preview subclasses"
false
end
end
end |
Is your feature request related to a problem? Please describe
I'm currently looking into a ViewComponent V3 upgrade. We've got the tests passing after upgrading to the new slot syntax, but another engineer identified that if we were to upgrade now, all our Lookbook previews would break because the slot syntax had not been updated in those.
Lookbook isn't covered by our CI. To have that coverage would help us to identify breaking changes going forward – not just those caused by version upgrades, but those caused by, for example, syntax errors or changes to a component's API for which the relevant preview wasn't changed.
Describe the solution you'd like
It would be nice to have, for example, a Rake task that runs a suite that renders every preview under its default conditions and checks that an error is not raised.
Describe alternatives you've considered
It's probably possible to load Lookbook within RSpec in some way, similarly to how we eager load all components in the Rails runtime. Using that, I suppose it might be possible to iterate through all preview routes and check that they return as we'd expect in a request spec.
This issue's mostly speculative – I haven't worked directly with Lookbook much just yet.
The text was updated successfully, but these errors were encountered: