【问题标题】:Require.JS and JS Test Driver: Unexpected token <Require.JS 和 JS 测试驱动程序:意外的令牌 <
【发布时间】:2012-06-07 09:47:29
【问题描述】:

我正在尝试测试通过 RequireJS 加载的简单主干模型:

define ["backbone"], (Backbone)->

    class Todo extends Backbone.Model 
        defaults:
            title: ''
            priority: 0
            done: false

        validate: (attrs) -> 
            errs = {}
            hasErrors = false

            if (attrs.title is "")
                hasErrors = true
                errs.title = "Please specify a todo"

            if hasErrors
                return errs

        toggleDone: ->
            @save("done", !@get("done"))

    return Todo

我的测试看起来像:

requirejs.config 
    baseUrl: "js/"
    paths: 
        jquery: "https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min"
        jqueryui: "https://ajax.googleapis.com/ajax/libs/jqueryui/1/jquery-ui.min"
        json2: "http://ajax.cdnjs.com/ajax/libs/json2/20110223/json2"
        underscore: "http://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.3.3/underscore-min"
        backbone: "http://cdnjs.cloudflare.com/ajax/libs/backbone.js/0.9.2/backbone-min"
        backboneLocalStorage: "https://raw.github.com/jeromegn/Backbone.localStorage/master/backbone.localStorage-min"
    shim: 
        "underscore":
            exports: "_"
        "backbone": 
            deps: ["jquery", "underscore", "json2"]
            exports: "Backbone"
        "jqueryui": 
            deps: ["jquery"]
        "backboneLocalStorage":
            deps: ["backbone"]
            exports: "Backbone.LocalStorage"

require ["models/todo"], (Todo) ->

    console.log Todo

    TodoTests = TestCase("TodoTests")

    TodoTests::testCreateTodo = -> 
        todo = new Todo({ title: "Hello" })
        assertEquals "Hello", todo.get("title")
        assertEquals 0, todo.get("priority")
        assertEquals false, todo.get("done")

JS 测试驱动配置:

server: http://localhost:3001

load:
  - ../public/js/libs/require.js
  - ../public/js/tests.js

serve:
  - ../public/js/models/*
  - ../public/js/collections/*
  - ../public/js/views/*

从 Chrome 控制台上的 JS 测试驱动程序监听页面看到的问题:

Uncaught SyntaxError: Unexpected token

从 Chrome 看 Todo.js,

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><title>Console Runner</title><script type="text/javascript">var start = new Date().getTime();</script>
Uncaught SyntaxError: Unexpected token <
<script src="/static/lib/json2.js" type="text/javascript"></script><script src="/static/lib/json_sans_eval.js" type="text/javascript"></script><script src="/static/jstestdrivernamespace.js" type="text/javascript"></script><script src="/static/lib/jquery-min.js" type="text/javascript"></script><script src="/static/runner.js" type="text/javascript"></script><script type="text/javascript">jstestdriver.runConfig = {'debug':false};</script>
<script type="text/javascript">jstestdriver.console = new jstestdriver.Console();

注意它是一个 HTML 页面,而不是我的实际 JS。此外,console.log(Todo) 返回 undefined,因为返回的是 HTML 页面而不是 JS。我是不是配置错了?

【问题讨论】:

  • 确保使用所有空格或所有制表符进行缩进。这会给你带来问题:)

标签: coffeescript requirejs js-test-driver


【解决方案1】:

我为此苦苦挣扎了好几天,并无休止地用谷歌搜索,直到我最终发现 JsTestDriver 在做什么。在您的 requirejs.config 中,为了让您的测试正常运行,您的 baseUrl 需要:

baseUrl: /test/path/to/your/stuff

原因是当 JsTestDriver 创建它的服务器时,它会将/test/ 添加到所有目录中。如果baseUrl 设置不正确,它会开始尝试向本地发回我认为的对窗口的引用。

我看到您可能遇到的唯一其他问题是使用 require 语句作为第一行运行测试。我有 Jasmine 并将我的 require() 放在我的测试顶部导致它们永远不会运行,所以我必须在我的 beforeEach 中为我的测试执行它并在它们运行之前获取对象。

虽然我看到无数其他人声称 Jasmine 中的 require 语句有效,但我可能做错了什么,所以我的搜索仍在继续。

【讨论】:

    【解决方案2】:

    您检查过您的 ajax 响应吗?我只是有同样的事情,'

    【讨论】:

      猜你喜欢
      • 2017-09-14
      • 1970-01-01
      • 2016-01-20
      • 2023-03-12
      • 2017-09-05
      • 2017-05-01
      • 1970-01-01
      • 2017-12-13
      • 1970-01-01
      相关资源
      最近更新 更多