require 'spec_helper' RSpec.describe ReactiveRuby::Rails::ComponentMount do let(:helper) { described_class.new } before do helper.setup(ActionView::TestCase::TestController.new) end describe '#react_component' do it 'renders a div' do html = helper.react_component('Components::HelloWorld') expect(html).to match(/<\/div>/) end it 'accepts a pre-render option' do html = helper.react_component('Components::HelloWorld', {}, prerender: true) expect(html).to match(/Hello, World!<\/span><\/div>/) end it 'sets data-react-class to React.TopLevelRailsComponent' do html = helper.react_component('Components::HelloWorld') top_level_class = 'React.TopLevelRailsComponent' expect(attr_value(html, 'data-react-class')).to eq(top_level_class) end it 'sets component_name in data-react-props hash' do html = helper.react_component('Components::HelloWorld') props = react_props_for(html) expect(props['component_name']).to eq('Components::HelloWorld') end it 'sets render_params in data-react-props hash' do html = helper.react_component('Components::HelloWorld', {'foo' => 'bar'}) props = react_props_for(html) expect(props['render_params']).to include({ 'foo' => 'bar' }) end it 'sets controller in data-react-props hash' do html = helper.react_component('Components::HelloWorld') props = react_props_for(html) expect(props['controller']).to eq('ActionView::TestCase::Test') end it 'passes additional options through as html attributes' do html = helper.react_component('Components::HelloWorld', {}, { 'foo-bar' => 'biz-baz' }) expect(attr_value(html, 'foo-bar')).to eq('biz-baz') end end def attr_value(html, attr) matches = html.match(/#{attr}=["']((?:.(?!["']\s+(?:\S+)=|[>"']))+.)["']?/) matches.captures.first end def react_props_for(html) JSON.parse(CGI.unescapeHTML("#{attr_value(html, 'data-react-props')}")) end end