50 lines
		
	
	
	
		
			1.8 KiB
			
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
	
		
			1.8 KiB
			
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { BrowserWindow } from 'electron';
 | 
						|
 | 
						|
import { expect } from 'chai';
 | 
						|
 | 
						|
import * as path from 'node:path';
 | 
						|
import { setTimeout } from 'node:timers/promises';
 | 
						|
 | 
						|
import { closeAllWindows } from './lib/window-helpers';
 | 
						|
 | 
						|
const fixturesPath = path.resolve(__dirname, 'fixtures');
 | 
						|
 | 
						|
describe('autofill', () => {
 | 
						|
  afterEach(closeAllWindows);
 | 
						|
 | 
						|
  it('can be selected via keyboard for a <datalist> with text type', async () => {
 | 
						|
    const w = new BrowserWindow({ show: true });
 | 
						|
    await w.loadFile(path.join(fixturesPath, 'pages', 'datalist-text.html'));
 | 
						|
    w.webContents.sendInputEvent({ type: 'keyDown', keyCode: 'Tab' });
 | 
						|
 | 
						|
    const inputText = 'clap';
 | 
						|
    for (const keyCode of inputText) {
 | 
						|
      w.webContents.sendInputEvent({ type: 'char', keyCode });
 | 
						|
      await setTimeout(100);
 | 
						|
    }
 | 
						|
 | 
						|
    w.webContents.sendInputEvent({ type: 'keyDown', keyCode: 'Down' });
 | 
						|
    w.webContents.sendInputEvent({ type: 'keyDown', keyCode: 'Enter' });
 | 
						|
 | 
						|
    const value = await w.webContents.executeJavaScript("document.querySelector('input').value");
 | 
						|
    expect(value).to.equal('Eric Clapton');
 | 
						|
  });
 | 
						|
 | 
						|
  it('can be selected via keyboard for a <datalist> with time type', async () => {
 | 
						|
    const w = new BrowserWindow({ show: true });
 | 
						|
    await w.loadFile(path.join(fixturesPath, 'pages', 'datalist-time.html'));
 | 
						|
 | 
						|
    const inputText = '11P'; // 1:01 PM
 | 
						|
    for (const keyCode of inputText) {
 | 
						|
      w.webContents.sendInputEvent({ type: 'keyDown', keyCode: 'Tab' });
 | 
						|
      w.webContents.sendInputEvent({ type: 'keyDown', keyCode });
 | 
						|
      w.webContents.sendInputEvent({ type: 'char', keyCode });
 | 
						|
      await setTimeout(100);
 | 
						|
    }
 | 
						|
 | 
						|
    w.webContents.sendInputEvent({ type: 'keyDown', keyCode: 'Tab' });
 | 
						|
 | 
						|
    const value = await w.webContents.executeJavaScript("document.querySelector('input').value");
 | 
						|
    expect(value).to.equal('13:01');
 | 
						|
  });
 | 
						|
});
 |