mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 06:03:38 +08:00
use ava and enzyme, replace jest (#2135)
This commit is contained in:
parent
b5b9175e1e
commit
8f60a3c483
42
package.json
42
package.json
@ -74,8 +74,8 @@
|
||||
},
|
||||
"devDependencies": {
|
||||
"antd-tools": "^0.8.0",
|
||||
"ava": "^0.15.2",
|
||||
"babel-eslint": "^6.0.2",
|
||||
"babel-jest": "^12.0.2",
|
||||
"babel-plugin-antd": "^0.4.0",
|
||||
"bisheng": "^0.7.1",
|
||||
"bisheng-plugin-antd": "0.1.0",
|
||||
@ -84,7 +84,7 @@
|
||||
"bisheng-plugin-toc": "0.2.0",
|
||||
"dora-plugin-upload": "^0.3.1",
|
||||
"enquire.js": "^2.1.1",
|
||||
"es6-shim": "^0.35.0",
|
||||
"enzyme": "^2.3.0",
|
||||
"eslint": "^2.2.0",
|
||||
"eslint-config-airbnb": "^9.0.1",
|
||||
"eslint-plugin-babel": "^3.0.0",
|
||||
@ -96,7 +96,6 @@
|
||||
"history": "^2.0.1",
|
||||
"intl": "^1.2.2",
|
||||
"intl-locales-supported": "^1.0.0",
|
||||
"jest-cli": "^12.0.2",
|
||||
"jsonml-to-react-component": "~0.2.0",
|
||||
"jsonml.js": "^0.1.0",
|
||||
"jsonp": "^0.2.0",
|
||||
@ -116,11 +115,9 @@
|
||||
"react-github-button": "^0.1.1",
|
||||
"react-intl": "^2.0.1",
|
||||
"react-router": "^2.0.0",
|
||||
"react-stateless-wrapper": "^1.0.2",
|
||||
"react-sublime-video": "^0.2.0",
|
||||
"reqwest": "^2.0.5",
|
||||
"values.js": "^1.0.3",
|
||||
"webpack-babel-jest": "^1.0.4"
|
||||
"values.js": "^1.0.3"
|
||||
},
|
||||
"scripts": {
|
||||
"dist": "antd-tools run dist",
|
||||
@ -136,30 +133,25 @@
|
||||
"demolint": "RUN_ENV=DEMO eslint components/*/demo/*.md --ext '.md'",
|
||||
"lesshint": "lesshint components -r scripts/lesshint-report.js",
|
||||
"eslint-fix": "eslint --fix components test site scripts ./*.js --ext '.js,.jsx' && eslint-tinker ./components/*/demo/*.md",
|
||||
"test": "npm run lint && npm run dist && npm run jest",
|
||||
"jest": "jest",
|
||||
"test": "npm run lint && npm run dist && npm run ava",
|
||||
"ava": "ava tests/*.test.js",
|
||||
"pre-publish": "node ./scripts/prepub",
|
||||
"prepublish": "antd-tools run guard",
|
||||
"pub": "antd-tools run update-self && antd-tools run pub",
|
||||
"authors": "git log --format='%aN <%aE>' | sort -u | grep -v 'users.noreply.github.com' | grep -v 'gitter.im' | grep -v '.local>' | grep -v 'alibaba-inc.com' | grep -v 'alipay.com' | grep -v 'taobao.com' > AUTHORS.txt"
|
||||
},
|
||||
"jest": {
|
||||
"moduleFileExtensions": [
|
||||
"js",
|
||||
"jsx",
|
||||
"json"
|
||||
],
|
||||
"unmockedModulePathPatterns": [
|
||||
"<rootDir>/node_modules/*"
|
||||
],
|
||||
"modulePathIgnorePatterns": [
|
||||
"/_site/"
|
||||
],
|
||||
"testPathIgnorePatterns": [
|
||||
"/node_modules/"
|
||||
],
|
||||
"scriptPreprocessor": "<rootDir>/node_modules/webpack-babel-jest",
|
||||
"testDirectoryName": "tests"
|
||||
"ava": {
|
||||
"babel": {
|
||||
"presets": [
|
||||
"es2015",
|
||||
"stage-0",
|
||||
"react"
|
||||
]
|
||||
},
|
||||
"require": [
|
||||
"./tests/helpers/setup-browser-env.js",
|
||||
"babel-register"
|
||||
]
|
||||
},
|
||||
"pre-commit": [
|
||||
"lint"
|
||||
|
@ -1,34 +1,23 @@
|
||||
jest.unmock('../components/button/button');
|
||||
jest.unmock('../components/icon/index');
|
||||
|
||||
import test from 'ava';
|
||||
import React from 'react';
|
||||
import TestUtils from 'react-addons-test-utils';
|
||||
import { shallow } from 'enzyme';
|
||||
import Button from '../components/button/button';
|
||||
|
||||
describe('Button', function() {
|
||||
let button;
|
||||
let buttonNode;
|
||||
let buttonNode;
|
||||
|
||||
beforeEach(() => {
|
||||
button = TestUtils.renderIntoDocument(
|
||||
<Button>Follow</Button>
|
||||
);
|
||||
buttonNode = TestUtils.findRenderedDOMComponentWithTag(button, 'button');
|
||||
});
|
||||
|
||||
it('should set the type to button by default', () => {
|
||||
expect(buttonNode.type).toBe('button');
|
||||
});
|
||||
|
||||
it('should set the default className to button', () => {
|
||||
expect(buttonNode.className).toBe('ant-btn');
|
||||
});
|
||||
|
||||
it('should has a whitespace in two Chinese charactor', () => {
|
||||
button = TestUtils.renderIntoDocument(
|
||||
<Button>按钮</Button>
|
||||
);
|
||||
buttonNode = TestUtils.findRenderedDOMComponentWithTag(button, 'button');
|
||||
expect(buttonNode.textContent).toBe('按 钮');
|
||||
});
|
||||
test.beforeEach(() => {
|
||||
buttonNode = shallow(<Button>Follow</Button>);
|
||||
});
|
||||
|
||||
test('should set the type to button by default', (t) => {
|
||||
t.is(buttonNode.type(), 'button');
|
||||
});
|
||||
|
||||
test('should set the default className to button', (t) => {
|
||||
t.true(buttonNode.hasClass('ant-btn'));
|
||||
});
|
||||
|
||||
test('should has a whitespace in two Chinese charactor', (t) => {
|
||||
buttonNode = shallow(<Button>按钮</Button>);
|
||||
t.is(buttonNode.text(), '按 钮');
|
||||
});
|
||||
|
3
tests/helpers/setup-browser-env.js
Normal file
3
tests/helpers/setup-browser-env.js
Normal file
@ -0,0 +1,3 @@
|
||||
global.document = require('jsdom').jsdom('<body></body>');
|
||||
global.window = document.defaultView;
|
||||
global.navigator = window.navigator;
|
@ -1,27 +1,19 @@
|
||||
jest.unmock('../components/icon/index');
|
||||
|
||||
import test from 'ava';
|
||||
import React from 'react';
|
||||
import TestUtils from 'react-addons-test-utils';
|
||||
import { wrap } from 'react-stateless-wrapper';
|
||||
import { shallow } from 'enzyme';
|
||||
import Icon from '../components/icon/index';
|
||||
|
||||
import AntIcon from '../components/icon/index';
|
||||
const Icon = wrap(AntIcon);
|
||||
let iconNode;
|
||||
|
||||
describe('Icon', function() {
|
||||
let icon;
|
||||
let iconNode;
|
||||
|
||||
beforeEach(() => {
|
||||
icon = TestUtils.renderIntoDocument(
|
||||
<Icon type="appstore" className="my-icon-classname" />
|
||||
);
|
||||
iconNode = TestUtils.findRenderedDOMComponentWithTag(icon, 'I');
|
||||
});
|
||||
|
||||
it('should render to a <i class="xxx"></i>', () => {
|
||||
expect(iconNode.tagName).toBe('I');
|
||||
expect(iconNode.className).toContain('my-icon-classname');
|
||||
expect(iconNode.className).toContain('anticon');
|
||||
expect(iconNode.className).toContain('anticon-appstore');
|
||||
});
|
||||
test.beforeEach(() => {
|
||||
iconNode = shallow(
|
||||
<Icon type="appstore" className="my-icon-classname" />
|
||||
);
|
||||
});
|
||||
|
||||
test('should render to a <i class="xxx"></i>', (t) => {
|
||||
t.is(iconNode.type(), 'i');
|
||||
t.true(iconNode.hasClass('my-icon-classname'));
|
||||
t.true(iconNode.hasClass('anticon'));
|
||||
t.true(iconNode.hasClass('anticon-appstore'));
|
||||
});
|
||||
|
@ -2,13 +2,13 @@
|
||||
import React from 'react';
|
||||
import fs from 'fs';
|
||||
import path from 'path';
|
||||
import test from 'ava';
|
||||
|
||||
describe('antd dist files', function() {
|
||||
const distFilesExisted = fs.existsSync(path.join(process.cwd(), 'dist', 'antd.js'));
|
||||
(function() {
|
||||
const distFilesExisted = fs.existsSync(path.join(process.cwd(), '..', 'dist', 'antd.js'));
|
||||
if (!distFilesExisted) {
|
||||
test(t => t.pass());
|
||||
return;
|
||||
} else {
|
||||
jest.unmock('../dist/antd');
|
||||
}
|
||||
|
||||
// fixed jsdom miss
|
||||
@ -29,63 +29,64 @@ describe('antd dist files', function() {
|
||||
|
||||
// https://github.com/ant-design/ant-design/issues/1638
|
||||
// https://github.com/ant-design/ant-design/issues/1968
|
||||
it('should has modules in antd', () => {
|
||||
expect('Affix' in antd).toBeTruthy();
|
||||
expect('Alert' in antd).toBeTruthy();
|
||||
expect('Badge' in antd).toBeTruthy();
|
||||
expect('Breadcrumb' in antd).toBeTruthy();
|
||||
expect('Button' in antd).toBeTruthy();
|
||||
expect('Calendar' in antd).toBeTruthy();
|
||||
expect('Card' in antd).toBeTruthy();
|
||||
expect('Carousel' in antd).toBeTruthy();
|
||||
expect('Cascader' in antd).toBeTruthy();
|
||||
expect('Checkbox' in antd).toBeTruthy();
|
||||
expect('Col' in antd).toBeTruthy();
|
||||
expect('Collapse' in antd).toBeTruthy();
|
||||
expect('DatePicker' in antd).toBeTruthy();
|
||||
expect('Dropdown' in antd).toBeTruthy();
|
||||
expect('Form' in antd).toBeTruthy();
|
||||
expect('Icon' in antd).toBeTruthy();
|
||||
expect('Input' in antd).toBeTruthy();
|
||||
expect('InputNumber' in antd).toBeTruthy();
|
||||
expect('LocaleProvider' in antd).toBeTruthy();
|
||||
expect('Menu' in antd).toBeTruthy();
|
||||
expect('message' in antd).toBeTruthy();
|
||||
expect('Modal' in antd).toBeTruthy();
|
||||
expect('notification' in antd).toBeTruthy();
|
||||
expect('Pagination' in antd).toBeTruthy();
|
||||
expect('Popconfirm' in antd).toBeTruthy();
|
||||
expect('Popover' in antd).toBeTruthy();
|
||||
expect('Progress' in antd).toBeTruthy();
|
||||
expect('QueueAnim' in antd).toBeTruthy();
|
||||
expect('Radio' in antd).toBeTruthy();
|
||||
expect('Rate' in antd).toBeTruthy();
|
||||
expect('Row' in antd).toBeTruthy();
|
||||
expect('Select' in antd).toBeTruthy();
|
||||
expect('Slider' in antd).toBeTruthy();
|
||||
expect('Spin' in antd).toBeTruthy();
|
||||
expect('Steps' in antd).toBeTruthy();
|
||||
expect('Switch' in antd).toBeTruthy();
|
||||
expect('Table' in antd).toBeTruthy();
|
||||
expect('Tabs' in antd).toBeTruthy();
|
||||
expect('Tag' in antd).toBeTruthy();
|
||||
expect('TimePicker' in antd).toBeTruthy();
|
||||
expect('Timeline' in antd).toBeTruthy();
|
||||
expect('Tooltip' in antd).toBeTruthy();
|
||||
expect('Transfer' in antd).toBeTruthy();
|
||||
expect('Tree' in antd).toBeTruthy();
|
||||
expect('TreeSelect' in antd).toBeTruthy();
|
||||
expect('Upload' in antd).toBeTruthy();
|
||||
expect('Validation' in antd).toBeTruthy();
|
||||
test('should has modules in antd', (t) => {
|
||||
t.true('Affix' in antd);
|
||||
t.true('Alert' in antd);
|
||||
t.true('Badge' in antd);
|
||||
t.true('Breadcrumb' in antd);
|
||||
t.true('Button' in antd);
|
||||
t.true('Calendar' in antd);
|
||||
t.true('Card' in antd);
|
||||
t.true('Carousel' in antd);
|
||||
t.true('Cascader' in antd);
|
||||
t.true('Checkbox' in antd);
|
||||
t.true('Col' in antd);
|
||||
t.true('Collapse' in antd);
|
||||
t.true('DatePicker' in antd);
|
||||
t.true('Dropdown' in antd);
|
||||
t.true('Form' in antd);
|
||||
t.true('Icon' in antd);
|
||||
t.true('Input' in antd);
|
||||
t.true('InputNumber' in antd);
|
||||
t.true('LocaleProvider' in antd);
|
||||
t.true('Menu' in antd);
|
||||
t.true('message' in antd);
|
||||
t.true('Modal' in antd);
|
||||
t.true('notification' in antd);
|
||||
t.true('Pagination' in antd);
|
||||
t.true('Popconfirm' in antd);
|
||||
t.true('Popover' in antd);
|
||||
t.true('Progress' in antd);
|
||||
t.true('QueueAnim' in antd);
|
||||
t.true('Radio' in antd);
|
||||
t.true('Rate' in antd);
|
||||
t.true('Row' in antd);
|
||||
t.true('Select' in antd);
|
||||
t.true('Slider' in antd);
|
||||
t.true('Spin' in antd);
|
||||
t.true('Steps' in antd);
|
||||
t.true('Switch' in antd);
|
||||
t.true('Table' in antd);
|
||||
t.true('Tabs' in antd);
|
||||
t.true('Tag' in antd);
|
||||
t.true('TimePicker' in antd);
|
||||
t.true('Timeline' in antd);
|
||||
t.true('Tooltip' in antd);
|
||||
t.true('Transfer' in antd);
|
||||
t.true('Tree' in antd);
|
||||
t.true('TreeSelect' in antd);
|
||||
t.true('Upload' in antd);
|
||||
t.true('Validation' in antd);
|
||||
});
|
||||
|
||||
// https://github.com/ant-design/ant-design/issues/1970
|
||||
// https://github.com/ant-design/ant-design/issues/1804
|
||||
it('should be compatible in IE8', () => {
|
||||
const antdJsContent = fs.readFileSync(path.join(process.cwd(), 'dist', 'antd.js'));
|
||||
expect(
|
||||
test('should be compatible in IE8', (t) => {
|
||||
const antdJsContent = fs.readFileSync(path.join(process.cwd(), '..', 'dist', 'antd.js'));
|
||||
t.is(
|
||||
antdJsContent.toString()
|
||||
.indexOf('function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }')
|
||||
).toBe(-1);
|
||||
.indexOf('function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }'),
|
||||
-1
|
||||
);
|
||||
})
|
||||
});
|
||||
})();
|
||||
|
@ -1,27 +1,14 @@
|
||||
jest.unmock('../components/layout/index');
|
||||
jest.unmock('../components/layout/col');
|
||||
jest.unmock('../components/layout/row');
|
||||
|
||||
import test from 'ava';
|
||||
import React from 'react';
|
||||
import TestUtils from 'react-addons-test-utils';
|
||||
import { wrap } from 'react-stateless-wrapper';
|
||||
import { shallow } from 'enzyme';
|
||||
import { Col, Row } from '../components/layout/index';
|
||||
|
||||
let { Col, Row } = require('../components/layout/index');
|
||||
Col = wrap(Col);
|
||||
|
||||
describe('Layout', function() {
|
||||
it('should render Col', () => {
|
||||
const col = TestUtils.renderIntoDocument(
|
||||
<Col span="2"></Col>
|
||||
);
|
||||
const colNode = TestUtils.findRenderedDOMComponentWithTag(col, 'DIV');
|
||||
expect(colNode.className).toBe('ant-col-2');
|
||||
});
|
||||
it('should render Row', () => {
|
||||
const row = TestUtils.renderIntoDocument(
|
||||
<Row></Row>
|
||||
);
|
||||
const rowNode = TestUtils.findRenderedDOMComponentWithTag(row, 'DIV');
|
||||
expect(rowNode.className).toBe('ant-row');
|
||||
});
|
||||
test('should render Col', (t) => {
|
||||
const col = shallow(<Col span={2} />);
|
||||
t.true(col.hasClass('ant-col-2'));
|
||||
});
|
||||
|
||||
test('should render Row', (t) => {
|
||||
const row = shallow(<Row />);
|
||||
t.true(row.hasClass('ant-row'));
|
||||
});
|
||||
|
@ -1,29 +1,21 @@
|
||||
jest.unmock('../components/popover/placements');
|
||||
jest.unmock('../components/popover/index');
|
||||
jest.unmock('../components/tooltip/index');
|
||||
|
||||
import test from 'ava';
|
||||
import React from 'react';
|
||||
import TestUtils from 'react-addons-test-utils';
|
||||
import Popover from '../components/popover/index';
|
||||
import Popover from '../components/popover'
|
||||
import { mount } from 'enzyme';
|
||||
|
||||
describe('Popover', function() {
|
||||
it('should show overlay when trigger is clicked', () => {
|
||||
const popover = TestUtils.renderIntoDocument(
|
||||
<Popover content="console.log('hello world')" title="code" trigger="click">
|
||||
<a href="#">show me your code</a>
|
||||
</Popover>
|
||||
);
|
||||
test('should show overlay when trigger is clicked', (t) => {
|
||||
const popover = mount(
|
||||
<Popover content="console.log('hello world')" title="code" trigger="click">
|
||||
<a href="#">show me your code</a>
|
||||
</Popover>
|
||||
);
|
||||
|
||||
expect(popover.getPopupDomNode()).toBe(undefined);
|
||||
t.is(popover.instance().getPopupDomNode(), undefined);
|
||||
|
||||
TestUtils.Simulate.click(
|
||||
TestUtils.findRenderedDOMComponentWithTag(popover, 'a')
|
||||
);
|
||||
popover.find('a').simulate('click');
|
||||
|
||||
const popup = popover.getPopupDomNode();
|
||||
expect(popup).not.toBe(undefined);
|
||||
expect(popup.className).toContain('ant-popover-placement-top');
|
||||
expect(popup.innerHTML).toMatch(/<div class="ant-popover-title".*?>code<\/div>/);
|
||||
expect(popup.innerHTML).toMatch(/<div class="ant-popover-inner-content".*?>console\.log\('hello world'\)<\/div>/);
|
||||
});
|
||||
const popup = popover.instance().getPopupDomNode();
|
||||
t.truthy(popup);
|
||||
t.true(popup.className.indexOf('ant-popover-placement-top') > 0);
|
||||
t.is(popup.innerHTML, '<div class="ant-popover-content"><div class="ant-popover-arrow"></div><div class="ant-popover-inner">code</div></div>');
|
||||
});
|
||||
|
Loading…
Reference in New Issue
Block a user