我正在尝试使用Protractor和Jasmine语法在typescript中编写一些e2e测试,使用Page Object从测试中抽象出DOM结构。
当运行量角器时,我收到错误,告诉我我的页面对象不是函数。
以下是作为打字稿类的页面对象:home.po.spec.ts
module Tests.e2e.Home {
export class HomePage {
emailInput;
constructor() {
this.emailInput = element(by.model('email'));
}
get(): void {
browser.get('https://localhost:44300');
}
get email(): string {
return this.emailInput.getText();
}
set email(value: string) {
this.emailInput.sendKeys(value);
}
}
}
这是我的测试:home.e2e.spec.ts
///<reference path="home.po.spec.ts"/>
module Tests.e2e.Home {
describe('home view', () => {
it('should mark invalid email in field', () => {
// arrange
var homePage = new HomePage();
homePage.get();
var emailField = homePage.emailInput;
// act
homePage.email = 'some invalid email';
// assert
expect(emailField.getAttribute('class')).toMatch('ng-invalid');
});
});
}
我正在Visual Studio 2013中编写测试并在nodejs上运行带有gulp任务的量角器。
以下是错误消息:
Starting selenium standalone server...
[launcher] Running 1 instances of WebDriver
Selenium standalone server started at http://192.168.5.153:23704/wd/hub
F
Failures:
1) home view should mark invalid email in field
Message:
TypeError: Home.HomePage is not a function
Stacktrace:
TypeError: Home.HomePage is not a function
at [object Object].<anonymous>(C:\Users\BSO\Documents\Git repos\app\Prese
ntation.Web\Tests\home.e2e.spec.ts:5:28)
at C: \Users\BSO\AppData\Roaming\npm\node_modules\protractor\node_modules\jas
minewd\index.js:94:14
at goog.async.run.processWorkQueue(C:\Users\BSO\AppData\Roaming\npm\node_mo
dules\protractor\node_modules\selenium - webdriver\lib\goog\async\run.js:130:15)
From: Task: Asynchronous test function: it()
at[object Object].<anonymous> (C:\Users\BSO\AppData\Roaming\npm\node_module
s\protractor\node_modules\jasminewd\index.js:93:33)
at[object Object].<anonymous> (C:\Users\BSO\AppData\Roaming\npm\node_module
s\protractor\node_modules\minijasminenode\lib\async - callback.js:45:37)
at[object Object].jasmine.Block.execute(C:\Users\BSO\AppData\Roaming\npm\n
ode_modules\protractor\node_modules\minijasminenode\lib\jasmine - 1.3.1.js:1174:17
)
at[object Object].jasmine.Queue.next_(C:\Users\BSO\AppData\Roaming\npm\nod
e_modules\protractor\node_modules\minijasminenode\lib\jasmine - 1.3.1.js:2209:31)
at[object Object]._onTimeout(C:\Users\BSO\AppData\Roaming\npm\node_modules
\protractor\node_modules\minijasminenode\lib\jasmine - 1.3.1.js:2199:18)
Error
at[object Object].<anonymous> (C:\Users\BSO\Documents\Git repos\app\Prese
ntation.Web\Tests\home.e2e.spec.ts:3:9)
at[object Object].jasmine.Env.describe_(C:\Users\BSO\AppData\Roaming\npm\n
ode_modules\protractor\node_modules\minijasminenode\lib\jasmine - 1.3.1.js:913:21)
at[object Object].jasmine.Env.describe(C:\Users\BSO\AppData\Roaming\npm\no
de_modules\protractor\node_modules\minijasminenode\lib\jasmine - 1.3.1.js:898:15)
at describe (C:\Users\BSO\AppData\Roaming\npm\node_modules\protractor\node_m
odules\minijasminenode\lib\jasmine - 1.3.1.js:658:27)
at e2e.Home.e2e.Home(C:\Users\BSO\Documents\Git repos\app\Presentation.We
b\Tests\home.e2e.spec.ts:2:5)
at Tests.e2e.Tests.e2e(C:\Users\BSO\Documents\Git repos\app\Presentation.
Web\Tests\home.e2e.spec.ts:16:2)
at Tests (C:\Users\BSO\Documents\Git repos\app\Presentation.Web\Tests\home
.e2e.spec.ts:16:2)
at Object.<anonymous>(C:\Users\BSO\Documents\Git repos\app\Presentation.W
eb\Tests\home.e2e.spec.ts:16:2)
Finished in 0.031 seconds
1 test, 1 assertion, 1 failure
Shutting down selenium standalone server.
[launcher] 0 instance(s) of WebDriver still running
[launcher] chrome #1 failed 1 test(s)
[launcher] overall: 1 failed spec(s)
[launcher] Process exited with error code 1
任何人都可以帮我吗?如何制作测试文件参考
解决方案是不要在TypeScript中使用内部模块。
通过更改为commonjs模块系统并使用typescripts import something = require('path to someting')
,它可以按预期工作。
以下是设置示例。
页面对象home.po.spec.ts
:
class HomePage {
getPage(): void {
browser.get('https://localhost:44300/');
}
nameElement = element(by.id('name'));
get nameInput(): string {
var value: string;
this.nameElement.getAttribute('value').then(v => value = v);
return value;
}
set nameInput(value: string) {
this.nameElement.sendKeys(value);
}
}
export = HomePage;
测试规范home.e2e.spec.ts
:
import HomePo = require('./home.po.spec');
describe('home view', () => {
it('name input should be writeable', () => {
// arrange
var pageObject: HomePo = new ItProjectEditPo();
pageObject.getPage();
// act
pageObject.nameInput = 'SomeName';
// assert
expect(pageObject.nameInput).toBe('SomeName');
});
});
关于解决方案的一些注意事项。 使用TypeScript属性时,页面对象需要解析元素getAttribute promise,getAttribute返回一个promise但sendKeys接受一个字符串。
TypeScript modules documentation is here。我花了一些时间来理解它,但现在它很有意义。通过使用此模块结构,还可以导入nodejs包。
答案 0 :(得分:4)
您可能告诉量角器要包含所有*.spec.ts
个文件,因此量角器将按abc的顺序包含它们。这意味着文件home.e2e.spec.ts
将包含在home.po.spec.ts
文件之前。
您有两种选择:
import
对页面对象(而不是参考文件)您还没有看到另一个问题:您在构造函数中初始化了emailInput
,但在初始化后调用了get
...