Ich versuche Winkel-tdd zu lernen
Mit diesen Versionen funktionieren meine Tests einwandfrei
Abhängigkeitsversion
eckig: 1.4.8
eckig-spott: 1.4.8
Knoten: v4.4.5
Karma-Kli: 0.13.22
aber wenn ich benutze
Versionen
"eckig": "^1.5.7"
"angular-mocks": "^1.5.7"
es wirft einen Fehler
karma start karma.conf.js
22 06 2016 16:53:04.002:WARN [karma]: No captured browser, open http://localhost:9876/
22 06 2016 16:53:04.012:INFO [karma]: Karma v0.13.22 server started at http://localhost:9876/
22 06 2016 16:53:04.018:INFO [launcher]: Starting browser Chrome
22 06 2016 16:53:05.959:INFO [Chrome 51.0.2704 (Linux 0.0.0)]: Connected on socket /#Vfy_Fpt6BZ2INRyEAAAA with id 36097936
Chrome 51.0.2704 (Linux 0.0.0) calculator sum 1 + 1 should equal 2 FAILED
TypeError: Function.prototype.bind.apply(...) is not a constructor
at Object.instantiate (/home/malanay/workspace/AngularJs-BDD-101/node_modules/angular/angular.min.js:41:477)
at /home/kiro112/workspace/AngularJs-BDD-101/node_modules/angular/angular.min.js:90:3
at /home/kiro112/workspace/AngularJs-BDD-101/node_modules/angular-mocks/angular-mocks.js:2214:12
at Object.it (/home/kiro112/workspace/AngularJs-BDD-101/tests/calculator.controller.test.js:17:21)
Chrome 51.0.2704 (Linux 0.0.0): Executed 1 of 1 (1 FAILED) (0 secs / 0.027 Chrome 51.0.2704 (Linux 0.0.0): Executed 1 of 1 (1 FAILED) ERROR (0.037 secs / 0.027 secs)
Das Problem besteht darin, den Funktionskonstruktor für die Controller-Klasse mit der Fat Arrow-Syntax zu definieren. Angenommen, Ihre als zweites Argument an module.controller übergebene Funktion ist Foo
, Angular ruft new Foo(...)
auf, was mit der Fat Arrow-Syntax in ES6 illegal ist.
@wesleycho , hat recht. Controller sollten instanziierbar sein (dh mit new
aufgerufen werden), also sind Dinge wie Pfeilfunktionen ( () => {...}
) und Kurzform-Objektmethoden ( {someMethod() {...}}
) nicht für Controller geeignet.
Weitere Informationen finden Sie unter https://github.com/angular/angular.js/issues/14766#issuecomment -226005516.
Hilfreichster Kommentar
Das Problem besteht darin, den Funktionskonstruktor für die Controller-Klasse mit der Fat Arrow-Syntax zu definieren. Angenommen, Ihre als zweites Argument an module.controller übergebene Funktion ist
Foo
, Angular ruftnew Foo(...)
auf, was mit der Fat Arrow-Syntax in ES6 illegal ist.