mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-24 02:16:12 +08:00
CellSwipe: improve test coverage
This commit is contained in:
parent
c5474b2106
commit
c6b8de3541
@ -1,5 +1,13 @@
|
|||||||
import CellSwipe from 'packages/cell-swipe';
|
import CellSwipe from 'packages/cell-swipe';
|
||||||
import { mount } from 'avoriaz';
|
import { mount } from 'avoriaz';
|
||||||
|
import { triggerTouch } from '../utils';
|
||||||
|
|
||||||
|
const defaultProps = {
|
||||||
|
propsData: {
|
||||||
|
leftWidth: 100,
|
||||||
|
rightWidth: 100
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
describe('CellSwipe', () => {
|
describe('CellSwipe', () => {
|
||||||
let wrapper;
|
let wrapper;
|
||||||
@ -7,135 +15,103 @@ describe('CellSwipe', () => {
|
|||||||
wrapper && wrapper.destroy();
|
wrapper && wrapper.destroy();
|
||||||
});
|
});
|
||||||
|
|
||||||
it('create a CellSwipe', () => {
|
it('render left or right part when has width', () => {
|
||||||
wrapper = mount(CellSwipe, {
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
propsData: {
|
expect(wrapper.find('.van-cell-swipe__left').length).to.equal(1);
|
||||||
leftWidth: 2,
|
expect(wrapper.find('.van-cell-swipe__right').length).to.equal(1);
|
||||||
rightWidth: 2
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
wrapper.vm.startDrag({
|
|
||||||
pageX: 0,
|
it('not render left or right part when width is 0', () => {
|
||||||
pageY: 0
|
wrapper = mount(CellSwipe);
|
||||||
|
expect(wrapper.find('.van-cell-swipe__left').length).to.equal(0);
|
||||||
|
expect(wrapper.find('.van-cell-swipe__right').length).to.equal(0);
|
||||||
});
|
});
|
||||||
wrapper.vm.onDrag({
|
|
||||||
preventDefault() {},
|
it('drag and show left part', () => {
|
||||||
pageY: 0,
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
pageX: 50
|
|
||||||
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
|
expect(wrapper.vm.startX).to.equal(0);
|
||||||
|
expect(wrapper.vm.startY).to.equal(0);
|
||||||
|
|
||||||
|
triggerTouch(wrapper, 'touchmove', 50, 0);
|
||||||
|
expect(wrapper.vm.offset).to.equal(50);
|
||||||
|
|
||||||
|
triggerTouch(wrapper, 'touchend', 50, 0);
|
||||||
|
expect(wrapper.vm.offset).to.equal(100);
|
||||||
|
wrapper.vm.$nextTick(() => {
|
||||||
|
expect(wrapper.vm.opened).to.be.true;
|
||||||
});
|
});
|
||||||
wrapper.vm.offsetLeft = -20;
|
});
|
||||||
wrapper.vm.rightWidth = 10;
|
|
||||||
wrapper.vm.swipeLeaveTransition(1);
|
it('drag and show right part', () => {
|
||||||
wrapper.vm.endDrag();
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
expect(wrapper.hasClass('van-cell-swipe')).to.be.true;
|
|
||||||
});
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
});
|
triggerTouch(wrapper, 'touchmove', -50, 0);
|
||||||
|
triggerTouch(wrapper, 'touchend', -50, 0);
|
||||||
|
expect(wrapper.vm.offset).to.equal(-100);
|
||||||
describe('CellSwipe-left', () => {
|
wrapper.vm.$nextTick(() => {
|
||||||
let wrapper;
|
expect(wrapper.vm.opened).to.be.true;
|
||||||
afterEach(() => {
|
});
|
||||||
wrapper && wrapper.destroy();
|
});
|
||||||
});
|
|
||||||
|
it('drag and reset left part', () => {
|
||||||
it('create a CellSwipe left', () => {
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
wrapper = mount(CellSwipe, {
|
|
||||||
propsData: {
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
leftWidth: 2,
|
triggerTouch(wrapper, 'touchmove', 10, 0);
|
||||||
rightWidth: 2
|
triggerTouch(wrapper, 'touchmove', 30, 0);
|
||||||
}
|
triggerTouch(wrapper, 'touchend', 30, 0);
|
||||||
});
|
expect(wrapper.vm.offset).to.equal(0);
|
||||||
wrapper.vm.startDrag({
|
});
|
||||||
changedTouches: [{
|
|
||||||
pageX: 0,
|
it('drag and reset right part', () => {
|
||||||
pageY: 0
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
}
|
|
||||||
]
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
});
|
triggerTouch(wrapper, 'touchmove', -10, 0);
|
||||||
wrapper.vm.onDrag({
|
triggerTouch(wrapper, 'touchmove', -30, 0);
|
||||||
preventDefault() {},
|
triggerTouch(wrapper, 'touchend', -30, 0);
|
||||||
changedTouches: [{
|
expect(wrapper.vm.offset).to.equal(0);
|
||||||
pageX: 0,
|
});
|
||||||
pageY: -50
|
|
||||||
}
|
it('drag distance out of ranges', () => {
|
||||||
]
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
});
|
|
||||||
wrapper.vm.offsetLeft = 20;
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
wrapper.vm.rightWidth = 10;
|
triggerTouch(wrapper, 'touchmove', 1000, 0);
|
||||||
wrapper.vm.swipeLeaveTransition(-1);
|
expect(wrapper.vm.offset).to.equal(0);
|
||||||
wrapper.vm.endDrag();
|
});
|
||||||
expect(wrapper.hasClass('van-cell-swipe')).to.be.true;
|
|
||||||
});
|
it('drag and hide left part', (done) => {
|
||||||
});
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
|
|
||||||
describe('CellSwipe-0', () => {
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
let wrapper;
|
triggerTouch(wrapper, 'touchmove', 20, 0);
|
||||||
afterEach(() => {
|
triggerTouch(wrapper, 'touchmove', 50, 0);
|
||||||
wrapper && wrapper.destroy();
|
triggerTouch(wrapper, 'touchend', 50, 0);
|
||||||
});
|
expect(wrapper.vm.offset).to.equal(100);
|
||||||
|
wrapper.vm.$nextTick(() => {
|
||||||
it('create a CellSwipe 0', () => {
|
expect(wrapper.vm.opened).to.be.true;
|
||||||
wrapper = mount(CellSwipe, {
|
|
||||||
propsData: {
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
leftWidth: 0,
|
triggerTouch(wrapper, 'touchmove', 1, 0);
|
||||||
rightWidth: 2
|
|
||||||
}
|
wrapper.vm.$nextTick(() => {
|
||||||
});
|
expect(wrapper.vm.offset).to.equal(0);
|
||||||
wrapper.vm.startDrag({
|
expect(wrapper.vm.opened).to.be.false;
|
||||||
pageX: 0,
|
done();
|
||||||
pageY: 0
|
});
|
||||||
});
|
});
|
||||||
wrapper.vm.onDrag({
|
});
|
||||||
preventDefault() {},
|
|
||||||
pageY: 0,
|
it('drag vertical', () => {
|
||||||
pageX: -2
|
wrapper = mount(CellSwipe, defaultProps);
|
||||||
});
|
|
||||||
wrapper.vm.opened = true;
|
triggerTouch(wrapper, 'touchstart', 0, 0);
|
||||||
wrapper.vm.onDrag({
|
triggerTouch(wrapper, 'touchmove', 0, 100);
|
||||||
preventDefault() {},
|
triggerTouch(wrapper, 'touchend', 0, 100);
|
||||||
pageY: 0,
|
expect(wrapper.vm.offset).to.equal(0);
|
||||||
pageX: -2
|
|
||||||
});
|
|
||||||
wrapper.vm.opened = false;
|
|
||||||
wrapper.vm.onDrag({
|
|
||||||
preventDefault() {},
|
|
||||||
pageY: 0,
|
|
||||||
pageX: 40
|
|
||||||
});
|
|
||||||
wrapper.vm.swipeLeaveTransition(0);
|
|
||||||
wrapper.vm.endDrag();
|
|
||||||
expect(wrapper.hasClass('van-cell-swipe')).to.be.true;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
describe('CellSwipe-0', () => {
|
|
||||||
let wrapper;
|
|
||||||
afterEach(() => {
|
|
||||||
wrapper && wrapper.destroy();
|
|
||||||
});
|
|
||||||
|
|
||||||
it('create a CellSwipe 0', () => {
|
|
||||||
wrapper = mount(CellSwipe, {
|
|
||||||
propsData: {
|
|
||||||
leftWidth: 0,
|
|
||||||
rightWidth: 2
|
|
||||||
}
|
|
||||||
});
|
|
||||||
wrapper.vm.startDrag({
|
|
||||||
pageX: 0,
|
|
||||||
pageY: 0
|
|
||||||
});
|
|
||||||
wrapper.vm.onDrag({
|
|
||||||
preventDefault() {},
|
|
||||||
pageY: 1000,
|
|
||||||
pageX: 40
|
|
||||||
});
|
|
||||||
wrapper.vm.swipeMove();
|
|
||||||
wrapper.vm.swiping = false;
|
|
||||||
wrapper.vm.endDrag();
|
|
||||||
wrapper.vm.swiping = true;
|
|
||||||
wrapper.vm.endDrag();
|
|
||||||
expect(wrapper.hasClass('van-cell-swipe')).to.be.true;
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -31,7 +31,9 @@ export function DOMChecker(wrapper, rules) {
|
|||||||
if (style) {
|
if (style) {
|
||||||
Object.keys(style).forEach(key => {
|
Object.keys(style).forEach(key => {
|
||||||
Object.keys(style[key]).forEach(prop => {
|
Object.keys(style[key]).forEach(prop => {
|
||||||
expect(wrapper.find(key)[0].hasStyle(prop, style[key][prop])).to.equal(true);
|
expect(wrapper.find(key)[0].hasStyle(prop, style[key][prop])).to.equal(
|
||||||
|
true
|
||||||
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -39,8 +41,35 @@ export function DOMChecker(wrapper, rules) {
|
|||||||
if (noStyle) {
|
if (noStyle) {
|
||||||
Object.keys(noStyle).forEach(key => {
|
Object.keys(noStyle).forEach(key => {
|
||||||
Object.keys(noStyle[key]).forEach(prop => {
|
Object.keys(noStyle[key]).forEach(prop => {
|
||||||
expect(wrapper.find(key)[0].hasStyle(prop, noStyle[key][prop])).to.equal(false);
|
expect(
|
||||||
|
wrapper.find(key)[0].hasStyle(prop, noStyle[key][prop])
|
||||||
|
).to.equal(false);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 触发一个 touch 事件
|
||||||
|
export function triggerTouch(wrapper, eventName, x, y) {
|
||||||
|
const el = wrapper.element ? wrapper.element : wrapper;
|
||||||
|
const touch = {
|
||||||
|
identifier: Date.now(),
|
||||||
|
target: el,
|
||||||
|
pageX: x,
|
||||||
|
pageY: y,
|
||||||
|
clientX: x,
|
||||||
|
clientY: y,
|
||||||
|
radiusX: 2.5,
|
||||||
|
radiusY: 2.5,
|
||||||
|
rotationAngle: 10,
|
||||||
|
force: 0.5,
|
||||||
|
};
|
||||||
|
|
||||||
|
const event = document.createEvent('CustomEvent');
|
||||||
|
event.initCustomEvent(eventName, true, true, {});
|
||||||
|
event.touches = [touch];
|
||||||
|
event.targetTouches = [touch];
|
||||||
|
event.changedTouches = [touch];
|
||||||
|
|
||||||
|
el.dispatchEvent(event);
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user