Nano Hash - криптовалюты, майнинг, программирование

документ не определен Импорт ES6 с помощью Jasmine с зависимостями внешней библиотеки (Babel)

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

App.js

// App.js - will be used to init the app
import Game from './Game';

const app = {
    initialize: function () {
        this.start();
    },
    start: function () {
        new Game();
    }
};

export default app;

Game.js

// Game.js - used to build out a Phaser Game
// chosen to use classes in this case. (not sure if relevant)
import Phaser from '../libs/phaser/phaser.min';

class Game extends Phaser.Game {

    constructor() {
        super(500, 500, Phaser.AUTO, 'content', null);
    }
}

export default Game;

Набор тестов

Я использую: Jasmine (cli в узле). Я не особенно хочу использовать что-то вроде Karma, но буду, если это единственный способ заставить все работать.

Вот моя спецификация приложения:

import app from "app";

describe("App", function() {

    describe("when app is started", function() {

        beforeEach(function () {

            app.initialize();
        });

        it("expect application to start after initialization", function() {
            expect(app.start).toHaveBeenCalled();
        });
    });
});

Запуск теста

Я запускаю тест через сценарий npm через babel (на самом деле не уверен, что здесь происходит. Может быть, кто-то может помочь мне пролить свет на это):

babel-node --presets es2015 ./node_modules/.bin/jasmine

Итак, он все компилирует, а затем запускает тест:

Проблема

Когда я запускаю тест, я получаю:

ReferenceError: document is not defined
    at Object.create (/Users/auser/Code/games/test/libs/phaser/phaser.min.js:7:10242)
    at new b.CanvasBuffer (/Users/auser/Code/games/test/libs/phaser/phaser.min.js:8:22106)
    at Function.b.CanvasTinter.checkInverseAlpha (/Users/auser/Code/games/test/libs/phaser/phaser.min.js:8:24223)
    at /Users/auser/Code/games/test/libs/phaser/phaser.min.js:8:24598
    at Object.<anonymous> (/Users/healy/Code/games/test/libs/phaser/phaser.min.js:9:15244)
    at Module._compile (module.js:425:26)
    at loader (/usr/local/lib/node_modules/babel-cli/node_modules/babel-register/lib/node.js:146:5)
    at Object.require.extensions.(anonymous function) [as .js] (/usr/local/lib/node_modules/babel-cli/node_modules/babel-register/lib/node.js:156:7)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:311:12)

Вопрос 1

Правильно ли я настраиваю проект? Я чувствую, что Phaser.js следует высмеивать или как-то опускать основной код? Особенно, если это ссылка на document. Любая помощь здесь будет высоко оценена. Не стесняйтесь присылать мне ссылку, чтобы помочь мне внедрить внешние библиотеки в веб-приложение с набором тестов.

вопрос 2

Уместно ли здесь babel-node --presets es2015? Я не слишком уверен, что он делает.


Ответы:


1

1) Когда вы используете жасмин с узлом, ваши тесты запускаются в среде узла. В узле нет ни окна, ни документа. Эти объекты доступны только в браузере. К счастью, вы можете издеваться над ними, используя jsdom.

Кроме того, вы можете увидеть эту статью, чтобы узнать, как настроить тестовую среду.

2) Актуален пресет Babel. Пресет — это просто вид конфигурации и/или плагина. Подумайте об использовании preset-es2015, если вы хотите использовать только стабильные функции ECMAScript, или preset-stage-0, если вам нужны новейшие и нестабильные функции.

Удачи!

25.09.2016
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..