/***************************************************************************** * Open MCT, Copyright (c) 2014-2018, United States Government * as represented by the Administrator of the National Aeronautics and Space * Administration. All rights reserved. * * Open MCT is licensed under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.apache.org/licenses/LICENSE-2.0. * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. * * Open MCT includes source code licensed under additional open source * licenses. See the Open Source Licenses file (LICENSES.md) included with * this source code distribution or the Licensing information page available * at runtime from the About dialog for additional information. *****************************************************************************/ define( ["../src/TemplateLinker"], function (TemplateLinker) { var JQLITE_METHODS = ['replaceWith', 'empty', 'html', 'contents'], SCOPE_METHODS = ['$on', '$new', '$destroy']; describe("TemplateLinker", function () { var mockTemplateRequest, mockSce, mockCompile, mockLog, mockScope, mockElement, mockTemplates, mockElements, mockContents, mockNewScope, mockPromise, linker; function testExtension(path, res, templatePath) { return { bundle: { path: path, resources: res }, templateUrl: templatePath }; } beforeEach(function () { mockTemplateRequest = jasmine.createSpy('$templateRequest'); mockSce = jasmine.createSpyObj('$sce', ['trustAsResourceUrl']); mockCompile = jasmine.createSpy('$compile'); mockLog = jasmine.createSpyObj('$log', ['error', 'warn']); mockScope = jasmine.createSpyObj('$scope', SCOPE_METHODS); mockNewScope = jasmine.createSpyObj('$scope', SCOPE_METHODS); mockElement = jasmine.createSpyObj('element', JQLITE_METHODS); mockPromise = jasmine.createSpyObj('promise', ['then']); mockTemplates = {}; mockElements = {}; mockContents = {}; mockTemplateRequest.and.returnValue(mockPromise); mockCompile.and.callFake(function (toCompile) { var html = typeof toCompile === 'string' ? toCompile : toCompile.testHtml; mockTemplates[html] = jasmine.createSpy('template'); mockElements[html] = jasmine.createSpyObj('templateEl', JQLITE_METHODS); mockTemplates[html].and.returnValue(mockElements[html]); return mockTemplates[html]; }); mockSce.trustAsResourceUrl.and.callFake(function (url) { return { trusted: url }; }); mockScope.$new.and.returnValue(mockNewScope); mockElement.html.and.callFake(function (html) { mockContents[html] = jasmine.createSpyObj('contentsEl', JQLITE_METHODS); mockContents[html].testHtml = html; }); mockElement.contents.and.callFake(function () { return mockContents[ mockElement.html.calls.mostRecent().args[0] ]; }); linker = new TemplateLinker( mockTemplateRequest, mockSce, mockCompile, mockLog ); }); it("resolves extension paths", function () { var testExt = testExtension('a', 'b', 'c/d.html'); expect(linker.getPath(testExt)).toEqual('a/b/c/d.html'); }); describe("when linking elements", function () { var changeTemplate, commentElement; function findCommentElement() { mockCompile.calls.all().forEach(function (call) { var html = call.args[0]; if (html.indexOf("