Тестирование ввода текста для приложения Electron

Я пытаюсь разобраться с использованием Electron и Spectron для его тестирования.

Я хотел бы написать в своем теле, которое является contentEditable, а затем проверить, что текст соответствует в моем тесте. До сих пор мне удалось написать успешный тест для названия, но я не могу найти решение для этого.

Index.html;

<!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>Hello</title>
    </head>
    <body id = "test" contentEditable = true>
    </body>
</html>

featureTest.js, который включает в себя прохождение теста для заголовка и мою попытку прохождения теста, которую я хотел бы получить внизу.

const electron = require("electron");
var expect = require("chai").expect;

var Application = require("spectron").Application;
var assert = require("assert");

describe("application launch", function() {
  this.timeout(10000);

  beforeEach(function() {
    this.app = new Application({
      path: `${__dirname}/../node_modules/.bin/electron`,
      args: ["main.js"]
    });
    return this.app.start();
  });

  afterEach(function() {
    if (this.app && this.app.isRunning()) {
      return this.app.stop();
    }
  });

  it("title says Hello", function() {
    return this.app.client
      .waitUntilWindowLoaded()
      .getTitle()
      .then(text => expect(text).to.eq("Hello"));
  });

  it("inputs and then finds the text on the page", function() {
    return this.app.client
      .waitUntilWindowLoaded()
      .elementIdText("test")
      .keys("Hello World!")
      .then(text => expect(text).to.eq("Hello World!"));
  });
});

main.js;

const {app, BrowserWindow, Menu} = require('electron')
const path = require('path')
const url = require('url')
const fs = require("fs")

let mainWindow;

app.on('ready', function () {

  mainWindow = new BrowserWindow({width: 800, height: 600})

  mainWindow.loadURL(url.format({
    pathname: path.join(__dirname, 'index.html'),
    protocol: 'file:',
    slashes: true
  }))

  // Open the DevTools.
  // mainWindow.webContents.openDevTools()

  mainWindow.on('closed', () => {
    app.quit();
  })

  const mainMenu = Menu.buildFromTemplate(mainMenuTemplate);

  Menu.setApplicationMenu(mainMenu);

  if(process.platform == 'darwin'){
    mainMenuTemplate.unshift({});
  }

});

package.JSON

"devDependencies": {
    "chai": "^4.1.2",
    "electron": "^1.7.8",
    "mocha": "^4.0.1",
    "spectron": "^3.7.2"
  }

2 ответа

Решение

Гораздо чище это

 return app.client.waitForVisible('#test')
        .waitForEnabled('#test')
        .clearElement('#test')
        .setValue('#test', "TEST")
        .getValue('#test')
        .should.eventually.equal("TEST")

Я нашел решение своей проблемы, просто пишу здесь для справки, если это нужно другим

Рабочий тест;

it("should enter and show text", function(){
    return this.app.client
      .waitUntilWindowLoaded()
      .click('#test')
      .keys('Hello')
      .getText('#test')
      .then(text => expect(text).to.eq('Hello'))

Кажется, что.get[что-то] функции помещает текст в текстовую переменную автоматически, из которого вы можете проверить.

Другие вопросы по тегам