Angular 1.5用jasmine测试组件
Angular 1.5 test component with jasmine
我试着用Jasmine和Angular-mock测试我的组件,但我不知道这是怎么做的。
这是我的组件
var angular = require('angular');
'use strict';
module.exports = angular
.module('app.login.component.login', [])
.component('login', {
templateUrl: '/app/js/login/components/login.template.html',
controller: LoginController
});
LoginController.$inject = ['$state', 'Auth', 'messages'];
function LoginController($state, Auth, messages) {
var ctrl = this;
ctrl.failMessage = messages.NO_AUTH;
ctrl.failResponse = false;
ctrl.login = login;
function login(user){
ctrl.errors = {};
Auth.login(user)
.success(function(result){
$state.go('profile');
})
.error(function(response) {
ctrl.failResponse = true;
})
};
}
我写这个测试,但他不工作。请告诉我我做错了什么,并展示一些模式如何测试组件
describe('Component: login', function() {
beforeEach(angular.mock.module(require('angular-ui-router')));
beforeEach(angular.mock.module(loginComponent.name));
var scope;
beforeEach(inject(function($rootScope, $compile){
scope = $rootScope.$new();
}));
var controller;
beforeEach(inject(function($componentController, Auth) {
ctrl = $componentController('login', {
$scope:scope});
}));
it('df', function() {
expect(ctrl.login).toBeDefined();
});
});
使用$componentController
beforeEach(inject(function($rootScope, $componentController){
scope = $rootScope.$new();
controller = $componentController('myComponent', {$scope: scope});
}));
相关文章:
- 单元测试:使用酶模拟父组件中子组件的点击事件
- yeoman generator聚合物的web组件测试失败
- 测试React组件内部的fetch()方法
- 测试React表单组件
- Angular 2组件测试错误:无法解析'TestComponentBuilder'
- 如何使用React和Redux在嵌套容器中测试组件
- React js - 如何在测试组件时模拟上下文
- 测试使用 jQuery 和窗口对象的 React 组件
- 如何在 Angular 中对组件进行单元测试
- 如何使用 Jest 0.8.x 测试使用上下文的 React 组件,例如在 react-router 2.0 中
- 测试 Vue.js 组件
- 对子项进行反应测试组件
- ReactJS:测试包含组件的组件
- 测试 React 模态组件
- Ember:在集成测试中测试组件的WillDestroyElement逻辑
- Angular 2——带路由器出口的测试组件
- React -测试组件propTypes -预期失败
- 如何在AVA上使用@decorator (redux-connect)测试组件的decorator
- Angular 1.5用jasmine测试组件
- ";有角度的";测试组件的方法