Jasmine and Requirejs in Resharper 7

前端 未结 3 768
情话喂你
情话喂你 2021-01-13 15:28

I\'m trying to run some JavaScript code using jasmine and Resharper 7 within visual studio 2012. I follow the AMD pattern with the aid of requirejs. However, i haven\'t mana

相关标签:
3条回答
  • 2021-01-13 15:47

    Use a named requireJS Module

    define("my/sut", function () {
    
        var MySut = function () {
            return {
                answer: 42
            };
        };
        return MySut;
    });
    

    And initialize the SUT with the asyncronus support of Jasmine. Don't forgot the references!

    /// <reference path="~/Scripts/require.js"/>
    /// <reference path="../code/sut.js" />
    
    describe("requireJS with Jasmine and Resharper", function () {
    
        it("should be executed", function () {
    
            // init SUT async
            var sut;
            runs(function () {
                require(['my/sut'], function (MyModel) {
                    sut = new MyModel();
                });
            });
            waitsFor(function () {
                return sut;
            }, "The Value should be incremented", 100);
    
            // run the test
            runs(function () {
                expect(sut.answer).toBe(42);
            });
        });
    });
    

    I hope this works with more modules. In my case it worked with waitsFor '0' ms.

    0 讨论(0)
  • 2021-01-13 15:49

    If you use Jasmine 2.0 or newer, you can support asynchronous calls in your code. Just pass the done parameter into the function for your it unit test, then call done() when you have loaded your modules:

    describe("add function", function(){
       it("calls renderNew", function(done){
          define("taskRenderer", [], function() {
             return {
                renderNew: function(){}
             };
          });
    
          require(["taskRenderer"], function(taskRenderer) {
             spyOn(taskRenderer, "renderNew");
             taskRenderer.renderNew();
             expect(taskRenderer.renderNew).toHaveBeenCalled();
             done();
          });
       }
    }
    

    This way, you don't actually perform your test until the modules are loaded and the test doesn't prematurely get marked as finished.

    0 讨论(0)
  • 2021-01-13 16:05

    A simplified version of mgsdev response, put the loading code in a beforeEach statement, that way you can write short expectations.

    module:

    define("stringCalculator", function () {
        return {
            calculate: function (string) {
                var result = 0;
                string.split("+").forEach(function(number) {
                    result += parseInt(number);
                });
                return result;
            }
        };
    });
    

    test file: if calculator is undefined it will try to load it before every expectation.

    /// <reference path="~/Scripts/require.js"/>
    /// <reference path="~/code/stringCalculator.js"/>
    
    describe("string calculator", function () {
        var calculator;
    
        beforeEach(function () {    
            if (!calculator) {
                require(["stringCalculator"], function (stringCalculator) {
                    calculator = stringCalculator;
                });
    
                waitsFor(function () {
                    return calculator;
                }, "loading external module", 1000);
            }
        });
    
        it("should add 1 and 2", function () {
            var result = calculator.calculate("1+2");
            expect(result).toEqual(3);
        });
    
        it("should add 2 and 2", function () {
            var result = calculator.calculate("2+2");
            expect(result).toEqual(4);
        });
    
        it("should add 1, 2 and 3", function() {
            var result = calculator.calculate("1+2+3");
            expect(result).toEqual(6);
        });
    });
    
    0 讨论(0)
自定义标题
段落格式
字体
字号
代码语言
提交回复
热议问题