質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Karma

Karma(元Testacular)は、node.jsベースのJavaScriptテストランナー。AngularJSのテストフレームワークとして開発されたもので、クライアントサイドのJavaScriptコードのテストを容易に実行できます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

Q&A

解決済

1回答

2196閲覧

FileReaderによるBlobの読み込みがKarmaでのテストにおいてChromeでは発生しません。

hyoujun

総合スコア10

Karma

Karma(元Testacular)は、node.jsベースのJavaScriptテストランナー。AngularJSのテストフレームワークとして開発されたもので、クライアントサイドのJavaScriptコードのテストを容易に実行できます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

0グッド

0クリップ

投稿2018/10/01 04:13

編集2018/10/01 10:28

前提・実現したいこと

TypeScriptで書いたものをKarmaを使ってテストしています。
Blobの中身を検証したいので、FileReaderを使って読み込もうとしています。
FireFoxではうまく行く(想定通り失敗する)のですが、Chromeではexpect()にたどり着きません。
Chromeでも想定通り失敗する解決法はありますでしょうか?
よろしくお願いいたします。

該当のソースコード

'foo'と'bar'の同一性を比較しているので失敗するはず。

TypeScript

1let blob = new Blob(['foo'], {type: 'text/plain'}); 2let reader = new FileReader(); 3reader.addEventListener('load', ()=>{ 4 expect(reader.result).toBe('bar'); 5}//テストにおいてChromeではイベントが発生しないようです。 6reader.readAsText(blob);

試したこと

テストがファイルの読み込み前に終了してしまうのかと思ったので、ファイルの読み込みが終わるまでkarmaを待たせるためにFileReaderのreadyStateプロパティが、2になるまでループするようにしたのですが、それもうまく行かず(ERROR [karma]: illegal access)、「baz」は一度も出ません。

TypeScript

1let blob = new Blob(['foo'], {type: 'text/plain'}); 2let reader = new FileReader(); 3reader.addEventListener('load', ()=>{ 4 expect(reader.result).toBe('bar'); 5} 6reader.readAsText(blob); 7while(reader.readyState != 2) { 8 console.log('baz');//一度も実行されない 9}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

jasmine2.0からは、引数にdoneと書き、それを中で実行すれば、非同期の実行が完了するまで待ってくれるようです。

Typescript

1it('test', (done)=>{//1.引数のdoneを 2 let blob = new Blob(['foo'], {type: 'text/plain'}); 3 let reader = new FileReader(); 4 reader.addEventListener('load', ()=>{ 5 expect(reader.result).toBe('bar');//3.load完了後に評価される 6 } 7 reader.readAsText(blob); 8 done()//2.ここで実行すると

jasmineのAsynchronous Support

投稿2018/10/01 12:38

hyoujun

総合スコア10

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問