add scroll tests
This commit is contained in:
parent
b694afb7ce
commit
d4e4b75414
4 changed files with 112 additions and 59 deletions
|
@ -1,29 +1,31 @@
|
|||
import { EVENT_KEYPRESS, EVENT_KEYDOWN, EVENT_KEYUP } from '../shared/messages';
|
||||
import * as ipc from './ipc';
|
||||
|
||||
const press = (tabId, key) => {
|
||||
return ipc.send({
|
||||
const NEUTRAL_MODIFIERS = { shiftKey: false, altKey: false, ctrlKey: false };
|
||||
|
||||
const press = (tabId, key, modifiers = NEUTRAL_MODIFIERS) => {
|
||||
return ipc.send(Object.assign({}, modifiers, {
|
||||
type: EVENT_KEYPRESS,
|
||||
tabId,
|
||||
key,
|
||||
});
|
||||
}));
|
||||
};
|
||||
|
||||
const down = (tabId, key) => {
|
||||
return ipc.send({
|
||||
const down = (tabId, key, modifiers = NEUTRAL_MODIFIERS) => {
|
||||
return ipc.send(Object.assign({}, modifiers, {
|
||||
type: EVENT_KEYDOWN,
|
||||
tabId,
|
||||
key,
|
||||
});
|
||||
}));
|
||||
};
|
||||
|
||||
|
||||
const up = (tabId, key) => {
|
||||
return ipc.send({
|
||||
const up = (tabId, key, modifiers = NEUTRAL_MODIFIERS) => {
|
||||
return ipc.send(Object.assign({}, modifiers, {
|
||||
type: EVENT_KEYUP,
|
||||
tabId,
|
||||
key,
|
||||
});
|
||||
}));
|
||||
};
|
||||
|
||||
export { press, down, up };
|
||||
|
|
31
e2e/ambassador/src/content/events.js
Normal file
31
e2e/ambassador/src/content/events.js
Normal file
|
@ -0,0 +1,31 @@
|
|||
const keypress = (opts) => {
|
||||
let event = new KeyboardEvent('keypress', {
|
||||
key: opts.key,
|
||||
altKey: opts.altKey,
|
||||
shiftKey: opts.shiftKey,
|
||||
ctrlKey: opts.ctrlKey
|
||||
});
|
||||
document.body.dispatchEvent(event);
|
||||
};
|
||||
|
||||
const keydown = (opts) => {
|
||||
let event = new KeyboardEvent('keydown', {
|
||||
key: opts.key,
|
||||
altKey: opts.altKey,
|
||||
shiftKey: opts.shiftKey,
|
||||
ctrlKey: opts.ctrlKey
|
||||
});
|
||||
document.body.dispatchEvent(event);
|
||||
};
|
||||
|
||||
const keyup = (opts) => {
|
||||
let event = new KeyboardEvent('keyup', {
|
||||
key: opts.key,
|
||||
altKey: opts.altKey,
|
||||
shiftKey: opts.shiftKey,
|
||||
ctrlKey: opts.ctrlKey
|
||||
});
|
||||
document.body.dispatchEvent(event);
|
||||
};
|
||||
|
||||
export { keypress, keydown, keyup };
|
|
@ -3,6 +3,7 @@ import {
|
|||
SCROLL_GET, SCROLL_SET,
|
||||
} from '../shared/messages';
|
||||
import * as ipc from './ipc';
|
||||
import * as events from './events';
|
||||
import * as scrolls from './scrolls';
|
||||
|
||||
ipc.receivePageMessage((message) => {
|
||||
|
@ -12,16 +13,13 @@ ipc.receivePageMessage((message) => {
|
|||
ipc.receiveBackgroundMesssage((message) => {
|
||||
switch (message.type) {
|
||||
case EVENT_KEYPRESS:
|
||||
document.body.dispatchEvent(
|
||||
new KeyboardEvent('keypress', { 'key': message.key }));
|
||||
events.keypress(message);
|
||||
break;
|
||||
case EVENT_KEYDOWN:
|
||||
document.body.dispatchEvent(
|
||||
new KeyboardEvent('keydown', { 'key': message.key }));
|
||||
events.keydown(message);
|
||||
break;
|
||||
case EVENT_KEYUP:
|
||||
document.body.dispatchEvent(
|
||||
new KeyboardEvent('keyup', { 'key': message.key }));
|
||||
events.keyup(message);
|
||||
break;
|
||||
case SCROLL_GET:
|
||||
return Promise.resolve(scrolls.get());
|
||||
|
|
|
@ -23,59 +23,81 @@ describe("scroll test", () => {
|
|||
return windows.remove(targetWindow.id);
|
||||
});
|
||||
|
||||
describe('press k', () => {
|
||||
it('scrolls up', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'k');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.y).to.be.lessThan(before.y);
|
||||
});
|
||||
it('scrolls up by k', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'k');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.y).to.be.lessThan(before.y);
|
||||
});
|
||||
});
|
||||
|
||||
describe('press j', () => {
|
||||
it('scrolls down', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'j');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.y).to.be.greaterThan(before.y);
|
||||
});
|
||||
it('scrolls down by j', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'j');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.y).to.be.greaterThan(before.y);
|
||||
});
|
||||
});
|
||||
|
||||
describe('press h', () => {
|
||||
it('scrolls left', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'h');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.x).to.be.lessThan(before.x);
|
||||
});
|
||||
it('scrolls left by h', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'h');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.x).to.be.lessThan(before.x);
|
||||
});
|
||||
});
|
||||
|
||||
describe('press l', () => {
|
||||
it('scrolls right', () => {
|
||||
let before
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
before = scroll;
|
||||
return keys.press(targetTab.id, 'l');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.x).to.be.greaterThan(before.x);
|
||||
});
|
||||
it('scrolls top by gg', () => {
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
return keys.press(targetTab.id, 'g');
|
||||
}).then(() => {
|
||||
return keys.press(targetTab.id, 'g');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.y).to.be.equals(0);
|
||||
});
|
||||
});
|
||||
|
||||
it('scrolls bottom by G', () => {
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
return keys.press(targetTab.id, 'G', { shiftKey: true });
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.y).to.be.equals(actual.yMax);
|
||||
});
|
||||
});
|
||||
|
||||
it('scrolls bottom by 0', () => {
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
return keys.press(targetTab.id, '0');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.x).to.be.equals(0);
|
||||
});
|
||||
});
|
||||
|
||||
it('scrolls bottom by $', () => {
|
||||
return scrolls.set(targetTab.id, 100, 100).then((scroll) => {
|
||||
return keys.press(targetTab.id, '$');
|
||||
}).then(() => {
|
||||
return scrolls.get(targetTab.id);
|
||||
}).then((actual) => {
|
||||
expect(actual.x).to.be.equals(actual.xMax);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Reference in a new issue