Jasmine 因果报应/茉莉花:错误:[ng:areq]论点';loginController';不是函数,未定义
我的控制器文件:Jasmine 因果报应/茉莉花:错误:[ng:areq]论点';loginController';不是函数,未定义,jasmine,Jasmine,我的控制器文件: define(['app', 'back123','loginService'], function (app) { app.controller('loginController', function ($scope, $window, loginService, srvAuth) {$scope.emailValidate = function () { var pattern = /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w
define(['app', 'back123','loginService'], function (app) {
app.controller('loginController', function ($scope, $window, loginService, srvAuth) {$scope.emailValidate = function () {
var pattern = /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/;
if (!pattern.test($scope.Email) ) {
$scope.email_invalid = true;
return false;
}
else {
$scope.email_invalid = false;
return true;
}
};
})
}))
我的测试文件:
define(['app', 'jquery', 'angular-mock', 'coreService', 'setterService', 'loginService','logincontroller'], function (App, $) {
describe('app', function () {
beforeEach(module('app'));
describe('logincontroller Email Vaidate', function () {
var scope;
beforeEach(inject(function ($rootScope, $controller) {
scope = $rootScope.$new();
$controller("loginController", {
$scope: scope
});
}));
it('sets email false', function () {
scope.email_invalid = false;
scope.Email = 'true';
scope.emailValidate();
expect(scope.email_invalid).toEqual(false);
});
});
});
}))
在我的浏览器中,加载了“源”选项卡loginCtrl文件,其中包含logincontroller函数
还在出错吗
Error: [ng:areq] Argument 'loginController' is not a function, got undefined
请建议由于我使用了angularAMD,我将代码更新如下:
angularAMD.inject(function ($rootScope, $controller) {
scope = $rootScope.$new();
$controller("loginController", {
$scope: scope
});
});
此外,我还将angularAMD作为依赖项包含在定义模块中:
define(['app', 'jquery', 'angularAMD', 'angular-mock', 'coreService', 'setterService', 'loginService', 'loginController'], function (App, $, angularAMD) {
只是补充一下,我使用require.js加载文件,如果您在测试中加载模块,则不需要
define
。