gpt4 book ai didi

javascript - Angular 1.5 测试组件与 jasmine

转载 作者:行者123 更新时间:2023-11-27 22:35:00 27 4
gpt4 key购买 nike

我尝试用 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});
}));

关于javascript - Angular 1.5 测试组件与 jasmine,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39195921/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com