Где я могу разместить HTML-фикстуры при использовании JsTestDriver? - PullRequest
4 голосов
/ 14 января 2012

Мне трудно заставить JSTD загрузить HTML-файл фикстуры.

Моя структура каталогов:

 localhost/JsTestDriver.conf
 localhost/JsTestDriver.jar
 localhost/js/App.js
 localhost/js/App.test.js
 localhost/fixtures/index.html

В моем файле conf указано:

server: http://localhost:4224

serve:

- fixtures/*.html

load: 

- http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js
- jasmine/lib/jasmine-1.1.0/jasmine.js
- jasmine/jasmine-jquery-1.3.1.js
- jasmine/jasmine-jstd.js
- js/App.js

test: 

- js/App.test.js

Мой тест:

describe("App", function(){

    beforeEach(function(){
        jasmine.getFixtures().fixturesPath = 'fixtures';
        loadFixtures('index.html'); **//THIS LINE CAUSES IT TO FAIL**
    });

    describe("When App is loaded", function(){

        it('should have a window object', function(){
            expect(window).not.toBe(null);
        });

    });

});

И вывод моей консоли:

enter image description here

( ссылка на полноразмерное изображение )

Я посмотрел на этот вопрос , но это не помогло мне разобраться.Странно то, что когда я закомментирую строку

loadFixtures ('index.html');

, тест пройден.

Anyидеи?

Ответы [ 2 ]

2 голосов
/ 05 июня 2012

Ладно - разобрался. JsTestDriver добавляет «test» к пути к вашим приборам.

Кроме того, jasmine-jquery получает светильники, используя ajax.

Таким образом, эти шаги, наконец, сработали для меня:

В jsTestDriver.conf:

serve:
 - trunk/wwwroot/fixtures/*.html

load:

  - trunk/wwwroot/js/libs/jquery-1.7.1.min.js 
  - jstd/jasmine/standalone-1.2.0/lib/jasmine-1.2.0/jasmine.js
  - jstd/jasmine-jstd-adapter/src/JasmineAdapter.js
  - jstd/jasmine-jquery/lib/jasmine-jquery.js

  - trunk/wwwroot/js/main.js

test:

  - trunk/wwwroot/js/main.test.js

В моем тестовом файле:

describe("main", function(){

    beforeEach(function(){
        jasmine.getFixtures().fixturesPath = '/test/trunk/wwwroot/fixtures';
        jasmine.getFixtures().load('main.html');
    });

    describe("when main.js is loaded", function(){

        it('should have a div', function(){
            expect($('div').length).toBe(1); 
        });

    });

});

Обратите внимание, что в вызове beforeEach() используется абсолютный URL-адрес для устройства HTML.

0 голосов
/ 19 января 2012

Попробуйте изменить путь к устройству:

jasmine.getFixtures().fixturesPath = '/fixtures';

В противном случае получаются разные, но странные ошибки.

...