2
0
mirror of https://github.com/tenrok/BBob.git synced 2026-06-23 20:40:34 +03:00

feat(react): update to react 18 and testing-library (#138)

This commit is contained in:
Nikolay Kost
2022-05-24 01:50:45 +02:00
committed by GitHub
parent d3c9cba8d3
commit 502362cc8c
3 changed files with 1293 additions and 994 deletions
+1274 -977
View File
File diff suppressed because it is too large Load Diff
+5 -6
View File
@@ -15,15 +15,14 @@
}, },
"peerDependencies": { "peerDependencies": {
"prop-types": "15.x", "prop-types": "15.x",
"react": "15.x" "react": "18.x"
}, },
"devDependencies": { "devDependencies": {
"@bbob/preset-react": "^2.8.0", "@bbob/preset-react": "^2.8.0",
"enzyme": "^3.9.0", "@testing-library/jest-dom": "^5.16.4",
"enzyme-adapter-react-15": "^1.0.6", "@testing-library/react": "13.x",
"react": "15.x", "react": "18.x",
"react-dom": "^15.6.2", "react-dom": "18.x"
"react-test-renderer": "^15.6.2"
}, },
"main": "lib/index.js", "main": "lib/index.js",
"module": "es/index.js", "module": "es/index.js",
+14 -11
View File
@@ -1,39 +1,42 @@
/**
* @jest-environment jsdom
*/
import React from 'react'; import React from 'react';
import preset from '@bbob/preset-react'; import preset from '@bbob/preset-react';
import '@testing-library/jest-dom'
import Enzyme, { shallow } from 'enzyme'; import { render } from '@testing-library/react'
import Adapter from 'enzyme-adapter-react-15';
import BBCode from '../src'; import BBCode from '../src';
Enzyme.configure({ adapter: new Adapter() });
const renderBBCode = (input, options) => shallow( const renderBBCode = (input, options) => render(
<BBCode plugins={[preset()]} options={options}>{input}</BBCode> <BBCode plugins={[preset()]} options={options}>{input}</BBCode>
).html(); ).container.innerHTML;
describe('@bbob/react', () => { describe('@bbob/react', () => {
test('[b]bolded text[/b]', () => { test('[b]bolded text[/b]', () => {
const html = renderBBCode('[b]bolded text[/b]'); const html = renderBBCode('[b]bolded text[/b]');
expect(html).toBe('<span><span style="font-weight:bold;">bolded text</span></span>') expect(html).toBe('<span><span style="font-weight: bold;">bolded text</span></span>')
}); });
test('[i]italicized text[/i]', () => { test('[i]italicized text[/i]', () => {
const html = renderBBCode('[i]italicized text[/i]'); const html = renderBBCode('[i]italicized text[/i]');
expect(html).toBe('<span><span style="font-style:italic;">italicized text</span></span>') expect(html).toBe('<span><span style="font-style: italic;">italicized text</span></span>')
}); });
test('[u]underlined text[/u]', () => { test('[u]underlined text[/u]', () => {
const html = renderBBCode('[u]underlined text[/u]'); const html = renderBBCode('[u]underlined text[/u]');
expect(html).toBe('<span><span style="text-decoration:underline;">underlined text</span></span>') expect(html).toBe('<span><span style="text-decoration: underline;">underlined text</span></span>')
}); });
test('[s]strikethrough text[/s]', () => { test('[s]strikethrough text[/s]', () => {
const html = renderBBCode('[s]strikethrough text[/s]'); const html = renderBBCode('[s]strikethrough text[/s]');
expect(html).toBe('<span><span style="text-decoration:line-through;">strikethrough text</span></span>') expect(html).toBe('<span><span style="text-decoration: line-through;">strikethrough text</span></span>')
}); });
test('[url]https://en.wikipedia.org[/url]', () => { test('[url]https://en.wikipedia.org[/url]', () => {
@@ -45,14 +48,14 @@ describe('@bbob/react', () => {
test('[b]Testing[/b][hr]', () => { test('[b]Testing[/b][hr]', () => {
const html = renderBBCode('[b]Testing[/b][hr]'); const html = renderBBCode('[b]Testing[/b][hr]');
expect(html).toBe('<span><span style="font-weight:bold;">Testing</span><hr/></span>') expect(html).toBe('<span><span style="font-weight: bold;">Testing</span><hr></span>')
}); });
describe('options.onlyAllowTags', () => { describe('options.onlyAllowTags', () => {
test('render "[Super Feature] and [i]super[/i]" when only [i] allowed', () => { test('render "[Super Feature] and [i]super[/i]" when only [i] allowed', () => {
const html = renderBBCode('[Super Feature] and [i]super[/i]', { onlyAllowTags: ['i'] }); const html = renderBBCode('[Super Feature] and [i]super[/i]', { onlyAllowTags: ['i'] });
expect(html).toBe('<span>[Super Feature] and <span style="font-style:italic;">super</span></span>') expect(html).toBe('<span>[Super Feature] and <span style="font-style: italic;">super</span></span>')
}); });
}); });