如何在Chutzpah的无头浏览器中使用templateUrl测试指令

Bri*_*128 16 jasmine chutzpah angularjs

有谁知道如何让像Chutzpah的Visual Studio测试适配器这样的无头浏览器允许指令访问其.html模板文件?Chutzpah使用PhantomJS作为无头浏览器,似乎限制了我的选择.

我正在使用Chutzpah Test Adapter 2.5和AngularJS 1.2.0-r.2.

我收到错误:

意外请求:获取myApp/directives/template.html

这是由Angular尝试使用$ http服务访问我的指令模板引起的.

我找到了一些不同的解决方法:

  1. 手动使用XMLHttpRequest导入模板.
  2. 使用像Grunt这样的实用程序将模板内联到指令的JS代码中.
  3. $httpBackend.when('GET', 'myApp/directives/template.html').passThrough() - 这仅适用于e2e测试,而不适用于单元测试.
  4. 将模板直接放入测试代码中.

这些选择都没有特别让我满意.我希望能够让指令透明地加载它的模板,这样我就可以将它作为一个组件进行测试.有没有办法让这个场景有效?

示例代码:

angular.module('myDirective', []).directive('myDirective', function() {
    return {
        restrict: 'E',
        transclude: true,
        templateUrl: 'myApp/directives/template.html',
        // Some other options, omitted for brevity.
    };
});
Run Code Online (Sandbox Code Playgroud)

template.html:

<div><div ng-transclude></div></div>
Run Code Online (Sandbox Code Playgroud)

茉莉花测试示例:

describe('myDirective', function() {
    // Assign $scope using inject(), load module etc.
    // Insert workaround for $httpBackend loading my templateUrl here.
    it('should transclude content', function() {
        var element = $compile("<my-directive>Look Mom, I'm in my directive!</my-directive>")($scope);
        $scope.$digest();

        expect(element.text().trim()).toBe("Look Mom, I'm in my directive!");
    });
}
Run Code Online (Sandbox Code Playgroud)

eva*_*n w 5

我设法使用Chutzpah的编译选项让它工作.我将karma-ng-html2js-preprocessor移植到PowerShell脚本中,然后从Chutzpah调用它将HTML编译成JS文件.

在chutzpah.json设置文件旁边添加了PowerShell脚本(以下脚本包含对PreprendPrefix和StripSuffix的未经测试的支持)

# PowerShell port of https://github.com/karma-runner/karma-ng-html2js-preprocessor

Param (
    [parameter(Mandatory=$true)] [string] $Path,
    [string] $Module = '',
    [string] $StripPrefix = '',
    [string] $PrependPrefix = '',
    [string] $StripSuffix = ''
)

Function EscapeContent($content) {
    $content -replace "\\", "\\\\" -replace "'", "\'" -replace  "`r?`n", "\n' +`n    '"
}

Function Rename($fileName) {
    "$PrependPrefix" + ("$fileName" -replace "$StripPrefix", '' -replace "$StripSuffix", '' -replace "\\", "/")
}

$Template = If ("$Module" -eq "") {
    "angular.module('{0}', []).run(function(`$templateCache) {{`n" `
      + "  `$templateCache.put('{0}',`n    '{2}');`n" `
      + "}});`n"
  } Else {
    "(function(module) {{`n" `
        + "try {{`n" `
        + "  module = angular.module('{1}');`n" `
        + "}} catch (e) {{`n" `
        + "  module = angular.module('{1}', []);`n" `
        + "}}`n" `
        + "module.run(function(`$templateCache) {{`n" `
        + "  `$templateCache.put('{0}',`n    '{2}');`n" `
        + "}});`n" `
        + "}})();`n"
  }

Get-ChildItem $Path -Recurse -Filter *.html | Foreach-Object {
    $content = Get-Content $_.FullName | Out-String
    $content = EscapeContent $content
    $fileName = Rename "$($_.FullName)"
    ("$Template" -f "$fileName", "$Module", "$content") | Set-Content "$($_.FullName).js"
}
Run Code Online (Sandbox Code Playgroud)

编译配置添加到chutzpah.json并将"已编译"的JS文件添加到References(可以从测试文件中添加引用,但我更喜欢使用chutzpah.json来管理所有引用)

{
    "References": [
        { "Path": "./path/to/templates/", "Include": "*.html.js" },
    ],
    "Compile": {
        "Extensions": [".html"],
        "ExtensionsWithNoOutput": [".html.js"],
        "SourceDirectory": "./path/to/templates",
        "OutDirectory": "./path/to/templates",
        "Executable": "%powershellexe%",
        "Arguments": "-NoProfile %chutzpahsettingsdir%\\chutzpah-ng-html2js-compiler.ps1 -Path '/path/to/templates/' -Module 'templates' -StripPrefix '.+(?=\\\\templates)'"
    }
}
Run Code Online (Sandbox Code Playgroud)

在您的测试文件中,加载模块,在我的情况下,它们都在"模板"模块中

beforeEach(module('templates'));
// or alternatively
beforeEach(module('/path/to/templates/foo.html'));
Run Code Online (Sandbox Code Playgroud)


squ*_*hel 5

你可以使用Chutzpah的"模板"参考

http://matthewmanela.com/blog/chutzpah-2-4-2/

/// <template path="../../MvcAngularJs1_3/ScriptsApp/directives/Templates/testTemplate.html" />
/// <reference path="../../mvcangularjs1_3/scripts/jquery-2.1.1.js" />
/// <reference path="../../mvcangularjs1_3/scripts/angular.js" />
/// <reference path="../../mvcangularjs1_3/scripts/angular-mocks.js" />
...
Run Code Online (Sandbox Code Playgroud)

在引用下,Chutzpah直接在测试HTML文件中包含HTML.我已经为我的模板提供了一个独特的css类来查找它们并将它们手工放入模板AngularJS模板缓存中.

我的HTML模板

<div class="row templateTestTemplate">
   <div class="col-lg-12">
       <h1>Tempalte Test</h1>
   </div>
</div>
Run Code Online (Sandbox Code Playgroud)

指令

angular.module("testTemplateDirective", [])
    .directive("testTemplate", function() {
        return {
           restrict: 'A',
           replace: true,
           templateUrl: 'ScriptsApp/directives/Templates/testTemplate.html'
       }
});
Run Code Online (Sandbox Code Playgroud)

在我的单元测试中我使用jQuery查找模板并将其添加到模板缓存中.Angular第一次在模板缓存中查找并且不进行HTTP调用.

var template = jQuery(".templateTestTemplate")[0].outerHTML;
$templateCache.put("ScriptsApp/directives/Templates/testTemplate.html", template);
Run Code Online (Sandbox Code Playgroud)

到目前为止工作得很好,但只适用于chutzpah,当您使用Resharper运行此测试时,测试将失败,因为resharper不会将模板复制到测试HTML中.

我还在Chutzpah GitHub页面上打开一个请求,用脚本标签和ID包围HTML,这样你就不需要扩展模板 https://github.com/mmanela/chutzpah/issues/330