我在编写 angulae e2e 量角器测试时遇到问题,在尝试使用正确的电子邮件和密码测试登录时总是出现超时错误。
describe("login view", () => {
const app = new App();
const login = new LoginPage();
beforeAll(() => {
app.navigateTo(BASE_URL);
app.clearLocalStorage();
});
it("should login successfully", async () => {
await Promise.all([login.clearPassword(), login.clearUsername()]);
login.username = E2E_USERNAME;
login.password = E2E_PASSWORD;
login.submit.click();
const currentUrl = await app.currentUrl;
expect(currentUrl).toEqual(LABORATORIES_URL);
});
export class LoginPage {
private usernameInput = element(by.id("loginFormUsernameInput"));
private passwordInput = element(by.id("loginFormPasswordInput"));
private confirmButton = element(by.id("loginFormConfirmButton"));
public set username(username: string) {
this.usernameInput.sendKeys(username);
}
public set password(password: string) {
this.passwordInput.sendKeys(password);
}
public get submit(): ElementFinder {
return this.confirmButton;
}
}
我正在处理节点:10.19.0。 package.json:
"devDependencies": {
"@angular/cli": "^6.2.9",
"@angular/compiler-cli": "^6.1.3",
"protractor": "^5.4.1",
寻找这个问题的解决方案,任何人都可以提供帮助?
你能分享一下你的login.clearUsername()
和login.clearPassword()
的定义吗?
或者,与其在规范文件中使用await Promise.all([login.clearPassword(), login.clearUsername()]);
,不如像这样稍微改变一下你的 getter。
public set username(username: string) {
this.usernameInput.clear();
this.usernameInput.sendKeys(username);
}
public set password(password: string) {
this.passwordInput.clear();
this.passwordInput.sendKeys(password);
}