jasmine-maven-plugin + phantomJS: Ошибка: [$ инжектор: номод]

Я создаю проект с:

mvn archetype:generate -DarchetypeGroupId=com.github.searls -DarchetypeArtifactId=jasmine-archetype -DarchetypeVersion=1.3.1.5 -DgroupId=com.acme -DartifactId=my-jasmine-project -Dversion=0.0.1-SNAPSHOT

Сначала я тестирую с помощью mvn jasmine: test тест выполняется нормально.

примечание: я использую maven 3.2.1

В каталог "target" я добавляю папку "phantomjs-1.9.7-windows", куда я помещаю "phantomjs.exe"

Я модифицирую свой оригинальный файл pom.xml, чтобы добавить

                ...
    <configuration>
        <srcDirectoryName>${project.artifactId}/src/main/javascript</srcDirectoryName>
        <webDriverClassName>org.openqa.selenium.phantomjs.PhantomJSDriver</webDriverClassName>
        <webDriverCapabilities>
            <capability>
                <name>phantomjs.binary.path</name>
                <value>${project.build.directory}/phantomjs-1.9.7-${os.phantomJS}/${run.phantomJS}</value>
            </capability>
        </webDriverCapabilities>


        <preloadSources>
            <source>${project.basedir}/src/main/javascript/libs/jquery-1.9.1.js</source>
            <source>${project.basedir}/src/main/javascript/libs/angular.js</source>
            <source>${project.basedir}/src/main/javascript/libs/angular-ui-router.js</source>
            <source>${project.basedir}/src/main/javascript/libs/angular-resource.js</source>
        </preloadSources>
    </configuration>
    ...

Я создаю папку "libs" в "src/main/javascript" и помещаю в нее: - jquery-1.9.1.js - angular.js - angular-ui-router.js - angular-resource.js

примечание: угловой в версии 1.2.23

После этого я создаю другую папку "app" в "src/main/javascript" и помещаю в нее: "app.module.js"

(function() {
    'use strict';

    angular.module('app', [
         'app.Security.modules'
    ]);
})();

Под "src/main/javascript/app" я создаю папку "security" и помещаю в нее: "security.module.js"

(function() {
'use strict';
    angular.module('app.Security.modules', []);
})();

и "cha_directive.js"

angular.module('app.Security.modules').directive('inputOld', InputAccessKeyManagement);
function InputAccessKeyManagement () {}

Если я тестирую с помощью mvn jasmine: test, я получаю ошибку:

[ERROR - 2015-02-26T08:12:49.751Z] Session [40eacc20-bd8f-11e4-a736-9934c466a5ff] - page.onError - stack:
  (anonymous function) (http://localhost:51170/jasmine-project/src/main/javascript/libs/angular.js:1679)
  ensure (http://localhost:51170/jasmine-project/src/main/javascript/libs/angular.js:1601)
  module (http://localhost:51170/jasmine-project/src/main/javascript/libs/angular.js:1892)
  (anonymous function) (http://localhost:51170/jasmine-project/src/main/javascript/app/security/cha_directive.js:1)
[WARNING] JavaScript Console Errors:

  * Error: [$injector:nomod] Module 'app.Security.modules' is not available! You either misspelled the module name or forgot to load it. If registering a module ensure that you specify the dependencies as the second argument.
http://errors.angularjs.org/1.2.23/$injector/nomod?p0=app.Security.modules


[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 3.163s
[INFO] Finished at: Thu Feb 26 09:12:49 CET 2015
[INFO] Final Memory: 12M/210M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal com.github.searls:jasmine-maven-plugin:1.3.1.5:test (default-cli) on project jasmine-project: The jasmine-maven-plugin encountered an exception:
[ERROR] java.lang.RuntimeException: java.lang.RuntimeException: There were javascript console errors.
[ERROR] at com.github.searls.jasmine.runner.SpecRunnerExecutor.execute(SpecRunnerExecutor.java:46)
[ERROR] at com.github.searls.jasmine.mojo.TestMojo.executeSpecs(TestMojo.java:86)

Если я просто переименую "cha_directive.js" в "toto_directive.js" (с тем же исходным кодом) и запусту mvn jasmine: test снова, тест будет запущен нормально.

Если я использую имя файла cha_directive.js и запускаю mvn jasmine: bdd. После этого я запускаю URL http://localhost:8234/ в FF, тесты запускаются нормально.

Единственное (если я редактирую HTML-код "Jasmine Spec Runner" с помощью fireBug), это то, что я вижу этот тег:

<head jmp_jserror="Error: [$injector:nomod] Module 'app.Security.modules' is not available! You either misspelled the module name or forgot to load it. If registering a module ensure that you specify the dependencies as the second argument. http://errors.angularjs.org/1.2.23/$injector/nomod?p0=app.Security.modules">

Если я смотрю в классе SpecRunnerExecutor.java в "checkForConsoleErrors", то есть тест:

WebElement head = driver.findElement(By.tagName("head"));
if (head != null) {
    String jserrors = head.getAttribute("jmp_jserror");
    if (StringUtils.isNotBlank(jserrors)) {
        throw new RuntimeException("There were javascript console errors.");
    }
}

примечание: другие имена файлов приводят к краху тестов: input_directive.js, accessKey_directive.js, ...

2 ответа

Решение

Это проблема порядка импорта скриптов.

Я заявляю

(function() {
   'use strict';
   angular.module('app.Security.modules', []);
})();

в файле с именем "s ecurity.module.js"

и я пытаюсь использовать мою декларацию

angular.module('app.Security.modules')
  .directive('inputOld', InputAccessKeyManagement);
  function InputAccessKeyManagement () {}

в файле с именем "c ha_directive.js"

Если вы не указали заказной порядок импорта сценариев, то по умолчанию используется алфавитный алфавит, тогда "c ha_directive.js" стоит перед "s ecurity.module.js".

Я решил проблему, используя "customRunnerTemplate".

Но, может быть, был еще один способ сделать "красивее"?

Если кто-то еще сталкивается с этим, хорошее решение состоит в том, чтобы сделать что-то подобное в вашем блоке sourceInclude:

<sourceInclude>
  <include>**/*.module.js</include>
  <include>**/*.controller.js</include>
  <include>**/*.service.js</include>
...

И так далее. Предполагая, что вы соответствуете определению ваших модулей в файле, называемом что-то вроде 'example.module.js', сначала будут загружены модули, затем контроллер, и так далее.

Другие вопросы по тегам