2016-11-18 2 views
1

Я пытаюсь настроить образец приложения в Angular 2, сейчас я пытаюсь проверить часть тестирования e2e. У меня мало знаний о структуре Jasmine или библиотеки Protractor, которую использует Angular 2.Ошибка тестирования E2E

Так что я не знаю, почему я мой получаю эту ошибку, когда я бегу ng e2e (я использую Угловое CLI)

Я получаю ошибку:

[09:41:10] I/direct - Using ChromeDriver directly... 
[09:41:10] I/launcher - Running 1 instances of WebDriver 
[09:41:12] E/launcher - Error: TSError: ? Unable to compile TypeScript 
e2e\app.e2e-spec.ts (16,4): Cannot find name 'browser'. (2304) 
e2e\app.e2e-spec.ts (17,19): Cannot find name 'element'. (2304) 
e2e\app.e2e-spec.ts (17,27): Cannot find name 'by'. (2304) 
e2e\app.e2e-spec.ts (18,5): Supplied parameters do not match any signature of ca 
ll target. (2346) 

Мой тест (app.e2e- spec.ts)

import { WebPage } from './app.po'; 

describe('web App', function() { 
    let page: WebPage; 

    beforeEach(() => { 
    page = new WebPage(); 
    }); 

    it('should display message saying app works',() => { 
    page.navigateTo(); 
    expect(page.getParagraphText()).toEqual('Hello World'); 
    }); 

    it('Has a greeting', function() { 
    browser.get('/index.html'); 
    var greeting = element(by.id('h2Id')); 
    expect().getText(greeting).toEqual('Hello, World!'); 
    }); 


}); 

Protrator.config.js

// Protractor configuration file, see link for more information 
// https://github.com/angular/protractor/blob/master/docs/referenceConf.js 

/*global jasmine */ 
var SpecReporter = require('jasmine-spec-reporter'); 

exports.config = { 
    allScriptsTimeout: 11000, 
    specs: [ 
    './e2e/**/*.e2e-spec.ts' 
    ], 
    capabilities: { 
    'browserName': 'chrome' 
    }, 
    directConnect: true, 
    baseUrl: 'http://localhost:4200/', 
    framework: 'jasmine', 
    jasmineNodeOpts: { 
    showColors: true, 
    defaultTimeoutInterval: 30000, 
    print: function() {} 
    }, 
    useAllAngular2AppRoots: true, 
    beforeLaunch: function() { 
    require('ts-node').register({ 
     project: 'e2e' 
    }); 
    }, 
    onPrepare: function() { 
    jasmine.getEnv().addReporter(new SpecReporter()); 
    } 
}; 
+1

'импорт {браузер, элемент, по} от 'транспортир'; 'Обратите внимание, что, как правило, вы бы их в * страница объекта * (см, например, [' app.po.ts'] (https://github.com/textbook/known-for-web/blob/master/e2e/pages/app.po.ts)), который абстрагирует бизнес, фактически взаимодействующий с DOM, из теста и демонстрирующий более удобный API делая ваши тесты более читабельными (например, ['app.e2e-spec.ts'] (https://github.com/textbook/known-for-web/blob/master/e2e/app.e2e-spec.ts)) - разница между 'page.getGreetingText()' и 'element (by.id ('h2Id')). getText()' в вашем примере. Вот как это делает CLI. – jonrsharpe

+0

Я вижу, что это работает, я предположил, что CLI неявно импортировал библиотеку, спасибо за ваш ответ – Snedden27

+0

CLI включает эти импортные файлы в автоматически сгенерированный файл '.po', где вы ожидаете взаимодействия с браузером и конкретными элементами, а не в файле '.e2e-spec', где вы не находитесь. – jonrsharpe

ответ

0

app.e2e-spec.ts:

ожидать(). GetText (приветствие) .toEqual ('Hello, World!');

=> expect(greeting.getText()).toEqual('Hello, World!'); 
+0

, пожалуйста, объясните свой ответ! – Mazz

+0

Добро пожаловать в StackOverflow. См. Здесь [как форматировать код] (https://stackoverflow.com/editing-help) –

Смежные вопросы