Why not login to Qiita and try out its useful features?

We'll deliver articles that match you.

You can read useful information later.

5
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Backbone.jsのEventテストでハマった話

Posted at

ハマったコード

下記のcoffeescriptのコードをjsTestDriverでテストします。なお私の場合Backbone.jsを使ってハマりましたが、基本的にはjQueryのonでも同じ結果になると思われます。

eventsample.coffee
class @EventSample
  constructor: ->
    @func = null

    Backbone.on("test", => @.onTest())

  onTest: ->
    @func()
  • イベント "test" が発生するとonTest()を実行するだけのクラスです。
  • onTest()は@func()を実行します。しかし@funcは初期値はnullです。

テストコードは下記です。

test.coffee
TestCase "Test1",
  setUp: ->
    @event = new EventSample()

  "test1": ->
    assertNull(@event.func)

TestCase "Test2",
  setUp: ->
    @event = new EventSample()
    @event.func = ->
      console.log "dummy"

  "test2": ->
    Backbone.trigger "test"
    assertNotNull(@event.func)
  • Test1はクラスを初期化して、@funcがnullであることを確認するだけのテストです。
  • Test2は@funcに適当に関数を設定して、イベント"test"を発行するテストです。@func()が実行されるはずです。

どうハマったか

上記のテストを実行すると、Test2でなぜか@funcがnullで実行できないというエラーが発生します。
test_coffee_-BackboneEventSample-___Develop_PhpstormProjects_BackboneEventSample.png

原因

Test2の実行時もTest1で生成した@eventのインスタンスが残っているのが原因。イベント"test"を発行すると、Test1, Test2両方の@eventのonTest()が実行される。Test1の@event.funcはnullなので当然関数としては実行できずエラーとなってしまう。

解決方法

下記のように、onで登録したイベントを解除する関数を追加する。

eventsample.coffee
class @EventSample
  constructor: ->
    @func = null

    Backbone.on("test", => @.onTest())

  #追加
  unbindEvent: ->
    Backbone.off("test")

  onTest: ->
    @func()

テストでは、 tearDownで登録したイベントを解除 します。

test.coffee
TestCase "Test1",
  setUp: ->
    @event = new EventSample()

  tearDown: ->
    @event.unbindEvent()

  "test1": ->
    assertNull(@event.func)

TestCase "Test2",
  setUp: ->
    @event = new EventSample()
    @event.func = ->
      console.log "dummy"

  tearDown: ->
    @event.unbindEvent()

  "test2": ->
    Backbone.trigger "test"
    assertNotNull(@event.func)

下記のようにテストがOKになりました。
test_coffee_-BackboneEventSample-___Develop_PhpstormProjects_BackboneEventSample.png

5
5
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up

Qiita Conference 2025 will be held!: 4/23(wed) - 4/25(Fri)

Qiita Conference is the largest tech conference in Qiita!

Keynote Speaker

ymrl、Masanobu Naruse, Takeshi Kano, Junichi Ito, uhyo, Hiroshi Tokumaru, MinoDriven, Minorun, Hiroyuki Sakuraba, tenntenn, drken, konifar

View event details
5
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?